/*
Theme Name: MocaMoca
Author: Tieumy Network
Description: Custom theme for mocamoca.info – Philippine loan comparison platform (Layout A)
Version: 2.0
*/

* { margin:0; padding:0; box-sizing:border-box; }
html { overflow-x: hidden; }
body { overflow-x: hidden; }
img { max-width:100%; height:auto; vertical-align:middle; }
:root {
  --primary: #2563EB;
  --primary-dark: #1D4ED8;
  --accent: #60A5FA;
  --secondary: #DBEAFE;
  --bg: #EFF6FF;
  --bg-alt: #F8FAFC;
  --text: #1E293B;
  --gray: #64748B;
  --light: #F1F5F9;
  --white: #FFFFFF;
  --border: #CBD5E1;
  --shadow: 0 4px 16px rgba(37,99,235,0.12);
  --radius: 12px;
  --radius-sm: 8px;
}
body { font-family:'Segoe UI',Roboto,sans-serif; line-height:1.7; color:var(--text); background:var(--bg); }
a { color:var(--primary); text-decoration:none; transition:all .3s; }
a:hover { color:var(--primary-dark); }
.container { max-width:1140px; margin:0 auto; padding:0 20px; }

/* ===== HEADER (unchanged structure, updated colors) ===== */
.site-header { background:var(--white); border-bottom:3px solid var(--primary); padding:15px 0; position:sticky; top:0; z-index:100; box-shadow:var(--shadow); }
.site-header .container { display:flex; justify-content:space-between; align-items:center; }
.logo { font-size:26px; font-weight:800; color:var(--primary-dark); text-transform:uppercase; letter-spacing:1px; }
.logo span { color:var(--primary); }
.menu-toggle { display:none; }
.nav-menu { display:flex; gap:25px; list-style:none; }
.nav-menu a { font-weight:600; color:var(--text); padding:5px 0; border-bottom:2px solid transparent; }
.nav-menu a:hover { color:var(--primary); border-bottom-color:var(--primary); }

/* ===== BUTTONS ===== */
.btn { display:inline-block; padding:14px 36px; border-radius:50px; font-weight:700; font-size:16px; cursor:pointer; transition:all .3s; border:none; text-transform:uppercase; letter-spacing:1px; text-align:center; }
.btn-primary { background:var(--white); color:var(--primary-dark); }
.btn-primary:hover { background:var(--secondary); transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,.2); }
.btn-gold { background:var(--primary); color:var(--white); }
.btn-gold:hover { background:var(--primary-dark); transform:translateY(-2px); box-shadow:0 6px 20px rgba(37,99,235,.3); }

/* ===== HERO ===== */
.hero { background:linear-gradient(135deg,#1E40AF,#2563EB,#3B82F6); color:var(--white); padding:80px 0 60px; text-align:center; position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; top:-50%; left:-50%; width:200%; height:200%; background:radial-gradient(circle,rgba(255,255,255,0.06) 0%,transparent 70%); pointer-events:none; }
.hero h1 { font-size:44px; margin-bottom:16px; line-height:1.15; font-weight:800; text-shadow:0 2px 10px rgba(0,0,0,0.15); }
.hero p { font-size:18px; opacity:.9; max-width:700px; margin:0 auto 30px; line-height:1.6; }
.hero-buttons { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin-bottom:0; }
.hero .btn { min-width:200px; }

/* Stats bar */
.hero-stats { display:flex; justify-content:center; gap:40px; margin-top:50px; padding-top:40px; border-top:1px solid rgba(255,255,255,0.2); flex-wrap:wrap; }
.hero-stat { text-align:center; }
.hero-stat .number { font-size:32px; font-weight:800; display:block; line-height:1.2; }
.hero-stat .label { font-size:14px; opacity:.8; display:block; margin-top:4px; }

/* ===== SECTION COMMON ===== */
section { padding:64px 0; }
.section-title { font-size:34px; color:var(--text); margin-bottom:8px; text-align:center; font-weight:800; }
.section-sub { text-align:center; color:var(--gray); margin-bottom:40px; font-size:16px; max-width:600px; margin-left:auto; margin-right:auto; }
.section-white { background:var(--white); }
.section-alt { background:var(--bg-alt); }

/* ===== LENDER COMPARISON TABLE ===== */
.table-wrapper { overflow-x:auto; margin-top:30px; border-radius:var(--radius); box-shadow:var(--shadow); }
.lender-table { width:100%; border-collapse:collapse; background:var(--white); font-size:15px; }
.lender-table thead { background:var(--primary); color:var(--white); }
.lender-table th { padding:16px 20px; text-align:left; font-weight:700; white-space:nowrap; }
.lender-table td { padding:14px 20px; border-bottom:1px solid var(--border); vertical-align:middle; }
.lender-table tbody tr:hover { background:var(--secondary); }
.lender-table .lender-name { font-weight:700; color:var(--text); }
.lender-table .apply-cell { text-align:center; }
.lender-table .btn-sm { display:inline-block; padding:8px 20px; border-radius:50px; font-weight:700; font-size:13px; background:var(--primary); color:var(--white); text-transform:uppercase; letter-spacing:0.5px; transition:all .3s; border:none; cursor:pointer; }
.lender-table .btn-sm:hover { background:var(--primary-dark); transform:translateY(-1px); }
.lender-table .badge-rate { display:inline-block; background:#FEF3C7; color:#92400E; padding:2px 10px; border-radius:20px; font-size:13px; font-weight:600; }

/* ===== FEATURES - Alternating (icon-left, text-right) ===== */
.features-alt { max-width:900px; margin:0 auto; display:flex; flex-direction:column; gap:28px; }
.feature-alt { display:flex; gap:24px; align-items:flex-start; background:var(--white); border-radius:var(--radius); padding:28px 30px; box-shadow:var(--shadow); border:1px solid var(--border); transition:all .3s; }
.feature-alt:hover { transform:translateY(-3px); box-shadow:0 8px 30px rgba(37,99,235,0.15); }
.feature-alt:nth-child(even) { flex-direction:row-reverse; }
.feature-alt .fa-icon { width:60px; height:60px; min-width:60px; background:linear-gradient(135deg,var(--primary),var(--accent)); border-radius:16px; display:flex; align-items:center; justify-content:center; font-size:28px; color:var(--white); }
.feature-alt .fa-content { flex:1; }
.feature-alt .fa-content h3 { font-size:20px; color:var(--text); margin-bottom:8px; font-weight:700; }
.feature-alt .fa-content p { color:var(--gray); font-size:15px; line-height:1.6; }

/* ===== TRUST BADGES ===== */
.trust-badges { display:flex; justify-content:center; gap:30px; flex-wrap:wrap; }
.trust-badge { display:flex; align-items:center; gap:14px; background:var(--white); border:2px solid var(--border); border-radius:var(--radius); padding:18px 28px; transition:all .3s; }
.trust-badge:hover { border-color:var(--primary); box-shadow:var(--shadow); }
.trust-badge .tb-icon { font-size:36px; }
.trust-badge .tb-info h4 { font-size:16px; color:var(--text); font-weight:700; }
.trust-badge .tb-info p { font-size:13px; color:var(--gray); }

/* ===== FAQ ACCORDION ===== */
.faq-section .faq-list { max-width:800px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.faq-item { background:var(--white); border-radius:var(--radius); border:1px solid var(--border); overflow:hidden; transition:all .3s; }
.faq-item:hover { border-color:var(--primary); }
.faq-question { display:flex; justify-content:space-between; align-items:center; padding:18px 24px; font-weight:700; font-size:16px; color:var(--text); cursor:pointer; user-select:none; }
.faq-question .faq-toggle { width:28px; height:28px; min-width:28px; border-radius:50%; background:var(--secondary); display:flex; align-items:center; justify-content:center; transition:all .3s; font-size:14px; color:var(--primary); }
.faq-item.active .faq-toggle { background:var(--primary); color:var(--white); transform:rotate(180deg); }
.faq-answer { padding:0 24px 18px; font-size:15px; color:var(--gray); line-height:1.7; display:none; }
.faq-item.active .faq-answer { display:block; }

/* ===== BLOG ===== */
.blog-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:25px; }
.blog-card { background:var(--white); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--border); transition:all .3s; }
.blog-card:hover { transform:translateY(-3px); box-shadow:0 8px 30px rgba(37,99,235,0.15); }
.blog-card img { width:100%; height:200px; object-fit:cover; }
.blog-card-content { padding:20px; }
.blog-card h3 { font-size:18px; margin-bottom:10px; }
.blog-card h3 a { color:var(--text); }
.blog-card h3 a:hover { color:var(--primary); }
.blog-card .meta { font-size:13px; color:var(--gray); margin-bottom:10px; }
.blog-card p { font-size:14px; color:var(--gray); }

/* ===== CONTENT AREA (pages / single post) ===== */
.content-area { padding:40px 0; }
.page-title { font-size:36px; color:var(--text); margin-bottom:25px; font-weight:800; line-height:1.2; }
.page-body { font-size:16px; line-height:1.8; }
.page-body h2 { color:var(--text); margin:30px 0 15px; font-size:26px; }
.page-body h3 { font-size:20px; margin:25px 0 12px; color:var(--primary); }
.page-body p { margin-bottom:15px; }
.page-body ul { margin:15px 0 15px 25px; }
.page-body ul li { margin-bottom:8px; }

.single-post { max-width:800px; margin:0 auto; }
.post-title { font-size:36px; color:var(--text); margin-bottom:10px; font-weight:800; }
.post-meta { color:var(--gray); font-size:14px; margin-bottom:20px; }
.post-thumbnail { margin-bottom:25px; border-radius:var(--radius); overflow:hidden; }
.post-thumbnail img { width:100%; height:auto; }
.post-content { line-height:1.8; font-size:16px; }
.post-content h2 { color:var(--text); margin:30px 0 15px; font-size:24px; }
.post-content h3 { font-size:20px; margin:25px 0 12px; color:var(--primary); }
.post-content p { margin-bottom:15px; }
.post-content ul { margin:15px 0 15px 25px; }
.post-content ul li { margin-bottom:8px; }

.post-thumbnail, .article-feat-image, .pg-thumb { overflow:hidden; border-radius:var(--radius); }
.post-thumbnail img, .article-feat-image img, .pg-thumb img { width:100%; height:auto; max-width:100%; }

/* ===== FOOTER ===== */
.site-footer { background:var(--text); color:var(--white); padding:40px 0 20px; }
.site-footer .container { display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:30px; }
.site-footer h4 { font-size:18px; margin-bottom:15px; color:var(--accent); }
.site-footer p, .site-footer a { font-size:14px; color:rgba(255,255,255,.8); line-height:2; }
.site-footer a:hover { color:var(--white); }
.footer-bottom { text-align:center; padding-top:20px; margin-top:20px; border-top:1px solid rgba(255,255,255,.1); font-size:13px; color:rgba(255,255,255,.6); }

/* ===== RESPONSIVE ===== */
@media(max-width:768px) {
  .hero { padding:60px 0 40px; }
  .hero h1 { font-size:30px; }
  .hero p { font-size:16px; }
  .hero-stats { gap:20px; margin-top:35px; padding-top:30px; }
  .hero-stat .number { font-size:26px; }
  .nav-menu { flex-direction:column; gap:10px; width:100%; margin-top:10px; }
  .section-title { font-size:26px; }
  .lender-table { font-size:13px; }
  .lender-table th, .lender-table td { padding:10px 12px; }
  .feature-alt { flex-direction:column !important; padding:20px; }
  .feature-alt .fa-icon { margin-bottom:4px; }
  .trust-badge { width:100%; justify-content:center; }
  .faq-question { padding:14px 18px; font-size:15px; }
  .faq-answer { padding:0 18px 16px; }
}

@media(max-width:480px) {
  .hero h1 { font-size:26px; }
  .section-title { font-size:22px; }
  .page-title { font-size:28px; }
  .post-title { font-size:28px; }
  .site-header .container { padding:0 16px; }
}

/* Mobile button spacing */
@media(max-width:768px) {
  .hero .btn { display:block !important; width:100%; margin-bottom:14px !important; text-align:center; }
  .hero .btn:last-child { margin-bottom:0 !important; }
  .lender-table .btn-sm { display:block; width:100%; }
}

/* Hamburger menu icon via CSS */
.menu-toggle { font-size:0 !important; width:30px; height:24px; position:relative; }
.menu-toggle::before,
.menu-toggle::after,
.menu-toggle span.hamb-line { content:''; position:absolute; left:0; width:100%; height:3px; background:var(--primary-dark); border-radius:2px; transition:all .3s; }
.menu-toggle::before { top:0; }
.menu-toggle::after { bottom:0; }
.menu-toggle .hamb-line { top:50%; transform:translateY(-50%); }
.menu-toggle.active::before { transform:rotate(45deg); top:10px; }
.menu-toggle.active::after { transform:rotate(-45deg); bottom:10px; }
.menu-toggle.active .hamb-line { opacity:0; }
@media(max-width:768px) {
  .menu-toggle { width:28px; height:20px; margin-left:auto; }
}
