/* ===== Reset & Base ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }
body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans SC", sans-serif; color: #333; line-height: 1.6; background: #f8fafc; }
a { color: #2563eb; text-decoration: none; }
a:hover { color: #1d4ed8; }
img { max-width: 100%; height: auto; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 1rem; }
.container-sm { max-width: 600px; }
.text-center { text-align: center; }
.text-muted { color: #64748b; font-size: .9rem; }
.required { color: #dc2626; }

/* ===== Buttons ===== */
.btn { display: inline-block; padding: .55rem 1.2rem; border-radius: 8px; font-size: .9rem; font-weight: 500; border: none; cursor: pointer; transition: all .2s; text-align: center; }
.btn-primary { background: #2563eb; color: #fff; }
.btn-primary:hover { background: #1d4ed8; color: #fff; }
.btn-secondary { background: #3b82f6; color: #fff; }
.btn-secondary:hover { background: #2563eb; }
.btn-outline { background: transparent; border: 1.5px solid #2563eb; color: #2563eb; }
.btn-outline:hover { background: #2563eb; color: #fff; }
.btn-white { background: #fff; color: #2563eb; }
.btn-white:hover { background: #f1f5f9; }
.btn-danger { background: #dc2626; color: #fff; }
.btn-danger:hover { background: #b91c1c; }
.btn-sm { padding: .35rem .8rem; font-size: .8rem; }
.btn-lg { padding: .75rem 2rem; font-size: 1rem; }
.btn-block { display: block; width: 100%; }

/* ===== Header ===== */
.site-header { background: #fff; box-shadow: 0 2px 12px rgba(0,0,0,.06); position: sticky; top: 0; z-index: 100; }
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: .875rem 1rem; }
.logo { display: flex; align-items: center; gap: .625rem; font-size: 1.25rem; font-weight: 700; color: #2563eb; }
.logo-img { height: 38px; width: auto; vertical-align: middle; }
.nav-list { display: flex; list-style: none; gap: 1.5rem; align-items: center; }
.nav-list a { color: #475569; font-weight: 500; font-size: .95rem; transition: color .2s; }
.nav-list a:hover, .nav-list a.active { color: #2563eb; }
.menu-toggle { display: none; background: none; border: none; font-size: 1.5rem; cursor: pointer; color: #475569; }

/* ===== Hero ===== */
.hero { position: relative; min-height: 520px; display: flex; align-items: center; color: #fff; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 50%, #1e40af 100%); z-index: 0; background-size: cover; background-position: center; }
.hero-pattern { position: absolute; inset: 0; background-image: radial-gradient(circle at 20% 80%, rgba(255,255,255,.08) 0%, transparent 50%), radial-gradient(circle at 80% 20%, rgba(255,255,255,.06) 0%, transparent 40%); }
.hero-content { position: relative; z-index: 1; text-align: center; padding: 4rem 1rem; }
.hero-title { font-size: 2.75rem; font-weight: 800; margin-bottom: 1rem; letter-spacing: -.02em; }
.hero-subtitle { font-size: 1.2rem; opacity: .92; margin-bottom: 2rem; max-width: 560px; margin-left: auto; margin-right: auto; }
.hero-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ===== Sections ===== */
.section { padding: 1.5rem 0; }
.section:nth-child(even) { background: #fff; }
.section-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1.5rem; }
.section-title { font-size: 1.6rem; font-weight: 700; color: #1e293b; position: relative; padding-left: 1rem; }
.section-title::before { content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 4px; height: 1.4rem; background: #2563eb; border-radius: 2px; }
.section-more { font-size: .9rem; color: #2563eb; font-weight: 500; }
.section-more:hover { color: #1d4ed8; }
.section-subtitle { text-align: center; color: #64748b; margin-top: -.5rem; margin-bottom: 1.5rem; font-size: 1rem; }
.page-title { font-size: 1.8rem; font-weight: 700; margin-bottom: 1.5rem; text-align: center; color: #1e293b; }
.empty-text { text-align: center; color: #94a3b8; padding: 2rem 0; font-size: 1rem; }

/* ===== Features ===== */
.features-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; }
.feature-card { background: #fff; padding: 2rem; border-radius: 16px; text-align: center; box-shadow: 0 4px 16px rgba(0,0,0,.04); border: 1px solid #e2e8f0; transition: all .3s; }
.feature-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(5,150,105,.12); }
.feature-icon { width: 64px; height: 64px; margin: 0 auto 1.25rem; background: linear-gradient(135deg, #ecfdf5, #d1fae5); border-radius: 16px; display: flex; align-items: center; justify-content: center; font-size: 1.75rem; }
.feature-title { font-size: 1.1rem; font-weight: 600; margin-bottom: .5rem; color: #1e293b; }
.feature-desc { font-size: .9rem; color: #64748b; line-height: 1.7; }

/* ===== Event Cards ===== */
.events-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.25rem; }
.event-card { background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 4px 16px rgba(0,0,0,.04); border: 1px solid #e2e8f0; transition: all .3s; }
.event-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(37,99,235,.12); }
.event-card-img { position: relative; height: 200px; overflow: hidden; }
.event-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.event-card:hover .event-card-img img { transform: scale(1.06); }
.event-area { position: absolute; top: .875rem; left: .875rem; background: rgba(37,99,235,.9); color: #fff; padding: .25rem .875rem; border-radius: 20px; font-size: .8rem; font-weight: 500; }
.event-badge { position: absolute; top: .875rem; right: .875rem; background: #3b82f6; color: #fff; padding: .25rem .75rem; border-radius: 20px; font-size: .75rem; font-weight: 600; }
.event-badge.countdown-badge { background: #f59e0b; animation: pulse 2s infinite; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: .8; } }
.event-card-body { padding: 1.5rem; }
.event-card-title { font-size: 1.15rem; font-weight: 600; margin-bottom: .5rem; color: #1e293b; line-height: 1.4; }
.event-card-subtitle { font-size: .875rem; color: #64748b; margin-bottom: .75rem; }
.event-card-meta { font-size: .875rem; color: #64748b; display: flex; flex-direction: column; gap: .375rem; margin-bottom: 1.25rem; }
.event-card-meta span { display: flex; align-items: center; gap: .375rem; }

/* ===== Event Detail ===== */
.event-detail-header { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; margin-bottom: 2.5rem; align-items: start; }
.event-detail-img img { width: 100%; border-radius: 16px; }
.event-detail-content { position: sticky; top: 100px; }
.event-detail-title { font-size: 1.9rem; font-weight: 700; margin-bottom: .625rem; color: #1e293b; }
.event-detail-subtitle { color: #64748b; margin-bottom: 1.25rem; font-size: 1.05rem; }
.event-detail-meta { display: flex; flex-direction: column; gap: .75rem; margin-bottom: 1.25rem; }
.meta-item { display: flex; align-items: flex-start; gap: .75rem; font-size: .95rem; }
.meta-label { font-weight: 600; min-width: 80px; color: #475569; }
.meta-value { color: #1e293b; }
.event-detail-actions { display: flex; gap: 1rem; margin-top: 1.75rem; }
.event-countdown { font-size: 1.1rem; font-weight: 600; color: #3b82f6; margin: .625rem 0; display: flex; align-items: center; gap: .5rem; }
.event-status-live { display: inline-block; background: #3b82f6; color: #fff; padding: .375rem 1rem; border-radius: 20px; font-size: .9rem; font-weight: 600; margin: .625rem 0; }

/* ===== Organizers ===== */
.organizers-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1.25rem; }
.organizer-card { background: #fff; padding: 1.75rem; border-radius: 16px; text-align: center; box-shadow: 0 4px 16px rgba(0,0,0,.04); border: 1px solid #e2e8f0; transition: all .3s; }
.organizer-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(37,99,235,.08); }
.organizer-logo { width: 64px; height: 64px; object-fit: contain; margin-bottom: 1rem; border-radius: 12px; }
.organizer-name { font-size: 1.05rem; font-weight: 600; margin-bottom: .375rem; color: #1e293b; }
.organizer-type { font-size: .8rem; color: #2563eb; display: inline-block; background: #eff6ff; padding: .2rem .75rem; border-radius: 20px; margin: .5rem 0; font-weight: 500; }
.organizer-desc { font-size: .85rem; color: #64748b; margin-top: .625rem; line-height: 1.6; }

/* ===== Gallery ===== */
.gallery-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1rem; }
.gallery-item { border-radius: 12px; overflow: hidden; position: relative; cursor: pointer; }
.gallery-item img { width: 100%; height: 180px; object-fit: cover; transition: transform .4s; }
.gallery-item:hover img { transform: scale(1.08); }
.gallery-caption { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(transparent, rgba(0,0,0,.7)); color: #fff; padding: 2rem .75rem .625rem; font-size: .875rem; font-weight: 500; }

/* ===== Reviews ===== */
.review-tabs { display: flex; gap: .625rem; margin-bottom: 1.75rem; justify-content: center; flex-wrap: wrap; }
.review-tab { padding: .625rem 1.75rem; border: 1.5px solid #e2e8f0; border-radius: 30px; background: #fff; cursor: pointer; font-size: .95rem; font-weight: 500; color: #64748b; transition: all .2s; }
.review-tab:hover { border-color: #3b82f6; color: #3b82f6; }
.review-tab.active { background: #2563eb; color: #fff; border-color: #2563eb; }
.review-panel { display: none; }
.review-panel.active { display: block; }
.reviews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.25rem; }
.review-card { background: #fff; padding: 1.75rem; border-radius: 16px; box-shadow: 0 4px 16px rgba(0,0,0,.04); border: 1px solid #e2e8f0; }
.review-stars { margin-bottom: .875rem; font-size: 1rem; }
.review-content { font-size: .95rem; color: #475569; margin-bottom: 1.25rem; line-height: 1.7; }
.review-author { display: flex; align-items: center; gap: .75rem; font-size: .875rem; }
.review-avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; background: #d1fae5; }
.review-author-info { display: flex; flex-direction: column; }
.review-name { font-weight: 600; color: #1e293b; }
.review-company { color: #94a3b8; font-size: .8rem; }

/* ===== News ===== */
.news-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.25rem; }
.news-card { background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 4px 16px rgba(0,0,0,.04); border: 1px solid #e2e8f0; display: flex; flex-direction: column; transition: all .3s; }
.news-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(37,99,235,.1); }
.news-card-img { height: 200px; overflow: hidden; }
.news-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.news-card:hover .news-card-img img { transform: scale(1.05); }
.news-card-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.news-card-date { font-size: .8rem; color: #3b82f6; margin-bottom: .5rem; font-weight: 500; }
.news-card-title { font-size: 1.1rem; font-weight: 600; margin-bottom: .625rem; color: #1e293b; line-height: 1.4; }
.news-card-excerpt { font-size: .875rem; color: #64748b; line-height: 1.7; flex: 1; }
.news-card-more { margin-top: 1rem; font-weight: 500; font-size: .9rem; }

/* ===== Forms ===== */
.form-card { background: #fff; padding: 2.5rem; border-radius: 16px; box-shadow: 0 4px 20px rgba(0,0,0,.06); border: 1px solid #e2e8f0; }
.form-group { margin-bottom: 1.5rem; }
.form-group label { display: block; margin-bottom: .5rem; font-weight: 600; font-size: .95rem; color: #374151; }
.form-group input, .form-group select, .form-group textarea { width: 100%; padding: .75rem 1rem; border: 1.5px solid #e2e8f0; border-radius: 10px; font-size: 1rem; transition: all .2s; background: #fff; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: #2563eb; outline: none; box-shadow: 0 0 0 3px rgba(37,99,235,.1); }
.form-group input::placeholder { color: #94a3b8; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.form-hint { font-size: .8rem; color: #94a3b8; margin-top: .375rem; }

/* ===== Alerts ===== */
.alert { padding: 1rem 1.25rem; border-radius: 10px; margin-bottom: 1.25rem; font-size: .9rem; }
.alert-error { background: #fef2f2; color: #b91c1c; border-left: 4px solid #dc2626; }
.alert-success { background: #f0fdf4; color: #166534; border-left: 4px solid #059669; }
.alert-info { background: #eff6ff; color: #1e40af; border-left: 4px solid #2563eb; }

/* ===== Member Center ===== */
.member-header { display: flex; align-items: center; gap: 1.75rem; background: #fff; padding: 2rem; border-radius: 16px; box-shadow: 0 4px 20px rgba(0,0,0,.06); border: 1px solid #e2e8f0; }
.member-avatar { width: 72px; height: 72px; border-radius: 50%; overflow: hidden; background: linear-gradient(135deg, #eff6ff, #dbeafe); display: flex; align-items: center; justify-content: center; }
.avatar-placeholder { font-size: 1.75rem; font-weight: 700; color: #2563eb; }
.member-avatar img { width: 100%; height: 100%; object-fit: cover; }
.member-info h1 { font-size: 1.4rem; font-weight: 700; margin-bottom: .25rem; color: #1e293b; }
.member-info p { color: #64748b; }

/* ===== Registration Cards ===== */
.reg-list { display: grid; gap: 1rem; }
.reg-card { background: #fff; padding: 1.5rem; border-radius: 14px; box-shadow: 0 4px 16px rgba(0,0,0,.04); border: 1px solid #e2e8f0; }
.reg-card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: .875rem; }
.reg-no { font-weight: 700; color: #2563eb; font-size: 1rem; }
.reg-status { padding: .25rem .75rem; border-radius: 16px; font-size: .8rem; font-weight: 600; }
.status-pending { background: #fef3c7; color: #92400e; }
.status-confirmed { background: #dcfce7; color: #166534; }
.status-cancelled { background: #fee2e2; color: #b91c1c; }
.reg-checked { color: #2563eb; font-weight: 700; display: flex; align-items: center; gap: .375rem; }
.reg-card-body h3 { font-size: 1.1rem; margin-bottom: .375rem; color: #1e293b; }

/* ===== Success Page ===== */
.success-card { background: #fff; padding: 3rem; border-radius: 20px; box-shadow: 0 8px 32px rgba(0,0,0,.08); max-width: 480px; margin: 0 auto; }
.success-icon { font-size: 3.5rem; margin-bottom: 1.25rem; }
.success-regno { font-size: 1.15rem; margin: 1.25rem 0; font-weight: 600; color: #2563eb; }
.success-info { text-align: left; margin: 1.75rem 0; }
.success-info p { margin: .5rem 0; display: flex; justify-content: space-between; }
.success-info .label { color: #64748b; }
.success-info .value { font-weight: 600; color: #1e293b; }
.qr-code-box { margin: 1.75rem 0; text-align: center; }
.qr-placeholder { display: inline-block; padding: 1rem; background: #f8fafc; border-radius: 12px; }
.qr-hint { font-size: .875rem; color: #94a3b8; margin-top: .625rem; }
.success-actions { display: flex; gap: 1rem; justify-content: center; margin-top: 1.75rem; }

/* ===== Modal ===== */
.modal { display: none; position: fixed; inset: 0; z-index: 200; background: rgba(0,0,0,.5); align-items: center; justify-content: center; }
.modal.active { display: flex; }
.modal-content { background: #fff; border-radius: 16px; width: 90%; max-width: 420px; overflow: hidden; }
.modal-header { display: flex; justify-content: space-between; align-items: center; padding: 1.25rem 1.5rem; border-bottom: 1px solid #e2e8f0; }
.modal-title { font-size: 1.15rem; font-weight: 700; color: #1e293b; }
.modal-close { background: none; border: none; font-size: 1.5rem; cursor: pointer; color: #94a3b8; }
.modal-close:hover { color: #475569; }
.modal-body { padding: 1.5rem; }

/* ===== Login Page ===== */
.login-page { display: flex; align-items: center; justify-content: center; min-height: 100vh; background: linear-gradient(135deg, #2563eb, #1d4ed8); }
.login-card { background: #fff; padding: 2.5rem; border-radius: 20px; box-shadow: 0 12px 40px rgba(0,0,0,.15); width: 90%; max-width: 400px; }
.login-card h1 { text-align: center; margin-bottom: .5rem; font-size: 1.5rem; color: #1e293b; }
.login-card .login-subtitle { text-align: center; color: #64748b; margin-bottom: 2rem; }
.login-tabs { display: flex; margin-bottom: 1.5rem; border-bottom: 2px solid #e2e8f0; }
.login-tab { flex: 1; padding: .75rem; text-align: center; cursor: pointer; font-weight: 600; color: #64748b; border-bottom: 2px solid transparent; margin-bottom: -2px; }
.login-tab.active { color: #2563eb; border-bottom-color: #2563eb; }

/* ===== Footer ===== */
.site-footer { background: #1e293b; color: #94a3b8; padding: 3rem 0 1.5rem; margin-top: 0; }
.footer-inner { display: flex; justify-content: space-between; align-items: start; flex-wrap: wrap; gap: 2rem; }
.footer-section { flex: 1; min-width: 180px; }
.footer-title { font-size: 1.1rem; font-weight: 700; color: #fff; margin-bottom: 1.25rem; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: .625rem; }
.footer-links a { color: #94a3b8; font-size: .9rem; transition: color .2s; }
.footer-links a:hover { color: #60a5fa; }
.footer-bottom { margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid #334155; text-align: center; font-size: .875rem; }
.footer-name { font-weight: 700; color: #fff; margin-bottom: .375rem; font-size: 1.1rem; }

/* ===== About Section ===== */
.about-section { background: linear-gradient(180deg, #f8fafc 0%, #fff 50%); }
.about-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 4rem; align-items: center; }
.about-image { border-radius: 20px; overflow: hidden; box-shadow: 0 12px 40px rgba(0,0,0,.1); }
.about-image img { width: 100%; height: auto; }
.about-content h2 { font-size: 1.75rem; font-weight: 700; margin-bottom: 1rem; color: #1e293b; }
.about-content h2 span { color: #2563eb; }
.about-content p { color: #475569; margin-bottom: 1.25rem; line-height: 1.8; font-size: 1rem; }
.about-stats { display: flex; gap: 2.5rem; margin-top: 2rem; }
.stat-item { text-align: center; }
.stat-number { font-size: 2.25rem; font-weight: 800; color: #2563eb; }
.stat-label { font-size: .875rem; color: #64748b; }

/* ===== Cooperation ===== */
.coop-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.coop-card { background: #fff; padding: 2rem; border-radius: 16px; text-align: center; box-shadow: 0 4px 16px rgba(0,0,0,.04); border: 1px solid #e2e8f0; transition: all .3s; }
.coop-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(37,99,235,.1); border-color: #3b82f6; }
.coop-icon { width: 72px; height: 72px; margin: 0 auto 1.25rem; background: linear-gradient(135deg, #eff6ff, #dbeafe); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.75rem; }
.coop-title { font-size: 1.15rem; font-weight: 700; margin-bottom: .625rem; color: #1e293b; }
.coop-desc { font-size: .9rem; color: #64748b; line-height: 1.7; }

/* ===== Back to Top ===== */
.back-top { position: fixed; bottom: 2rem; right: 2rem; width: 44px; height: 44px; border-radius: 50%; background: #2563eb; color: #fff; border: none; font-size: 1.25rem; cursor: pointer; display: none; z-index: 50; box-shadow: 0 4px 16px rgba(0,0,0,.2); transition: all .2s; }
.back-top:hover { background: #1d4ed8; transform: translateY(-2px); }

/* ===== Responsive ===== */
@media (max-width: 768px) {
    .nav-list { display: none; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: #fff; padding: .75rem 1rem; box-shadow: 0 8px 24px rgba(0,0,0,.1); }
    .nav-list.active { display: flex; }
    .menu-toggle { display: block; }
    .hero-content { padding: 2.5rem .75rem; }
    .hero-title { font-size: 1.5rem; }
    .hero-subtitle { font-size: .9rem; margin-bottom: 1.25rem; }
    .hero-actions { flex-direction: column; align-items: center; gap: .75rem; }
    .section { padding: .75rem 0; }
    .section-header { margin-bottom: 1rem; }
    .section-title { font-size: 1.25rem; }
    .section-subtitle { font-size: .9rem; margin-top: -.25rem; margin-bottom: 1rem; }
    .event-card-img { height: 160px; }
    .event-card-body { padding: 1rem; }
    .event-card-title { font-size: 1rem; }
    .event-detail-header { grid-template-columns: 1fr; gap: 1.25rem; }
    .event-detail-title { font-size: 1.35rem; }
    .event-detail-actions { flex-direction: column; gap: .75rem; }
    .form-row { grid-template-columns: 1fr; }
    .form-card { padding: 1.25rem; }
    .footer-inner { flex-direction: column; text-align: center; gap: 1rem; }
    .footer-section { width: 100%; }
    .events-grid { grid-template-columns: 1fr; }
    .news-grid { grid-template-columns: 1fr; }
    .member-header { flex-direction: column; text-align: center; padding: 1.25rem; }
    .about-grid { grid-template-columns: 1fr; gap: 1.5rem; }
    .about-stats { justify-content: center; gap: 1.5rem; }
    .about-content h2 { font-size: 1.35rem; }
    .coop-grid { grid-template-columns: 1fr; }
    .features-grid { grid-template-columns: 1fr; }
    .feature-card { padding: 1.25rem; }
    .gallery-grid { grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: .75rem; }
    .gallery-item img { height: 120px; }
    .review-card { padding: 1.25rem; }
    .news-card-body { padding: 1rem; }
    .organizer-card { padding: 1.25rem; }
}
/* ===== Rich Text (Quill output) ===== */
.rich-text { color: #475569; font-size: .95rem; line-height: 1.7; }
.rich-text p { margin-bottom: 1.25rem; }
.rich-text img { max-width: 100%; height: auto; border-radius: 12px; margin: 1rem 0; }
.rich-text h1, .rich-text h2, .rich-text h3 { margin-top: 1.5rem; margin-bottom: .75rem; color: #1e293b; }
.rich-text ul, .rich-text ol { margin-left: 1.5rem; margin-bottom: 1rem; }
.rich-text a { color: #2563eb; text-decoration: underline; }