/*
Theme Name: CPMSEO
Theme URI: https://cpmseo.com
Author: CPMSEO
Author URI: https://cpmseo.com
Description: A custom homepage theme for CPMSEO - professional SEO agency. Includes hero, trust badges, features, stats, packages, testimonials and footer with site-wide widget areas.
Version: 1.0
Requires at least: 5.8
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cpmseo
*/

:root{
  --navy:#0E1B2C;
  --navy-2:#142539;
  --cream:#F6F4EE;
  --teal:#12B886;
  --amber:#FF7A30;
  --slate:#5B6677;
  --line:#E4E0D6;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',Arial,sans-serif;
  background:var(--cream);
  color:var(--navy);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{
  font-family:'Sora',Arial,sans-serif;
  font-weight:700;
  letter-spacing:-0.02em;
  color:var(--navy);
}
.mono{font-family:'JetBrains Mono','Courier New',monospace;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
ul{list-style:none;}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px;}
.screen-reader-text{position:absolute;left:-9999px;}

/* TOPBAR */
.topbar{background:var(--navy);color:#cdd6e0;font-size:13px;}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;flex-wrap:wrap;}
.topbar-links{display:flex;gap:18px;flex-wrap:wrap;}
.topbar-links a:hover{color:var(--teal);}
.topbar-cta{background:var(--teal);color:var(--navy);padding:4px 14px;border-radius:20px;font-weight:600;font-size:12px;}

/* NAV */
nav.site-nav{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;}
nav.site-nav .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;}
.logo{font-family:'Sora';font-weight:800;font-size:22px;letter-spacing:-0.03em;}
.logo span{color:var(--teal);}
.navlinks{display:flex;gap:26px;font-size:14px;font-weight:600;list-style:none;}
.navlinks li{position:relative;}
.navlinks > li > a{color:var(--navy);opacity:.8;transition:.2s;cursor:pointer;}
.navlinks > li > a:hover, .navlinks li.menu-item-has-children:hover > a{opacity:1;color:var(--teal);}
.navlinks .sub-menu{position:absolute;top:28px;left:0;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px;min-width:220px;box-shadow:0 16px 34px -16px rgba(0,0,0,.18);display:none;flex-direction:column;gap:4px;list-style:none;}
.navlinks li:hover > .sub-menu{display:flex;}
.navlinks .sub-menu a{font-size:13px;font-weight:500;padding:8px 10px;border-radius:6px;color:var(--slate);display:block;}
.navlinks .sub-menu a:hover{background:var(--cream);color:var(--teal);}
.nav-cta{background:var(--navy);color:#fff;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;}
.nav-cta:hover{background:var(--teal);color:var(--navy);}
@media (max-width:980px){.navlinks{display:none;}}

/* HERO */
.hero{background:var(--navy);color:#fff;position:relative;overflow:hidden;padding:90px 0 70px;}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%, rgba(18,184,134,.25), transparent 55%);pointer-events:none;}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;position:relative;}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr;}}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(18,184,134,.15);border:1px solid rgba(18,184,134,.4);color:var(--teal);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;border-radius:30px;margin-bottom:22px;}
.hero h1{font-size:46px;line-height:1.1;margin-bottom:18px;}
.hero h1 .hl{color:var(--teal);}
.hero p.lead{color:#aab8c7;font-size:17px;line-height:1.6;max-width:520px;margin-bottom:14px;}
.price-pill{display:inline-block;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);padding:14px 20px;border-radius:12px;margin-bottom:30px;}
.price-pill .num{font-family:'Sora';font-weight:800;font-size:26px;color:var(--amber);}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;}
.btn{display:inline-block;padding:14px 28px;border-radius:8px;font-weight:700;font-size:14px;letter-spacing:.02em;border:none;cursor:pointer;}
.btn-primary{background:var(--amber);color:var(--navy);}
.btn-primary:hover{background:#fff;}
.btn-ghost{border:1px solid rgba(255,255,255,.3);color:#fff;background:transparent;}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);}

.chart-card{background:var(--navy-2);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:26px 26px 14px;box-shadow:0 30px 60px -20px rgba(0,0,0,.5);}
.chart-card .ch-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;}
.chart-card .ch-head h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.06em;}
.chart-card .ch-head .badge{font-size:12px;color:var(--teal);font-weight:700;}
svg.rankline{width:100%;height:180px;}
.rank-stat{display:flex;justify-content:space-between;border-top:1px solid rgba(255,255,255,.08);padding-top:14px;margin-top:6px;}
.rank-stat div{text-align:center;flex:1;}
.rank-stat .v{font-family:'Sora';font-weight:800;color:#fff;font-size:18px;}
.rank-stat .l{font-size:11px;color:#8a98a8;text-transform:uppercase;letter-spacing:.05em;margin-top:2px;}

/* TRUST */
.trust{background:#fff;border-bottom:1px solid var(--line);padding:42px 0;}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;}
@media (max-width:880px){.trust-grid{grid-template-columns:repeat(2,1fr);}}
.trust-item{display:flex;gap:14px;align-items:flex-start;}
.trust-icon{width:42px;height:42px;border-radius:10px;background:rgba(18,184,134,.1);display:flex;align-items:center;justify-content:center;color:var(--teal);flex-shrink:0;font-size:18px;font-weight:800;}
.trust-item h4{font-size:15px;margin-bottom:4px;}
.trust-item p{font-size:13px;color:var(--slate);line-height:1.5;}

/* ABOUT */
.about{padding:80px 0;}
.about .tag{color:var(--teal);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:12px;margin-bottom:10px;display:block;}
.about h2{font-size:32px;max-width:680px;margin-bottom:20px;}
.about-cols{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:30px;}
@media (max-width:880px){.about-cols{grid-template-columns:1fr;}}
.about-cols p{color:var(--slate);line-height:1.7;font-size:15px;margin-bottom:16px;}

/* FEATURES */
.features{padding:70px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.section-head{text-align:center;max-width:600px;margin:0 auto 50px;}
.section-head .tag{color:var(--teal);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:12px;}
.section-head h2{font-size:30px;margin-top:8px;}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
@media (max-width:880px){.feat-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.feat-grid{grid-template-columns:1fr;}}
.feat-card{border:1px solid var(--line);border-radius:14px;padding:28px 24px;transition:.2s;}
.feat-card:hover{border-color:var(--teal);transform:translateY(-3px);box-shadow:0 14px 30px -16px rgba(18,184,134,.4);}
.feat-num{font-family:'JetBrains Mono';font-size:12px;color:var(--amber);font-weight:700;margin-bottom:12px;}
.feat-card h3{font-size:17px;margin-bottom:8px;}
.feat-card p{font-size:14px;color:var(--slate);line-height:1.6;}

/* STATS */
.stats{background:var(--navy);color:#fff;padding:60px 0;}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);text-align:center;gap:30px;}
@media (max-width:700px){.stats-grid{grid-template-columns:1fr 1fr;}}
.stat-num{font-family:'Sora';font-weight:800;font-size:42px;color:var(--teal);}
.stat-label{font-size:13px;color:#aab8c7;text-transform:uppercase;letter-spacing:.05em;margin-top:6px;}

/* PACKAGES */
.services{padding:80px 0;}
.pkg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
@media (max-width:980px){.pkg-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.pkg-grid{grid-template-columns:1fr;}}
.pkg-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;}
.pkg-top{background:var(--navy-2);color:#fff;padding:22px 22px 18px;}
.pkg-top .tag{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);font-weight:700;}
.pkg-top h3{font-size:19px;margin-top:6px;}
.pkg-body{padding:20px 22px;flex:1;display:flex;flex-direction:column;gap:10px;}
.pkg-body li{font-size:13.5px;color:var(--slate);display:flex;gap:8px;align-items:flex-start;}
.pkg-body li::before{content:"✓";color:var(--teal);font-weight:800;}
.pkg-cta{margin:18px 22px 22px;text-align:center;background:var(--cream);border:1px solid var(--line);border-radius:8px;padding:10px;font-weight:700;font-size:13px;letter-spacing:.03em;display:block;}
.pkg-cta:hover{background:var(--teal);color:#fff;border-color:var(--teal);}

/* WHY */
.why{padding:80px 0;background:#fff;border-top:1px solid var(--line);}
.why-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:start;}
@media (max-width:880px){.why-grid{grid-template-columns:1fr;}}
.why ul{margin-top:16px;display:grid;gap:12px;}
.why ul li{display:flex;gap:10px;font-size:14.5px;color:var(--slate);align-items:flex-start;}
.why ul li::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--amber);margin-top:6px;flex-shrink:0;}
.why-card{background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:24px;}
.why-card h4{font-size:15px;margin-bottom:6px;}
.why-card p{font-size:13.5px;color:var(--slate);line-height:1.6;}
.why-cards{display:grid;gap:16px;}

/* TESTIMONIALS */
.testimonials{padding:80px 0;background:var(--navy);color:#fff;}
.testimonials .section-head h2{color:#fff;}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media (max-width:880px){.test-grid{grid-template-columns:1fr;}}
.test-card{background:var(--navy-2);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:24px;}
.stars{color:var(--amber);font-size:14px;margin-bottom:12px;}
.test-card p{font-size:14px;color:#cdd6e0;line-height:1.65;margin-bottom:16px;}
.test-author{display:flex;align-items:center;gap:10px;}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--teal);color:var(--navy);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;}
.test-author .name{font-size:13.5px;font-weight:700;color:#fff;}
.test-author .role{font-size:11.5px;color:#8a98a8;}

/* CTA BAND */
.ctaband{background:linear-gradient(120deg,var(--teal),#0ea374);padding:50px 0;color:var(--navy);}
.ctaband .wrap{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;}
.ctaband h3{font-size:24px;max-width:560px;}
.ctaband .btn-primary{background:var(--navy);color:#fff;}
.ctaband .btn-primary:hover{background:#fff;color:var(--navy);}

/* CLIENTS */
.clients{padding:60px 0;text-align:center;}
.clients .section-head{margin-bottom:34px;}
.client-row{display:flex;justify-content:center;align-items:center;gap:46px;flex-wrap:wrap;opacity:.55;filter:grayscale(1);}
.client-row span{font-family:'Sora';font-weight:800;font-size:18px;color:var(--navy);}

/* FOOTER */
footer.site-footer{background:var(--navy-2);color:#aab8c7;padding-top:60px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.08);}
@media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.foot-grid{grid-template-columns:1fr;}}
footer h4{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;font-family:'Sora';}
footer .logo{color:#fff;margin-bottom:14px;}
footer p{font-size:13.5px;line-height:1.7;color:#8a98a8;max-width:280px;}
footer ul{display:grid;gap:10px;}
footer ul a{font-size:13.5px;color:#aab8c7;}
footer ul a:hover{color:var(--teal);}
.map-frame{border-radius:10px;overflow:hidden;margin-top:14px;border:1px solid rgba(255,255,255,.1);}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding:22px 0;font-size:12.5px;color:#7c8a9a;flex-wrap:wrap;gap:10px;}
.foot-social{display:flex;gap:14px;}
.foot-social a{width:32px;height:32px;border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;}
.foot-social a:hover{background:var(--teal);border-color:var(--teal);color:var(--navy);}

/* Default WP content (blog/page fallback) */
.wp-default-content{padding:80px 0;max-width:760px;margin:0 auto;}
.wp-default-content h1{margin-bottom:20px;}
.wp-default-content p{color:var(--slate);line-height:1.8;margin-bottom:16px;}

/* ===== INNER PAGES ===== */

/* Breadcrumb */
.breadcrumb{background:var(--navy-2);padding:16px 0;}
.breadcrumb .wrap{display:flex;gap:8px;align-items:center;font-size:13px;color:#aab8c7;}
.breadcrumb a{color:#aab8c7;}
.breadcrumb a:hover{color:var(--teal);}
.breadcrumb .sep{opacity:.5;}
.breadcrumb .current{color:var(--teal);font-weight:600;}

/* Inner hero (smaller than homepage hero) */
.inner-hero{background:var(--navy);color:#fff;padding:54px 0;position:relative;overflow:hidden;}
.inner-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 10%, rgba(18,184,134,.2), transparent 55%);pointer-events:none;}
.inner-hero h1{font-size:32px;position:relative;margin-bottom:10px;}
.inner-hero p{color:#aab8c7;font-size:15px;max-width:560px;position:relative;}

/* Section wrapper used across inner pages */
.inner-section{padding:64px 0;}
.inner-section.alt{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}

/* Benefits grid (service pages) */
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:10px;}
@media (max-width:880px){.benefits-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.benefits-grid{grid-template-columns:1fr;}}
.benefit-card{border:1px solid var(--line);border-radius:14px;padding:24px;background:#fff;}
.benefit-card h3{font-size:16px;margin-bottom:8px;}
.benefit-card p{font-size:13.5px;color:var(--slate);line-height:1.6;}

/* Process steps */
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:10px;}
@media (max-width:880px){.process-steps{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.process-steps{grid-template-columns:1fr;}}
.step-card{position:relative;padding:22px 18px;border-radius:12px;background:var(--cream);border:1px solid var(--line);}
.step-card .step-num{font-family:'Sora';font-weight:800;font-size:26px;color:var(--teal);margin-bottom:8px;}
.step-card h4{font-size:14.5px;margin-bottom:6px;}
.step-card p{font-size:13px;color:var(--slate);line-height:1.5;}

/* Pricing box (service/seo/link building pages) */
.pricing-box{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:10px;}
@media (max-width:880px){.pricing-box{grid-template-columns:1fr;}}
.price-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 24px;text-align:center;display:flex;flex-direction:column;}
.price-card.featured{border-color:var(--teal);box-shadow:0 18px 40px -20px rgba(18,184,134,.45);}
.price-card .plan-name{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--teal);font-weight:700;margin-bottom:10px;}
.price-card .plan-price{font-family:'Sora';font-weight:800;font-size:34px;margin-bottom:6px;}
.price-card .plan-price span{font-size:13px;color:var(--slate);font-weight:500;}
.price-card ul{margin:18px 0;display:grid;gap:10px;text-align:left;}
.price-card ul li{font-size:13.5px;color:var(--slate);display:flex;gap:8px;}
.price-card ul li::before{content:"✓";color:var(--teal);font-weight:800;}

/* FAQ accordion */
.faq-list{margin-top:10px;max-width:760px;}
.faq-item{border-bottom:1px solid var(--line);padding:16px 0;}
.faq-item summary{font-weight:700;font-size:15px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:"+";color:var(--teal);font-size:18px;}
.faq-item[open] summary::after{content:"−";}
.faq-item p{margin-top:10px;color:var(--slate);font-size:14px;line-height:1.6;}

/* Contact page */
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;}}
.contact-form{display:grid;gap:14px;}
.contact-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media (max-width:560px){.contact-form .row2{grid-template-columns:1fr;}}
.contact-form input, .contact-form select, .contact-form textarea{
  width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14px;background:#fff;color:var(--navy);
}
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus{outline:2px solid var(--teal);border-color:var(--teal);}
.contact-form button{justify-self:start;}
.contact-side{display:grid;gap:18px;align-content:start;}
.contact-side .info-card{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:18px;}
.contact-side .info-card h4{font-size:14px;margin-bottom:4px;}
.contact-side .info-card p{font-size:13.5px;color:var(--slate);}
.contact-map{border-radius:12px;overflow:hidden;border:1px solid var(--line);}

/* Reviews page */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
@media (max-width:880px){.reviews-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.reviews-grid{grid-template-columns:1fr;}}
.review-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;}
.review-card .stars{color:var(--amber);font-size:13px;margin-bottom:10px;}
.review-card p{font-size:13.5px;color:var(--slate);line-height:1.6;margin-bottom:14px;}
.review-card .test-author .name{color:var(--navy);}
.review-card .test-author .role{color:var(--slate);}

/* Blog grid */
.blog-layout{display:grid;grid-template-columns:2fr 1fr;gap:40px;}
@media (max-width:880px){.blog-layout{grid-template-columns:1fr;}}
.blog-grid{display:grid;gap:26px;}
.post-card{display:grid;grid-template-columns:220px 1fr;gap:20px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;}
@media (max-width:640px){.post-card{grid-template-columns:1fr;}}
.post-card img{height:100%;object-fit:cover;}
.post-card .post-body{padding:18px 18px 18px 0;}
@media (max-width:640px){.post-card .post-body{padding:14px;}}
.post-card .post-meta{font-size:12px;color:var(--teal);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;}
.post-card h3{font-size:18px;margin-bottom:8px;}
.post-card p{font-size:13.5px;color:var(--slate);line-height:1.6;margin-bottom:10px;}
.post-card .read-more{font-size:13px;font-weight:700;color:var(--teal);}
.blog-sidebar{display:grid;gap:24px;align-content:start;}
.sidebar-box{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:18px;}
.sidebar-box h4{font-size:14px;margin-bottom:12px;}
.sidebar-box ul{display:grid;gap:8px;}
.sidebar-box ul a{font-size:13.5px;color:var(--slate);}
.sidebar-box ul a:hover{color:var(--teal);}
.sidebar-box input[type="search"]{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:8px;font-size:13.5px;}
.pagination{display:flex;gap:8px;margin-top:30px;}
.pagination a, .pagination span{width:36px;height:36px;border:1px solid var(--line);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;}
.pagination .current{background:var(--teal);color:#fff;border-color:var(--teal);}

/* Single blog post */
.single-post-header{margin-bottom:24px;}
.single-post-header .post-meta{font-size:12.5px;color:var(--teal);font-weight:700;text-transform:uppercase;margin-bottom:8px;}
.single-post-header h1{font-size:30px;margin-bottom:10px;}
.single-post-content{max-width:760px;}
.single-post-content img{border-radius:12px;margin:18px 0;}
.single-post-content p{color:var(--slate);line-height:1.8;margin-bottom:16px;font-size:15px;}
.single-post-content h2, .single-post-content h3{margin:24px 0 12px;}
.post-tags{display:flex;gap:8px;flex-wrap:wrap;margin:20px 0;}
.post-tags a{font-size:12px;background:var(--cream);border:1px solid var(--line);padding:6px 12px;border-radius:20px;color:var(--slate);}
.author-box{display:flex;gap:16px;background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:20px;margin-top:30px;}
.author-box .avatar{width:54px;height:54px;font-size:18px;}
.author-box h4{font-size:14px;margin-bottom:4px;}
.author-box p{font-size:13px;color:var(--slate);}

/* Legal pages */
.legal-content{max-width:760px;}
.legal-content h2{font-size:20px;margin:26px 0 10px;}
.legal-content p, .legal-content li{color:var(--slate);line-height:1.8;font-size:14.5px;margin-bottom:10px;}
.legal-content ul{padding-left:20px;list-style:disc;}
