/* ===== INFO SECTION ===== */
.info-section {
    background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
    padding: 64px 24px;
    position: relative;
}

.info-container {
    max-width: 880px;
    margin: 0 auto;
}

/* Main Title */
.info-title {
    font-size: 32px;
    font-weight: 900;
    color: #0f172a;
    text-align: center;
    margin: 0 0 36px;
    letter-spacing: -0.8px;
    line-height: 1.2;
}

/* Info Box */
.info-box {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 16px;
    padding: 32px 36px;
    margin-bottom: 40px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04), 0 1px 3px rgba(0, 0, 0, 0.02);
    transition: box-shadow 0.3s ease;
}

.info-box:hover {
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.06);
}

.info-text {
    font-size: 15px;
    color: #475569;
    line-height: 1.85;
    margin: 0 0 18px;
}

.info-text strong { color: #0f172a; font-weight: 700; }

.info-list {
    list-style: none;
    padding: 0;
    margin: 18px 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.info-list li {
    font-size: 14.5px;
    color: #475569;
    line-height: 1.75;
    padding-left: 24px;
    position: relative;
}

.info-list li:before {
    content: "";
    position: absolute;
    left: 0;
    top: 9px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, #f97316, #f59e0b);
}

.info-date {
    font-size: 13px;
    color: #94a3b8;
    margin: 18px 0 0;
    padding-top: 16px;
    border-top: 1px solid #f1f5f9;
}

.info-date strong { color: #64748b; }

/* Section Divider */
.section-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, #e2e8f0, transparent);
    margin: 48px 0;
}

/* Section Title */
.section-title {
    font-size: 24px;
    font-weight: 800;
    color: #0f172a;
    margin: 0 0 16px;
    text-align: center;
    letter-spacing: -0.5px;
    line-height: 1.3;
}

.section-description {
    font-size: 15px;
    color: #64748b;
    line-height: 1.75;
    margin-bottom: 28px;
    text-align: center;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

/* Steps List */
.steps-list {
    list-style: none;
    padding: 0;
    margin: 0 0 12px;
    counter-reset: step-counter;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.steps-list li {
    font-size: 15px;
    color: #475569;
    line-height: 1.75;
    padding-left: 40px;
    position: relative;
    counter-increment: step-counter;
}

.steps-list li:before {
    content: counter(step-counter);
    position: absolute;
    left: 0;
    top: 2px;
    color: #ffffff;
    background: linear-gradient(135deg, #f97316, #ea580c);
    width: 26px;
    height: 26px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 12px;
    line-height: 26px;
    text-align: center;
    box-shadow: 0 2px 6px rgba(249, 115, 22, 0.3);
}

/* Content Boxes */
.masjid-box,
.why-box,
.history-box,
.contact-box,
.fine-box,
.sms-box {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 16px;
    padding: 32px 36px;
    margin-bottom: 12px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
    transition: all 0.3s ease;
}

.masjid-box:hover, .why-box:hover, .history-box:hover,
.contact-box:hover, .fine-box:hover, .sms-box:hover {
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.06);
    transform: translateY(-2px);
}

.masjid-box   { border-left: 4px solid #f97316; }
.why-box      { border-left: 4px solid #3b82f6; }
.history-box  { border-left: 4px solid #10b981; }
.contact-box  { border-left: 4px solid #8b5cf6; }
.fine-box     { border-left: 4px solid #ef4444; }
.sms-box      { border-left: none; }

.masjid-text,
.why-text,
.history-text,
.contact-text,
.fine-intro,
.sms-intro {
    font-size: 15px;
    color: #475569;
    line-height: 1.85;
    margin: 0 0 16px;
    text-align: justify;
}

.contact-text:last-child,
.masjid-text:last-child,
.why-text:last-child,
.history-text:last-child { margin-bottom: 0; }

/* SMS */
.sms-instructions { margin: 24px 0; }

.sms-instruction-item { margin-bottom: 24px; }
.sms-instruction-item:last-child { margin-bottom: 0; }

.instruction-title {
    font-size: 15px;
    font-weight: 700;
    color: #0f172a;
    margin: 0 0 14px;
}

.instruction-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.instruction-list li {
    padding-left: 24px;
    position: relative;
}

.instruction-list li:before {
    content: "";
    position: absolute;
    left: 0;
    top: 8px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, #f97316, #f59e0b);
}

.instruction-label {
    display: block;
    font-size: 14.5px;
    color: #475569;
    line-height: 1.7;
    margin-bottom: 4px;
}

.instruction-example {
    display: block;
    font-size: 13.5px;
    color: #94a3b8;
    font-style: italic;
    line-height: 1.6;
}

.instruction-text {
    font-size: 14.5px;
    color: #475569;
    line-height: 1.7;
    margin: 0 0 8px;
}

/* SMS Note */
.sms-note {
    background: linear-gradient(135deg, #fffbeb, #fef3c7);
    border-left: 4px solid #f59e0b;
    padding: 16px 20px;
    border-radius: 12px;
    margin-top: 24px;
}

.note-text {
    font-size: 14px;
    color: #92400e;
    margin: 0;
    line-height: 1.7;
}

.note-text strong { color: #78350f; font-weight: 700; }

/* Fine */
.fine-subtitle {
    font-size: 15px;
    color: #0f172a;
    font-weight: 600;
    line-height: 1.75;
    margin: 0 0 18px;
}

.fine-list {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: fine-counter;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.fine-list li {
    font-size: 14.5px;
    color: #475569;
    line-height: 1.75;
    padding-left: 40px;
    position: relative;
    counter-increment: fine-counter;
}

.fine-list li:before {
    content: counter(fine-counter);
    position: absolute;
    left: 0;
    top: 2px;
    color: #ffffff;
    background: linear-gradient(135deg, #f97316, #ea580c);
    width: 26px;
    height: 26px;
    border-radius: 50%;
    font-weight: 800;
    font-size: 12px;
    line-height: 26px;
    text-align: center;
    box-shadow: 0 2px 6px rgba(249, 115, 22, 0.3);
}

/* Responsive */
@media (max-width: 768px) {
    .info-section { padding: 48px 16px; }
    .info-title { font-size: 26px; margin-bottom: 28px; }
    .info-box, .masjid-box, .why-box, .history-box,
    .contact-box, .fine-box, .sms-box { padding: 24px 24px; }
    .section-title { font-size: 21px; }
    .info-text, .masjid-text, .why-text, .history-text,
    .contact-text, .fine-intro, .sms-intro { font-size: 14.5px; }
    .steps-list li, .fine-list li { font-size: 14.5px; }
}

@media (max-width: 480px) {
    .info-section { padding: 36px 14px; }
    .info-title { font-size: 22px; }
    .info-box, .masjid-box, .why-box, .history-box,
    .contact-box, .fine-box, .sms-box { padding: 20px 20px; }
    .section-title { font-size: 19px; }
    .info-text, .masjid-text, .why-text, .history-text,
    .contact-text, .fine-intro, .sms-intro { font-size: 14px; }
    .steps-list li, .fine-list li { font-size: 14px; padding-left: 34px; }
}
