/*
Theme Name: GeneratePress Child
Template: generatepress
Version: 1.0
Description: HKHowMuch custom child theme
*/

/* === HKHM Global Styles === */
:root {
    --hkhm-blue: #1B3A6B;
    --hkhm-green: #00A878;
    --hkhm-bg: #F8F9FA;
    --hkhm-border: #E2E8F0;
    --hkhm-text: #1A202C;
    --hkhm-muted: #718096;
}

/* Price Hero */
.hkhm-price-hero {
    background: var(--hkhm-blue);
    color: white;
    padding: 32px;
    border-radius: 12px;
    text-align: center;
    margin: 24px 0;
}
.hkhm-price-range {
    font-size: 2.5rem;
    font-weight: 700;
    margin-bottom: 8px;
}
.hkhm-price-unit { font-size: 0.9rem; opacity: 0.75; }

/* Tier Table */
.hkhm-tier-table { margin: 24px 0; }
.hkhm-tier-row {
    display: grid;
    grid-template-columns: 1fr 1fr 2fr;
    gap: 16px;
    padding: 16px;
    border: 1px solid var(--hkhm-border);
    border-radius: 8px;
    margin-bottom: 8px;
    background: white;
}
.hkhm-tier-name { font-weight: 600; color: var(--hkhm-blue); }
.hkhm-tier-range { color: var(--hkhm-green); font-weight: 500; }
.hkhm-tier-notes { font-size: 13px; color: var(--hkhm-muted); }

/* Services Grid */
.hkhm-services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
    margin: 24px 0;
}
.hkhm-service-card {
    background: white;
    border: 1px solid var(--hkhm-border);
    border-radius: 10px;
    padding: 20px;
    text-decoration: none;
    color: var(--hkhm-text);
    transition: border-color 0.15s, box-shadow 0.15s;
    display: block;
}
.hkhm-service-card:hover {
    border-color: var(--hkhm-blue);
    box-shadow: 0 4px 12px rgba(27,58,107,0.08);
    text-decoration: none;
    color: var(--hkhm-text);
}
.hkhm-sc-title {
    font-weight: 600;
    margin-bottom: 8px;
    font-size: 15px;
    color: var(--hkhm-blue);
}
.hkhm-sc-price {
    color: var(--hkhm-green);
    font-weight: 500;
    font-size: 14px;
    margin-bottom: 8px;
}
.hkhm-sc-link { font-size: 13px; color: var(--hkhm-muted); }

/* Comparison Grid */
.hkhm-comp-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 12px;
    margin: 20px 0;
}
.hkhm-comp-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: white;
    border: 1px solid var(--hkhm-border);
    border-radius: 8px;
    padding: 14px 16px;
    text-decoration: none;
    color: var(--hkhm-text);
    font-size: 14px;
    font-weight: 500;
    transition: border-color 0.15s;
}
.hkhm-comp-card:hover {
    border-color: var(--hkhm-green);
    text-decoration: none;
    color: var(--hkhm-text);
}
.hkhm-comp-badge {
    background: #EBF0FA;
    color: var(--hkhm-blue);
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 20px;
    white-space: nowrap;
    margin-left: 8px;
}

/* FAQ */
.hkhm-faq-section { margin: 32px 0; }
.hkhm-faq-section > h2 {
    font-size: 1.3rem;
    color: var(--hkhm-blue);
    margin-bottom: 16px;
}
.hkhm-faq-item {
    border: 1px solid var(--hkhm-border);
    border-radius: 8px;
    margin-bottom: 8px;
    overflow: hidden;
}
.hkhm-faq-q {
    width: 100%;
    background: white;
    border: none;
    padding: 16px 20px;
    text-align: left;
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--hkhm-text);
}
.hkhm-faq-a {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
    padding: 0 20px;
    background: var(--hkhm-bg);
}
.hkhm-faq-a.open { max-height: 400px; padding: 16px 20px; }

/* Hub Stats */
.hkhm-hub-stats-dyn {
    display: flex;
    gap: 0;
    border: 1px solid var(--hkhm-border);
    border-radius: 10px;
    overflow: hidden;
    margin: 20px 0;
    background: white;
}
.hkhm-hub-stat-dyn {
    flex: 1;
    text-align: center;
    padding: 16px;
    border-right: 1px solid var(--hkhm-border);
}
.hkhm-hub-stat-dyn:last-child { border-right: none; }
.hkhm-hub-stat-dyn .num {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--hkhm-blue);
}
.hkhm-hub-stat-dyn .lbl { font-size: 0.75rem; color: var(--hkhm-muted); }

/* Hub Quick Nav */
.hkhm-hub-quicknav-dyn {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin: 16px 0;
}
.hkhm-hub-quicknav-dyn a {
    background: white;
    border: 1.5px solid var(--hkhm-blue);
    border-radius: 20px;
    padding: 5px 16px;
    font-size: 13px;
    text-decoration: none;
    color: var(--hkhm-blue);
    font-weight: 500;
    transition: background 0.15s, color 0.15s;
}
.hkhm-hub-quicknav-dyn a:hover {
    background: var(--hkhm-blue);
    color: white;
    text-decoration: none;
}

/* Lead Form */
.hkhm-lead-form {
    background: #f0faf6;
    border: 1.5px solid var(--hkhm-green);
    border-radius: 12px;
    padding: 28px;
    margin: 32px 0;
}
.hkhm-lead-form h3 { color: var(--hkhm-blue); margin-bottom: 8px; }
.hkhm-lead-fields {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 16px 0;
}
.hkhm-lead-fields input {
    padding: 12px 16px;
    border: 1px solid var(--hkhm-border);
    border-radius: 8px;
    font-size: 14px;
    color: #1a202c;
    background: white;
    box-sizing: border-box;
    width: 100%;
}
.hkhm-lead-fields button {
    background: var(--hkhm-green);
    color: white;
    border: none;
    border-radius: 8px;
    padding: 14px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    width: 100%;
}
.hkhm-lead-fields button:hover { background: #008f65; }
.hkhm-lead-note { font-size: 12px; color: var(--hkhm-muted); margin-top: 8px; }
.hkhm-lead-success {
    text-align: center;
    color: var(--hkhm-green);
    font-weight: 600;
    padding: 20px;
}

/* Comparison Page */
.hkhm-comparison-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin: 24px 0;
}
.hkhm-comp-col {
    background: white;
    border: 1px solid var(--hkhm-border);
    border-radius: 10px;
    padding: 24px;
}
.hkhm-comp-col h3 { color: var(--hkhm-blue); margin-bottom: 16px; }
.hkhm-pros h4 { color: var(--hkhm-green); font-size: 14px; margin: 12px 0 6px; }
.hkhm-cons h4 { color: #e53e3e; font-size: 14px; margin: 12px 0 6px; }
.hkhm-pros ul, .hkhm-cons ul { margin: 0; padding-left: 18px; }
.hkhm-pros li, .hkhm-cons li { font-size: 14px; margin-bottom: 4px; }
.hkhm-use-case {
    font-size: 13px;
    color: var(--hkhm-muted);
    background: var(--hkhm-bg);
    padding: 8px 12px;
    border-radius: 6px;
    margin-bottom: 12px;
}

/* Quick Answer */
.hkhm-quick-answer {
    background: #EBF0FA;
    border-left: 4px solid var(--hkhm-blue);
    padding: 20px 24px;
    border-radius: 0 8px 8px 0;
    margin: 20px 0;
}
.hkhm-quick-answer h2 { color: var(--hkhm-blue); font-size: 1rem; margin-bottom: 8px; }
.hkhm-quick-answer p { color: var(--hkhm-text); margin: 0; }

/* E-E-A-T Bar */
.hkhm-eeat-bar {
    display: flex;
    gap: 16px;
    font-size: 12px;
    color: var(--hkhm-muted);
    margin-bottom: 16px;
    padding: 8px 0;
    border-bottom: 1px solid var(--hkhm-border);
    flex-wrap: wrap;
}

/* Hub Back Link */
.hkhm-hub-back { margin-bottom: 16px; }
.hkhm-hub-back a {
    color: var(--hkhm-blue);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
}
.hkhm-hub-back a:hover { text-decoration: underline; }

/* Hub Section */
.hkhm-hub-section-dyn { margin: 40px 0; }
.hkhm-hub-section-dyn > h2 {
    font-size: 1.3rem;
    color: var(--hkhm-blue);
    margin-bottom: 20px;
    padding-bottom: 8px;
    border-bottom: 3px solid var(--hkhm-green);
    display: inline-block;
}

/* Intro Summary */
.hkhm-intro {
    background: var(--hkhm-bg);
    border-radius: 8px;
    padding: 16px 20px;
    color: var(--hkhm-text);
    font-size: 15px;
    line-height: 1.7;
    margin: 16px 0 24px;
}

/* Expert Tip */
.hkhm-expert-tip {
    background: #fff8e6;
    border: 1px solid #f6c945;
    border-radius: 8px;
    padding: 16px 20px;
    margin: 20px 0;
    font-size: 14px;
}

/* Footer Hub Links */
.hkhm-footer-links {
    text-align: center;
    padding: 16px;
    font-size: 13px;
    border-top: 1px solid var(--hkhm-border);
    margin-top: 8px;
}
.hkhm-footer-links a {
    color: var(--hkhm-muted);
    text-decoration: none;
    margin: 0 4px;
}
.hkhm-footer-links a:hover { color: var(--hkhm-blue); }


/* ============================================================
   HKHM COST PAGE UI — CANONICAL v12
   Unified colors across ALL hubs
   ============================================================ */

/* ── Hero Card ── */
.hkhm-hero-block {
    background: #eef2ff !important;
    border: 1px solid #c7d2fe !important;
    border-radius: 16px !important;
    padding: 24px !important;
    margin: 20px 0 28px !important;
    display: block !important;
}
.hkhm-hub-badge {
    display: inline-block !important;
    background: color-mix(in srgb, var(--cat-color, #4f46e5) 15%, white) !important;
    color: color-mix(in srgb, var(--cat-color, #4f46e5) 80%, black) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.04em !important;
    padding: 4px 12px !important;
    border-radius: 20px !important;
    margin-bottom: 12px !important;
    border: 1px solid color-mix(in srgb, var(--cat-color, #4f46e5) 25%, white) !important;
}
.hkhm-hero-ref { font-size: 12px !important; color: #6b7280 !important; margin: 0 0 4px !important; }
.hkhm-hero-price {
    font-size: 30px !important; font-weight: 700 !important; color: #1e293b !important;
    margin: 4px 0 2px !important; line-height: 1.2 !important; display: block !important;
}
.hkhm-hero-unit { font-size: 12px !important; color: #9ca3af !important; margin: 0 0 14px !important; }
.hkhm-progress-wrap {
    display: flex !important; align-items: center !important; gap: 10px !important; margin: 0 0 14px !important;
}
.hkhm-progress-min,
.hkhm-progress-max { font-size: 12px !important; color: #9ca3af !important; white-space: nowrap !important; flex-shrink: 0 !important; }
.hkhm-progress-bar {
    flex: 1 !important; height: 6px !important; background: #e2e8f0 !important;
    border-radius: 99px !important; overflow: hidden !important; display: block !important; min-width: 100px !important;
}
.hkhm-progress-fill {
    height: 100% !important; border-radius: 99px !important;
    background: linear-gradient(90deg, #34d399 0%, #818cf8 100%) !important;
    display: block !important; min-width: 25% !important;
}
.hkhm-hero-intro { font-size: 13px !important; color: #4b5563 !important; line-height: 1.6 !important; margin: 0 0 14px !important; }
.hkhm-hero-icons {
    display: flex !important; flex-wrap: wrap !important; gap: 20px !important;
    padding-top: 12px !important; border-top: 1px solid #dde3f8 !important;
}
.hkhm-hero-icons span { font-size: 12px !important; color: #6b7280 !important; }

/* ── Quick Answer ── */
.hkhm-quick-answer-box {
    border-left: 3px solid #0d6b6b !important; border-radius: 0 8px 8px 0 !important;
    background: #f0fdf9 !important; padding: 14px 18px !important; margin: 20px 0 !important; display: block !important;
}
.hkhm-qa-label { font-size: 11px !important; font-weight: 600 !important; color: #0d6b6b !important; margin-bottom: 4px !important; display: block !important; }

/* ── Market Overview ── */
.hkhm-market-overview {
    background: #fff !important; border: 1px solid #e5e7eb !important;
    border-radius: 12px !important; padding: 18px 22px !important; margin: 20px 0 !important; display: block !important;
}
.hkhm-market-overview-title { font-size: 15px !important; font-weight: 600 !important; color: #1e293b !important; margin: 0 0 8px !important; }
.hkhm-market-overview p { font-size: 13px !important; color: #4b5563 !important; line-height: 1.7 !important; margin: 0 !important; }

/* ── Tier Table ── */
.hkhm-tier-section { margin: 24px 0 !important; }
.hkhm-tier-title { font-size: 17px !important; font-weight: 700 !important; color: #1e293b !important; margin-bottom: 14px !important; }
.hkhm-tier-cards { display: flex !important; flex-direction: column !important; gap: 10px !important; }
.hkhm-tier-card {
    position: relative !important; border: 1px solid #e5e7eb !important;
    border-radius: 12px !important; padding: 18px !important; background: #fff !important; display: block !important;
}
.hkhm-tier-recommended { border: 1.5px solid #818cf8 !important; padding-top: 30px !important; }
.hkhm-tier-badge {
    position: absolute !important; top: -11px !important; left: 50% !important;
    transform: translateX(-50%) !important; background: #818cf8 !important; color: #fff !important;
    font-size: 11px !important; font-weight: 600 !important; padding: 2px 12px !important;
    border-radius: 20px !important; white-space: nowrap !important;
}
.hkhm-tier-name { font-size: 10px !important; color: #9ca3af !important; font-weight: 600 !important; text-transform: uppercase !important; letter-spacing: 0.08em !important; margin-bottom: 4px !important; }
.hkhm-tier-desc { font-size: 13px !important; color: #4b5563 !important; margin-bottom: 8px !important; }
.hkhm-tier-price { font-size: 18px !important; font-weight: 700 !important; color: #1e293b !important; }
.hkhm-tier-footnote { font-size: 11px !important; color: #9ca3af !important; margin-top: 10px !important; }

/* ── Expert Tip ── */
.hkhm-expert-tip {
    background: #fffbeb !important; border-left: 3px solid #f59e0b !important;
    border-radius: 0 8px 8px 0 !important; padding: 14px 18px !important; margin: 20px 0 !important; display: block !important;
}
.hkhm-expert-label { font-size: 11px !important; font-weight: 600 !important; color: #b45309 !important; margin-bottom: 4px !important; display: block !important; }

/* ── FAQ ── */
.hkhm-faq-section { margin: 24px 0 !important; }
.hkhm-faq-heading { font-size: 17px !important; font-weight: 700 !important; color: #1e293b !important; margin-bottom: 14px !important; }
.hkhm-faq-item {
    background: #f8fafc !important; border: 1px solid #e9ecef !important;
    border-radius: 10px !important; padding: 14px 16px !important; margin-bottom: 10px !important; display: block !important;
}
.hkhm-faq-q {
    display: flex !important; flex-direction: row !important; align-items: flex-start !important;
    justify-content: flex-start !important; text-align: left !important;
    background: none !important; background-color: transparent !important; border: none !important;
    padding: 0 !important; gap: 10px !important; font-weight: 600 !important; font-size: 14px !important;
    color: #1e293b !important; width: 100% !important; margin-bottom: 8px !important;
    cursor: default !important; line-height: 1.4 !important;
}
.hkhm-faq-q::before, .hkhm-faq-q::after { content: none !important; display: none !important; }
.hkhm-faq-q-badge {
    display: inline-flex !important; align-items: center !important; justify-content: center !important;
    background: #818cf8 !important; background-color: #818cf8 !important; color: #fff !important;
    font-size: 10px !important; font-weight: 700 !important;
    width: 20px !important; min-width: 20px !important; height: 20px !important;
    border-radius: 4px !important; flex-shrink: 0 !important; margin-top: 2px !important; padding: 0 !important;
}
.hkhm-faq-a {
    display: block !important; max-height: none !important; overflow: visible !important;
    padding-left: 30px !important; font-size: 13px !important; color: #6b7280 !important;
    line-height: 1.6 !important; background: none !important; border: none !important;
}

/* ── Hub More Button ── */
.hkhm-hub-more-btn {
    display: inline-block !important; border: 1.5px solid #0d6b6b !important; color: #0d6b6b !important;
    border-radius: 8px !important; padding: 10px 18px !important; font-weight: 600 !important;
    font-size: 13px !important; text-decoration: none !important; margin: 16px 0 !important;
}
.hkhm-hub-more-btn:hover { background: #0d6b6b !important; color: #fff !important; }

/* ── Related Costs ── */
.hkhm-related-costs { margin: 24px 0 !important; }
.hkhm-related-costs h3 {
    font-size: 17px !important; font-weight: 700 !important; color: #1e293b !important;
    margin-bottom: 14px !important; padding-bottom: 8px !important; border-bottom: 1.5px solid #0d6b6b !important;
}
.hkhm-related-grid { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 12px !important; }
.hkhm-related-card {
    border: 1px solid #e5e7eb !important; border-radius: 10px !important; padding: 16px !important;
    text-decoration: none !important; color: inherit !important; display: block !important; background: #fff !important;
}
.hkhm-related-card:hover { border-color: #818cf8 !important; }
.hkhm-related-card h4 { font-size: 13px !important; font-weight: 600 !important; color: #1e293b !important; margin-bottom: 6px !important; line-height: 1.4 !important; }
.hkhm-related-price { color: #0d6b6b !important; font-weight: 600 !important; font-size: 13px !important; margin-bottom: 6px !important; display: block !important; }
.hkhm-related-link { font-size: 12px !important; color: #9ca3af !important; }

/* ── Price Check Widget ── */
.hkhm-price-check {
    background: #fff !important; border-top: 3px solid #0d6b6b !important;
    border-radius: 12px !important; padding: 22px !important; margin: 28px 0 !important;
    box-shadow: 0 1px 8px rgba(0,0,0,0.06) !important; display: block !important;
}
.hkhm-pc-header { display: flex !important; align-items: center !important; gap: 14px !important; margin-bottom: 18px !important; }
.hkhm-pc-icon {
    font-size: 22px !important; background: #f0fdf4 !important; border-radius: 10px !important;
    width: 48px !important; height: 48px !important; display: flex !important;
    align-items: center !important; justify-content: center !important; flex-shrink: 0 !important;
}
.hkhm-pc-title { font-size: 17px !important; font-weight: 700 !important; color: #1e293b !important; margin: 0 0 3px !important; }
.hkhm-pc-subtitle { font-size: 12px !important; color: #6b7280 !important; margin: 0 !important; }
.hkhm-pc-input-group {
    display: flex !important; flex-direction: row !important; align-items: stretch !important;
    border: 1px solid #d1d5db !important; border-radius: 10px !important;
    overflow: hidden !important; margin-bottom: 10px !important; background: #f9fafb !important;
}
.hkhm-pc-label {
    font-size: 13px !important; font-weight: 600 !important; color: #374151 !important;
    padding: 13px 14px !important; white-space: nowrap !important; background: #f3f4f6 !important;
    border-right: 1px solid #e5e7eb !important; flex-shrink: 0 !important;
    display: flex !important; align-items: center !important;
}
.hkhm-pc-input {
    border: none !important; background: transparent !important; padding: 13px 14px !important;
    font-size: 14px !important; flex: 1 !important; outline: none !important;
    min-width: 0 !important; color: #1e293b !important;
}
.hkhm-pc-btn {
    width: 100% !important; background: #0d6b6b !important; color: #fff !important;
    border: none !important; border-radius: 10px !important; padding: 14px !important;
    font-size: 15px !important; font-weight: 700 !important; cursor: pointer !important;
    margin-bottom: 10px !important; display: block !important;
}
.hkhm-pc-btn:hover { background: #0a5555 !important; }
.hkhm-pc-anon { text-align: center !important; font-size: 12px !important; color: #9ca3af !important; margin: 0 !important; }

/* ── Responsive ── */
@media (max-width: 768px) {
    .hkhm-hero-price { font-size: 24px !important; }
    .hkhm-related-grid { grid-template-columns: 1fr !important; }
    .hkhm-hero-icons { gap: 12px !important; }
}

/* ============================================================
   END HKHM COST PAGE UI CANONICAL v12
   ============================================================ */


/* ============================================================
   HKHM UI FIXES — Disclaimer + Navbar mobile
   ============================================================ */

/* Disclaimer — white card */
.hkhm-disclaimer-bar {
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 10px !important;
    padding: 16px 20px !important;
    margin: 24px 0 !important;
    display: block !important;
    border-left: none !important;
}
.hkhm-disclaimer-title,
.hkhm-disclaimer-bar strong {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #374151 !important;
    display: block !important;
    margin-bottom: 6px !important;
}
.hkhm-disclaimer-text,
.hkhm-disclaimer-bar p {
    font-size: 12px !important;
    color: #6b7280 !important;
    line-height: 1.7 !important;
    margin: 0 !important;
}

/* Navbar mobile fixes */
@media (max-width: 768px) {
    .site-header .inside-header {
        padding-top: 6px !important;
        padding-bottom: 6px !important;
        min-height: unset !important;
    }
    .site-header .site-logo img,
    .site-header .custom-logo {
        max-height: 28px !important;
        width: auto !important;
    }
}

/* ============================================================
   END HKHM UI FIXES
   ============================================================ */
