/*
Theme Name: Pesogo
Author: Tieumy Network
Description: Custom theme for pesogo.org – Philippine loan comparison platform (Layout D)
Version: 2.0
*/

* { margin:0; padding:0; box-sizing:border-box; }
html { overflow-x: hidden; scroll-behavior: smooth; }
body { overflow-x: hidden; }
img { max-width:100%; height:auto; vertical-align:middle; }
:root {
  --primary: #DC2626;
  --primary-dark: #B91C1C;
  --accent: #FCD34D;
  --bg: #FEF2F2;
  --text: #1A1A2E;
  --gray: #6B7280;
  --light: #FEE2E2;
  --white: #FFFFFF;
  --border: #FECACA;
  --shadow: 0 4px 20px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 40px rgba(220,38,38,0.15);
  --radius: 16px;
  --radius-sm: 10px;
}
body { font-family:'Segoe UI',Roboto,sans-serif; line-height:1.7; color:var(--text); background:var(--white); }
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 ========== */
.site-header {
  background:var(--white); border-bottom:2px solid var(--border);
  padding:12px 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:24px; font-weight:900; color:var(--primary-dark);
  text-transform:uppercase; letter-spacing:1.5px;
}
.logo span { color:var(--primary); }
.menu-toggle { display:none; }
.nav-menu { display:flex; gap:24px; list-style:none; align-items:center; }
.nav-menu a {
  font-weight:600; color:var(--text); padding:6px 0;
  border-bottom:2px solid transparent; font-size:15px;
}
.nav-menu a:hover { color:var(--primary); border-bottom-color:var(--primary); }
.nav-menu .nav-cta a {
  background:var(--primary); color:var(--white); padding:8px 20px;
  border-radius:50px; border:none; font-weight:700; font-size:14px;
}
.nav-menu .nav-cta a:hover { background:var(--primary-dark); transform:translateY(-1px); }

/* ========== HERO - 2 COLUMN ========== */
.hero {
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:var(--white); padding:70px 0; overflow:hidden;
}
.hero .container { display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; }
.hero-left h1 { font-size:40px; line-height:1.15; margin-bottom:16px; font-weight:900; }
.hero-left p { font-size:17px; opacity:.92; line-height:1.6; margin-bottom:28px; max-width:520px; }
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; }
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 32px; border-radius:50px; font-weight:700; font-size:15px;
  cursor:pointer; transition:all .3s; border:none; white-space:nowrap;
}
.btn-white { background:var(--white); color:var(--primary); }
.btn-white:hover { background:#fff5f5; transform:translateY(-2px); box-shadow:0 6px 24px rgba(0,0,0,.2); }
.btn-outline { background:transparent; color:var(--white); border:2px solid rgba(255,255,255,.5); }
.btn-outline:hover { border-color:var(--white); transform:translateY(-2px); }
.btn-gold { background:var(--accent); color:var(--text); }
.btn-gold:hover { background:#fbbf24; transform:translateY(-2px); }
.btn-sm { padding:10px 22px; font-size:13px; }
.hero-right { text-align:center; }
.hero-illustration {
  font-size:140px; line-height:1; display:flex; flex-wrap:wrap;
  justify-content:center; gap:10px; filter:drop-shadow(0 8px 30px rgba(0,0,0,.15));
}
.hero-illustration span { display:inline-block; animation:float 3s ease-in-out infinite; }
.hero-illustration span:nth-child(2) { animation-delay:.5s; }
.hero-illustration span:nth-child(3) { animation-delay:1s; }
@keyframes float {
  0%,100% { transform:translateY(0); } 50% { transform:translateY(-12px); }
}

/* ========== TRUST BAR ========== */
.trust-bar {
  background:var(--bg); padding:20px 0;
  border-bottom:1px solid var(--border);
}
.trust-bar .container { display:flex; justify-content:center; align-items:center; gap:30px; flex-wrap:wrap; }
.trust-item { display:flex; align-items:center; gap:8px; font-size:14px; color:var(--gray); font-weight:600; }
.trust-item .badge {
  display:inline-flex; align-items:center; gap:4px;
  background:var(--white); border:1px solid var(--border);
  border-radius:6px; padding:4px 12px; font-size:12px;
}

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

/* ========== LOAN CALCULATOR ========== */
.loan-calc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.loan-card {
  background:var(--white); border-radius:var(--radius); padding:30px 25px;
  text-align:center; box-shadow:var(--shadow); border:2px solid var(--border);
  transition:all .3s; position:relative;
}
.loan-card:hover { transform:translateY(-6px); border-color:var(--primary); box-shadow:var(--shadow-lg); }
.loan-card.featured { border-color:var(--primary); background:linear-gradient(180deg,#FFF5F5,var(--white)); }
.loan-card .loan-amount { font-size:36px; font-weight:900; color:var(--primary); margin-bottom:4px; }
.loan-card .loan-label { font-size:13px; color:var(--gray); text-transform:uppercase; letter-spacing:1px; margin-bottom:16px; }
.loan-card .loan-detail { display:flex; justify-content:space-between; padding:8px 0; border-bottom:1px solid var(--border); font-size:14px; }
.loan-card .loan-detail:last-of-type { border:none; }
.loan-card .loan-detail span:last-child { font-weight:700; color:var(--text); }
.loan-card .btn { margin-top:16px; }

/* ========== BENEFITS (4 CARDS) ========== */
.benefits-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.benefit-card {
  background:var(--white); border-radius:var(--radius); padding:30px 22px;
  text-align:center; box-shadow:var(--shadow); border:2px solid var(--border);
  transition:all .4s; position:relative; overflow:hidden;
}
.benefit-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background:var(--primary); transform:scaleX(0); transform-origin:left;
  transition:transform .4s;
}
.benefit-card:hover::before { transform:scaleX(1); }
.benefit-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); }
.benefit-card .icon {
  font-size:44px; margin-bottom:14px; display:block;
  transition:transform .4s;
}
.benefit-card:hover .icon { transform:scale(1.2); }
.benefit-card h3 { font-size:18px; color:var(--primary-dark); margin-bottom:8px; }
.benefit-card p { font-size:14px; color:var(--gray); line-height:1.6; }

/* ========== HOW IT WORKS (3 steps horizontal with arrows) ========== */
.steps-horizontal { display:grid; grid-template-columns:repeat(3,1fr); gap:0; position:relative; }
.step-h-item {
  text-align:center; padding:30px 20px; position:relative;
  background:var(--white); border-radius:var(--radius);
  box-shadow:var(--shadow); border:2px solid var(--border);
  margin:0 5px; transition:all .3s;
}
.step-h-item:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.step-h-icon {
  width:64px; height:64px; margin:0 auto 14px;
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:28px; color:var(--white); font-weight:900;
}
.step-h-item h4 { font-size:17px; color:var(--primary-dark); margin-bottom:6px; }
.step-h-item p { font-size:14px; color:var(--gray); line-height:1.6; }
.step-arrow {
  position:absolute; top:50%; right:-20px; transform:translateY(-50%);
  font-size:28px; color:var(--primary); z-index:2;
}
.steps-horizontal .step-h-item:last-child .step-arrow { display:none; }

/* ========== PARTNER COMPARISON ========== */
.compare-table-wrap { overflow-x:auto; }
.compare-table {
  width:100%; border-collapse:collapse; background:var(--white);
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
}
.compare-table thead { background:var(--primary); color:var(--white); }
.compare-table th {
  padding:16px 20px; font-size:15px; font-weight:700; text-align:center;
}
.compare-table th:first-child { text-align:left; }
.compare-table td {
  padding:14px 20px; font-size:14px; text-align:center;
  border-bottom:1px solid var(--border);
}
.compare-table td:first-child { text-align:left; font-weight:600; color:var(--text); }
.compare-table tbody tr:hover { background:var(--bg); }
.compare-table .rating { color:var(--accent); font-size:16px; }
.compare-table .apply-cell .btn { font-size:12px; padding:8px 18px; }

/* ========== FAQ ========== */
.faq-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.faq-item {
  background:var(--white); border-radius:var(--radius-sm);
  padding:18px 22px; box-shadow:var(--shadow);
  border:1px solid var(--border); cursor:pointer; transition:all .3s;
}
.faq-item:hover { border-color:var(--primary); }
.faq-question {
  font-weight:700; font-size:15px; color:var(--text);
  display:flex; justify-content:space-between; align-items:center; gap:10px;
}
.faq-question .faq-toggle { font-size:12px; color:var(--primary); transition:transform .3s; }
.faq-item.active .faq-toggle { transform:rotate(45deg); }
.faq-answer {
  margin-top:10px; font-size:14px; color:var(--gray);
  display:none; line-height:1.6;
}
.faq-item.active .faq-answer { display:block; }

/* ========== BLOG ========== */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.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(-5px); box-shadow:var(--shadow-lg); }
.blog-card img { width:100%; height:180px; object-fit:cover; }
.blog-card-content { padding:20px; }
.blog-card h3 { font-size:17px; margin-bottom:8px; line-height:1.4; }
.blog-card h3 a { color:var(--text); }
.blog-card h3 a:hover { color:var(--primary); }
.blog-card .meta { font-size:12px; color:var(--gray); margin-bottom:8px; }
.blog-card p { font-size:13px; color:var(--gray); line-height:1.5; }

/* ========== FOOTER ========== */
.site-footer { background:var(--primary-dark); color:var(--white); padding:50px 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:14px; color:rgba(255,255,255,.9); }
.site-footer p, .site-footer a { font-size:14px; color:rgba(255,255,255,.75); line-height:2; }
.site-footer a:hover { color:var(--accent); }
.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,.55); }

/* ========== PAGE / SINGLE (kept from previous) ========== */
.content-area { padding:40px 0; }
.page-title { font-size:36px; color:var(--primary-dark); margin-bottom:25px; font-weight:800; line-height:1.2; }
.page-body { font-size:16px; line-height:1.8; }
.page-body h2 { color:var(--primary-dark); 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(--primary-dark); 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(--primary-dark); 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 img, .post-content img { max-width:100%!important; height:auto!important; }

/* ========== RESPONSIVE ========== */
@media(max-width:992px) {
  .hero .container { grid-template-columns:1fr; gap:30px; text-align:center; }
  .hero-left p { margin:0 auto 28px; }
  .hero-btns { justify-content:center; }
  .hero-illustration { font-size:100px; }
  .loan-calc-grid { grid-template-columns:repeat(2,1fr); }
  .benefits-grid { grid-template-columns:repeat(2,1fr); }
  .steps-horizontal { grid-template-columns:1fr; gap:16px; }
  .step-arrow { display:none; }
  .blog-grid { grid-template-columns:1fr 1fr; }
  .faq-grid { grid-template-columns:1fr; }
}
@media(max-width:768px) {
  .menu-toggle { display:block; background:none; border:none; font-size:28px; cursor:pointer; padding:5px; color:var(--primary-dark); }
  nav { display:flex; align-items:center; }
  .nav-menu { display:none; position:absolute; top:100%; left:0; right:0; flex-direction:column; gap:0; z-index:999;
    background:var(--white); box-shadow:0 4px 12px rgba(0,0,0,0.1); }
  .site-header { position:relative; }
  .site-header .container { position:relative; flex-wrap:nowrap; }
  .nav-menu.active { display:flex; }
  .nav-menu li { width:100%; border-bottom:1px solid var(--border); }
  .nav-menu a { display:block; padding:14px 20px; font-size:16px; }
  .nav-menu .nav-cta a { border-radius:0; background:var(--primary); }
  .hero-left h1 { font-size:28px; }
  .hero-illustration { font-size:72px; }
  .hero-btns { flex-direction:column; }
  .hero-btns .btn { width:100%; justify-content:center; }
  .loan-calc-grid { grid-template-columns:1fr; }
  .benefits-grid { grid-template-columns:1fr; }
  .trust-bar .container { gap:14px; }
  .blog-grid { grid-template-columns:1fr; }
  .section-title { font-size:26px; }
  .compare-table th, .compare-table td { padding:10px 12px; font-size:12px; }
  .site-footer .container { grid-template-columns:1fr; }
}
@media(max-width:480px) {
  .single-post { padding:0; }
  .post-thumbnail { margin-left:-20px;margin-right:-20px;border-radius:0; }
}

/* Responsive tables */
.table-wrapper, .compare-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.table-wrapper table, .compare-table-wrap table { min-width: 500px; }
.apply-cell { white-space: nowrap; }
@media(max-width:768px) {
  .table-wrapper table, .compare-table-wrap table { min-width: 400px; }
  .lender-table th, .lender-table td, .compare-table th, .compare-table td { padding: 8px 6px; font-size: 13px; }
  .btn-sm { padding: 8px 14px; font-size: 13px; }
}

/* 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; }
}
