/*
Theme Name: Papan Makmur Theme
Theme URI: https://papanmakmur.co.id
Author: Tim Pengembang
Description: Theme untuk landing page SEO Papan Makmur. Gunakan bersama plugin Papan Makmur SEO. Mendukung customizer untuk warna, typography, dan layout.
Version: 1.0.0
Requires at least: 5.0
Tested up to: 6.4
Requires PHP: 7.4
License: GPL v2 or later
Text Domain: papan-makmur-theme
Tags: custom-logo, custom-menu, featured-images
*/

/* ========================================
   CSS VARIABLES - Edit via Customizer
   ======================================== */
:root {
    /* Colors */
    --pms-primary: #1a5f7a;
    --pms-secondary: #57c5b6;
    --pms-accent: #159895;
    --pms-dark: #002b5b;
    --pms-light: #f8f9fa;
    --pms-white: #ffffff;
    --pms-text: #1f2937;
    --pms-text-secondary: #4b5563;
    --pms-text-muted: #9ca3af;
    
    /* Typography */
    --pms-font-heading: 'Poppins', sans-serif;
    --pms-font-body: 'Inter', sans-serif;
    --pms-font-size-base: 16px;
    --pms-line-height: 1.6;
    
    /* Layout */
    --pms-container-width: 1200px;
    --pms-container-padding: 1.5rem;
    --pms-section-padding: 4rem;
    
    /* Spacing */
    --pms-spacing-sm: 0.5rem;
    --pms-spacing-md: 1rem;
    --pms-spacing-lg: 2rem;
    --pms-spacing-xl: 3rem;
    
    /* Border Radius */
    --pms-radius-sm: 4px;
    --pms-radius-md: 8px;
    --pms-radius-lg: 16px;
    
    /* Shadows */
    --pms-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --pms-shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);
    --pms-shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
}

/* ========================================
   BASE RESET
   ======================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: var(--pms-font-size-base); }
body {
    font-family: var(--pms-font-body);
    line-height: var(--pms-line-height);
    color: var(--pms-text);
    background-color: var(--pms-white);
    -webkit-font-smoothing: antialiased;
}

/* ========================================
   TYPOGRAPHY
   ======================================== */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--pms-font-heading);
    font-weight: 600;
    line-height: 1.3;
    color: var(--pms-text);
    margin-bottom: var(--pms-spacing-md);
}
h1 { font-size: 2.5rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.25rem; }

p { margin-bottom: var(--pms-spacing-md); color: var(--pms-text-secondary); }
a { color: var(--pms-primary); text-decoration: none; transition: color 0.3s; }
a:hover { color: var(--pms-secondary); }

/* ========================================
   LAYOUT
   ======================================== */
.pms-container {
    width: 100%;
    max-width: var(--pms-container-width);
    margin: 0 auto;
    padding: 0 var(--pms-container-padding);
}

/* ========================================
   BUTTONS
   ======================================== */
.pms-btn {
    display: inline-block;
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
    font-weight: 500;
    text-align: center;
    border: none;
    border-radius: var(--pms-radius-md);
    cursor: pointer;
    transition: all 0.3s ease;
}
.pms-btn-primary {
    background-color: var(--pms-primary);
    color: var(--pms-white);
}
.pms-btn-primary:hover {
    background-color: var(--pms-dark);
    color: var(--pms-white);
    transform: translateY(-2px);
    box-shadow: var(--pms-shadow-md);
}
.pms-btn-whatsapp {
    background-color: #25D366;
    color: var(--pms-white);
}
.pms-btn-whatsapp:hover {
    background-color: #128C7E;
    color: var(--pms-white);
    transform: translateY(-2px);
}

/* ========================================
   HEADER
   ======================================== */
.pms-header {
    background: var(--pms-white);
    box-shadow: var(--pms-shadow-sm);
    position: sticky;
    top: 0;
    z-index: 1000;
}
.pms-header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem var(--pms-container-padding);
}
.pms-logo a {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--pms-primary);
    text-decoration: none;
}
.pms-logo img { max-height: 60px; }
.pms-nav ul {
    display: flex;
    gap: 1.5rem;
    list-style: none;
    margin: 0;
    padding: 0;
}
.pms-nav a { text-decoration: none; color: var(--pms-text); }
.pms-nav a:hover { color: var(--pms-primary); }
.pms-header-cta .pms-btn { font-size: 0.9rem; }

/* ========================================
   HERO
   ======================================== */
.pms-hero {
    background: linear-gradient(135deg, var(--pms-primary) 0%, var(--pms-dark) 100%);
    color: var(--pms-white);
    padding: var(--pms-section-padding) 0;
    text-align: center;
}
.pms-hero h1 {
    color: var(--pms-white);
    font-size: 2.5rem;
    margin-bottom: var(--pms-spacing-md);
}
.pms-hero .pms-subtitle {
    font-size: 1.25rem;
    opacity: 0.9;
    max-width: 700px;
    margin: 0 auto var(--pms-spacing-lg);
    color: rgba(255,255,255,0.9);
}
.pms-hero-cta {
    display: flex;
    gap: var(--pms-spacing-md);
    justify-content: center;
    flex-wrap: wrap;
}

/* ========================================
   CONTENT
   ======================================== */
.pms-content {
    padding: var(--pms-section-padding) var(--pms-container-padding);
    max-width: 900px;
    margin: 0 auto;
}
.pms-section { margin-bottom: var(--pms-spacing-xl); }
.pms-section h2 {
    color: var(--pms-primary);
    border-bottom: 3px solid var(--pms-secondary);
    padding-bottom: var(--pms-spacing-sm);
    margin-bottom: var(--pms-spacing-lg);
}
.pms-section p { font-size: 1.1rem; line-height: 1.8; }

/* ========================================
   FEATURES GRID
   ======================================== */
.pms-features {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--pms-spacing-md);
    margin: var(--pms-spacing-lg) 0;
}
.pms-feature {
    background: var(--pms-light);
    padding: 1.5rem;
    border-radius: var(--pms-radius-md);
    text-align: center;
}
.pms-feature-icon { font-size: 1.5rem; display: block; margin-bottom: 0.5rem; }
.pms-feature h4 { margin: 0; font-size: 1rem; }

/* ========================================
   BENEFITS
   ======================================== */
.pms-benefits {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: var(--pms-spacing-lg);
    margin: var(--pms-spacing-lg) 0;
}
.pms-benefit {
    background: var(--pms-white);
    border-radius: var(--pms-radius-lg);
    box-shadow: var(--pms-shadow-md);
    padding: 1.5rem;
    text-align: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.pms-benefit:hover {
    transform: translateY(-4px);
    box-shadow: var(--pms-shadow-lg);
}
.pms-benefit-icon { font-size: 2rem; margin-bottom: var(--pms-spacing-md); }
.pms-benefit h4 { color: var(--pms-primary); margin-bottom: var(--pms-spacing-sm); }
.pms-benefit p { font-size: 0.95rem; margin: 0; }

/* ========================================
   TESTIMONIALS
   ======================================== */
.pms-testimonials {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--pms-spacing-lg);
    margin: var(--pms-spacing-lg) 0;
}
.pms-testimonial {
    background: var(--pms-white);
    border-radius: var(--pms-radius-lg);
    box-shadow: var(--pms-shadow-md);
    padding: 1.5rem;
}
.pms-testimonial-text { font-style: italic; margin-bottom: var(--pms-spacing-md); }
.pms-testimonial-author { font-weight: 600; color: var(--pms-primary); margin: 0; }

/* ========================================
   SERVICES GRID
   ======================================== */
.pms-services {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--pms-spacing-lg);
    margin-top: var(--pms-spacing-lg);
}
.pms-service {
    background: var(--pms-light);
    padding: 1.5rem;
    border-radius: var(--pms-radius-md);
    text-align: center;
    text-decoration: none;
    color: inherit;
    transition: all 0.3s ease;
}
.pms-service:hover {
    background: var(--pms-white);
    box-shadow: var(--pms-shadow-md);
    transform: translateY(-4px);
}
.pms-service-icon { font-size: 2.5rem; display: block; margin-bottom: 0.5rem; }
.pms-service h4 { margin-bottom: var(--pms-spacing-sm); }
.pms-service-link { font-size: 0.9rem; color: var(--pms-text-muted); }

/* ========================================
   CITIES
   ======================================== */
.pms-cities {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: var(--pms-spacing-md);
}
.pms-city {
    padding: 0.5rem 1rem;
    background: var(--pms-light);
    border-radius: var(--pms-radius-md);
    text-decoration: none;
    color: var(--pms-text);
    font-size: 0.9rem;
    transition: all 0.3s ease;
}
.pms-city:hover {
    background: var(--pms-primary);
    color: var(--pms-white);
}

/* ========================================
   CTA SECTION
   ======================================== */
.pms-cta {
    background: var(--pms-light);
    padding: var(--pms-spacing-xl);
    text-align: center;
    border-radius: var(--pms-radius-lg);
    margin: var(--pms-spacing-xl) auto;
    max-width: 900px;
}
.pms-cta h3 { color: var(--pms-primary); margin-bottom: var(--pms-spacing-md); }
.pms-cta-buttons {
    display: flex;
    gap: var(--pms-spacing-md);
    justify-content: center;
    flex-wrap: wrap;
    margin-top: var(--pms-spacing-lg);
}
.pms-cta-hours {
    margin-top: var(--pms-spacing-lg);
    font-weight: 600;
    color: var(--pms-primary);
}

/* ========================================
   FOOTER
   ======================================== */
.pms-footer {
    background: var(--pms-dark);
    color: var(--pms-white);
    padding: var(--pms-spacing-xl) 0;
    margin-top: var(--pms-spacing-xl);
}
.pms-footer a { color: var(--pms-secondary); }
.pms-footer a:hover { color: var(--pms-white); }
.pms-footer-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--pms-spacing-lg);
}
.pms-footer-section h4 { color: var(--pms-white); margin-bottom: var(--pms-spacing-md); }
.pms-footer-section p,
.pms-footer-section li { font-size: 0.9rem; color: rgba(255,255,255,0.8); }
.pms-footer-section ul { list-style: none; margin: 0; padding: 0; }
.pms-footer-section li { margin-bottom: 0.5rem; }
.pms-footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.1);
    padding-top: 1.5rem;
    margin-top: var(--pms-spacing-lg);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--pms-spacing-md);
}

/* ========================================
   RESPONSIVE
   ======================================== */
@media (max-width: 768px) {
    :root { --pms-font-size-base: 14px; }
    .pms-hero h1 { font-size: 1.75rem; }
    .pms-hero .pms-subtitle { font-size: 1rem; }
    .pms-hero-cta { flex-direction: column; align-items: center; }
    .pms-benefits { grid-template-columns: 1fr; }
    .pms-cta { padding: var(--pms-spacing-lg); margin: var(--pms-spacing-lg) 1rem; }
    .pms-footer-grid { grid-template-columns: 1fr; }
    h1 { font-size: 1.75rem; }
    h2 { font-size: 1.5rem; }
    h3 { font-size: 1.25rem; }
    .pms-nav { display: none; }
    .pms-menu-toggle { display: block; }
}

@media (max-width: 480px) {
    .pms-container { padding: 0 1rem; }
    .pms-hero { padding: var(--pms-spacing-lg) 0; }
    .pms-content { padding: var(--pms-spacing-lg) 1rem; }
    .pms-btn { padding: 0.6rem 1.2rem; font-size: 0.9rem; }
}
