/*
Theme Name:  KlaviyoPro
Theme URI:   https://yoursite.com
Author:      Your Name
Author URI:  https://yoursite.com
Description: A clean, professional WordPress theme built for Klaviyo freelancers. Features full Customizer integration for homepage content, project management, blog with sidebar, and Google Fonts support.
Version:     1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License:     GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: klaviyopro
Tags:        custom-colors, custom-logo, custom-menu, featured-images, theme-options, blog, e-commerce, portfolio
*/

/* ============================================================
   CSS CUSTOM PROPERTIES (set by Customizer via wp_add_inline_style)
   ============================================================ */
:root {
    --kp-color-primary:    #1a6b45;
    --kp-color-accent:     #e8521a;
    --kp-color-ink:        #1a1916;
    --kp-color-ink-light:  #6b6860;
    --kp-color-ink-xlight: #b0aea8;
    --kp-color-bg:         #fafaf8;
    --kp-color-bg2:        #f3f2ee;
    --kp-color-white:      #ffffff;
    --kp-color-border:     #e4e2db;
    --kp-font-heading:     'Playfair Display', Georgia, serif;
    --kp-font-body:        'Outfit', sans-serif;
    --kp-radius:           12px;
    --kp-radius-pill:      100px;
    --kp-shadow:           0 4px 24px rgba(0,0,0,0.07);
    --kp-shadow-lg:        0 12px 48px rgba(0,0,0,0.10);
    --kp-max-width:        1200px;
    --kp-sidebar-width:    320px;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
    background:  var(--kp-color-bg);
    color:       var(--kp-color-ink);
    font-family: var(--kp-font-body);
    font-weight: 300;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a  { color: var(--kp-color-primary); text-decoration: none; transition: color .2s; }
a:hover { color: var(--kp-color-ink); }
ul, ol { padding-left: 1.5rem; }
button, input, textarea, select {
    font-family: var(--kp-font-body);
    font-size: 1rem;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1,h2,h3,h4,h5,h6 {
    font-family: var(--kp-font-heading);
    font-weight: 400;
    line-height: 1.15;
    letter-spacing: -0.01em;
    color: var(--kp-color-ink);
}
h1 { font-size: clamp(2.4rem, 5vw, 4rem); }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); }
h3 { font-size: clamp(1.3rem, 2.5vw, 1.8rem); }
h4 { font-size: 1.2rem; }
p  { margin-bottom: 1.2rem; color: var(--kp-color-ink-light); font-size: .95rem; line-height: 1.8; }
p:last-child { margin-bottom: 0; }
em  { color: var(--kp-color-primary); font-style: italic; }
strong { font-weight: 600; color: var(--kp-color-ink); }

/* Entry content typography */
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4 { margin: 2rem 0 1rem; }
.entry-content ul,
.entry-content ol { margin: 1rem 0 1.5rem; }
.entry-content li { margin-bottom: .5rem; color: var(--kp-color-ink-light); font-size: .95rem; }
.entry-content blockquote {
    border-left: 3px solid var(--kp-color-primary);
    padding: 1rem 1.5rem;
    margin: 2rem 0;
    background: var(--kp-color-bg2);
    border-radius: 0 var(--kp-radius) var(--kp-radius) 0;
    font-family: var(--kp-font-heading);
    font-style: italic;
    font-size: 1.1rem;
    color: var(--kp-color-ink);
}
.entry-content pre {
    background: var(--kp-color-ink);
    color: #e8f0e8;
    padding: 1.5rem;
    border-radius: var(--kp-radius);
    overflow-x: auto;
    font-size: .85rem;
    margin: 1.5rem 0;
}
.entry-content code {
    background: var(--kp-color-bg2);
    padding: .15rem .4rem;
    border-radius: 4px;
    font-size: .85rem;
}
.entry-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 1.5rem 0;
    font-size: .88rem;
}
.entry-content th {
    background: var(--kp-color-ink);
    color: var(--kp-color-white);
    padding: .75rem 1rem;
    text-align: left;
    font-weight: 500;
}
.entry-content td {
    padding: .7rem 1rem;
    border-bottom: 1px solid var(--kp-color-border);
    color: var(--kp-color-ink-light);
}
.entry-content tr:nth-child(even) td { background: var(--kp-color-bg2); }

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.kp-container {
    max-width: var(--kp-max-width);
    margin: 0 auto;
    padding: 0 2rem;
}
.kp-section { padding: 6rem 0; }
.kp-section--dark { background: var(--kp-color-ink); }
.kp-section--light { background: var(--kp-color-bg2); }
.kp-section--white { background: var(--kp-color-white); }
.kp-section-eyebrow {
    font-size: .72rem; font-weight: 500; letter-spacing: .12em;
    text-transform: uppercase; color: var(--kp-color-primary);
    margin-bottom: .6rem; display: block;
}
.kp-section-title { margin-bottom: 1rem; }
.kp-section-sub {
    font-size: .95rem; color: var(--kp-color-ink-light);
    line-height: 1.8; max-width: 560px; margin-bottom: 0;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.kp-btn {
    display: inline-block; padding: .85rem 2rem;
    border-radius: var(--kp-radius-pill);
    font-size: .88rem; font-weight: 500;
    letter-spacing: .02em; transition: all .2s;
    border: 2px solid transparent; cursor: pointer;
    text-decoration: none;
}
.kp-btn--primary {
    background: var(--kp-color-ink); color: var(--kp-color-white);
}
.kp-btn--primary:hover {
    background: var(--kp-color-primary); color: var(--kp-color-white);
    transform: translateY(-2px);
}
.kp-btn--green {
    background: var(--kp-color-primary); color: var(--kp-color-white);
}
.kp-btn--green:hover {
    background: #145235; color: var(--kp-color-white);
    transform: translateY(-2px);
}
.kp-btn--outline {
    border-color: var(--kp-color-border); color: var(--kp-color-ink);
}
.kp-btn--outline:hover {
    border-color: var(--kp-color-primary); color: var(--kp-color-primary);
    transform: translateY(-2px);
}
.kp-btn--white {
    background: var(--kp-color-white); color: var(--kp-color-primary);
}
.kp-btn--white:hover { background: #f0f8f4; transform: translateY(-2px); }
.kp-btn--sm { padding: .55rem 1.2rem; font-size: .8rem; }

/* ============================================================
   TAGS / BADGES
   ============================================================ */
.kp-tag {
    display: inline-block;
    background: #eef6f1; color: var(--kp-color-primary);
    font-size: .68rem; font-weight: 500;
    letter-spacing: .06em; text-transform: uppercase;
    padding: .28rem .75rem; border-radius: var(--kp-radius-pill);
}
.kp-badge {
    display: inline-block;
    background: var(--kp-color-primary); color: var(--kp-color-white);
    font-size: .65rem; font-weight: 600;
    letter-spacing: .08em; text-transform: uppercase;
    padding: .22rem .65rem; border-radius: var(--kp-radius-pill);
}
.kp-badge--gold { background: #c8922a; }

/* ============================================================
   HEADER / NAVIGATION
   ============================================================ */
.site-header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
    background: rgba(250,250,248,.92);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--kp-color-border);
    transition: box-shadow .3s;
}
.site-header.scrolled { box-shadow: 0 2px 20px rgba(0,0,0,.08); }
.header-inner {
    display: flex; align-items: center;
    justify-content: space-between;
    height: 70px;
    max-width: var(--kp-max-width);
    margin: 0 auto; padding: 0 2rem;
}
.site-branding { display: flex; align-items: center; gap: .75rem; }
.site-logo img { height: 40px; width: auto; }
.site-title-link {
    font-family: var(--kp-font-heading);
    font-style: italic; font-size: 1.2rem;
    color: var(--kp-color-ink); text-decoration: none;
}
.site-title-link:hover { color: var(--kp-color-primary); }

/* Primary nav */
.primary-navigation { display: flex; align-items: center; gap: 2rem; }
.primary-navigation ul { list-style: none; display: flex; gap: 2rem; padding: 0; margin: 0; }
.primary-navigation a {
    font-size: .82rem; font-weight: 400; letter-spacing: .04em;
    color: var(--kp-color-ink-light); text-decoration: none; transition: color .2s;
    padding: .3rem 0;
}
.primary-navigation a:hover,
.primary-navigation .current-menu-item > a { color: var(--kp-color-ink); }
.primary-navigation .current-menu-item > a {
    border-bottom: 1.5px solid var(--kp-color-primary);
}

/* Dropdown */
.primary-navigation li { position: relative; }
.primary-navigation .sub-menu {
    display: none; position: absolute; top: 100%; left: 0;
    background: var(--kp-color-white);
    border: 1px solid var(--kp-color-border);
    border-radius: var(--kp-radius);
    padding: .5rem 0; min-width: 200px;
    box-shadow: var(--kp-shadow); flex-direction: column; gap: 0;
}
.primary-navigation li:hover > .sub-menu { display: flex; }
.primary-navigation .sub-menu a {
    padding: .6rem 1.2rem; display: block; font-size: .82rem;
}
.primary-navigation .sub-menu a:hover { background: var(--kp-color-bg2); }

/* Mobile toggle */
.menu-toggle {
    display: none; background: none; border: none;
    cursor: pointer; padding: .5rem; color: var(--kp-color-ink);
}
.menu-toggle span {
    display: block; width: 22px; height: 2px;
    background: var(--kp-color-ink); margin: 4px 0;
    transition: transform .3s, opacity .3s;
}
.header-cta { display: flex; gap: .6rem; align-items: center; }
.header-store-link {
    font-size: .8rem; font-weight: 500; color: var(--kp-color-primary);
    border: 1.5px solid #c6e0d3; padding: .45rem 1rem;
    border-radius: var(--kp-radius-pill); transition: all .2s;
}
.header-store-link:hover {
    background: var(--kp-color-primary); color: var(--kp-color-white);
    border-color: var(--kp-color-primary);
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.hero-section {
    padding: 11rem 0 7rem;
    background: var(--kp-color-white);
    border-bottom: 1px solid var(--kp-color-border);
}
.hero-inner {
    display: grid; grid-template-columns: 1fr 360px;
    gap: 5rem; align-items: end;
}
.hero-eyebrow {
    display: inline-flex; align-items: center; gap: .6rem;
    font-size: .75rem; font-weight: 500; letter-spacing: .1em;
    text-transform: uppercase; color: var(--kp-color-primary);
    margin-bottom: 1.5rem; animation: kpFadeUp .6s ease both;
}
.hero-eyebrow-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--kp-color-primary); animation: kpPulse 2s ease infinite;
}
@keyframes kpPulse {
    0%,100% { box-shadow: 0 0 0 0 rgba(26,107,69,.4); }
    50%      { box-shadow: 0 0 0 7px rgba(26,107,69,0); }
}
.hero-title { animation: kpFadeUp .7s .1s ease both; margin-bottom: 1.2rem; }
.hero-subtitle {
    font-size: 1rem; line-height: 1.8; color: var(--kp-color-ink-light);
    max-width: 500px; margin-bottom: 2.2rem;
    animation: kpFadeUp .7s .2s ease both;
}
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; animation: kpFadeUp .7s .3s ease both; }
.hero-avail {
    display: inline-flex; align-items: center; gap: .5rem;
    font-size: .72rem; letter-spacing: .08em; color: #4ade80;
    margin-top: 1.5rem; animation: kpFadeUp .7s .4s ease both;
}
.hero-avail-dot {
    width: 7px; height: 7px; border-radius: 50%; background: #4ade80;
    animation: kpPulse 2s ease infinite;
}

/* Hero stats card */
.hero-card {
    background: var(--kp-color-white);
    border: 1px solid var(--kp-color-border);
    border-radius: 20px; padding: 2rem;
    box-shadow: var(--kp-shadow-lg);
    animation: kpFadeLeft .8s .3s ease both;
}
.hero-card-label {
    font-size: .7rem; font-weight: 500; letter-spacing: .1em;
    text-transform: uppercase; color: var(--kp-color-ink-xlight);
    margin-bottom: 1.2rem;
}
.hero-metric-row {
    padding: .9rem 0; border-bottom: 1px solid var(--kp-color-border);
    display: flex; justify-content: space-between; align-items: baseline;
}
.hero-metric-row:last-child { border-bottom: none; }
.hero-metric-val {
    font-family: var(--kp-font-heading);
    font-size: 1.7rem; font-weight: 600;
    color: var(--kp-color-ink); letter-spacing: -.03em;
}
.hero-metric-val span { color: var(--kp-color-primary); }
.hero-metric-desc {
    font-size: .73rem; color: var(--kp-color-ink-light);
    text-align: right; max-width: 120px; line-height: 1.4;
}

/* Logos strip */
.logos-strip {
    background: var(--kp-color-white);
    border-bottom: 1px solid var(--kp-color-border);
    padding: 1.5rem 2rem;
    display: flex; align-items: center; gap: 1.5rem; overflow: hidden;
}
.logos-label {
    font-size: .7rem; font-weight: 500; letter-spacing: .1em;
    text-transform: uppercase; color: var(--kp-color-ink-xlight);
    white-space: nowrap; flex-shrink: 0;
}
.logos-divider { width: 1px; height: 24px; background: var(--kp-color-border); flex-shrink: 0; }
.logos-track { display: flex; gap: 2.5rem; flex-wrap: wrap; }
.logos-track span {
    font-family: var(--kp-font-heading); font-style: italic;
    font-size: .9rem; color: var(--kp-color-ink-xlight);
}

/* ============================================================
   SERVICES SECTION
   ============================================================ */
.services-list { margin-top: 3rem; }
.service-row {
    display: grid; grid-template-columns: 56px 1fr 180px;
    align-items: start; gap: 2.5rem;
    padding: 2.2rem 0; border-bottom: 1px solid var(--kp-color-border);
    position: relative;
    transition: background .2s;
}
.service-row:first-child { border-top: 1px solid var(--kp-color-border); }
.service-row::after {
    content: '↗'; position: absolute; right: 0; top: 2.2rem;
    font-size: 1.1rem; color: var(--kp-color-primary);
    opacity: 0; transform: translateX(-8px); transition: all .2s;
}
.service-row:hover::after { opacity: 1; transform: translateX(0); }
.service-num {
    font-family: var(--kp-font-heading); font-style: italic;
    font-size: 1rem; color: var(--kp-color-ink-xlight); padding-top: .2rem;
}
.service-name {
    font-family: var(--kp-font-heading); font-size: 1.35rem;
    font-weight: 400; margin-bottom: .5rem; color: var(--kp-color-ink);
}
.service-desc { font-size: .84rem; line-height: 1.8; color: var(--kp-color-ink-light); margin: 0; }
.service-tags { display: flex; flex-direction: column; gap: .4rem; padding-top: .2rem; }

/* ============================================================
   PRICING SECTION
   ============================================================ */
.pricing-grid {
    display: grid; grid-template-columns: repeat(3,1fr);
    gap: 1.5rem; margin-top: 3rem;
}
.price-card {
    background: var(--kp-color-white);
    border: 1px solid var(--kp-color-border);
    border-radius: 18px; padding: 2rem;
    position: relative; overflow: hidden;
    transition: transform .25s, box-shadow .25s, border-color .25s;
}
.price-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--kp-shadow-lg);
    border-color: #c6e0d3;
}
.price-card--featured {
    background: var(--kp-color-primary);
    border-color: var(--kp-color-primary);
}
.price-card--featured .price-name,
.price-card--featured .price-period,
.price-card--featured .price-desc { color: rgba(255,255,255,.65); }
.price-card--featured .price-amount,
.price-card--featured .price-features li { color: var(--kp-color-white); }
.price-card--featured .price-features li::before { color: #c6e0d3; }
.price-card--featured .price-divider { background: rgba(255,255,255,.2); }
.price-badge {
    position: absolute; top: 1.2rem; right: 1.2rem;
    font-size: .62rem; font-weight: 600; letter-spacing: .08em;
    text-transform: uppercase; padding: .22rem .65rem;
    border-radius: var(--kp-radius-pill);
    background: #eef6f1; color: var(--kp-color-primary);
}
.price-card--featured .price-badge { background: rgba(255,255,255,.2); color: var(--kp-color-white); }
.price-name {
    font-size: .7rem; font-weight: 500; letter-spacing: .1em;
    text-transform: uppercase; color: var(--kp-color-ink-xlight); margin-bottom: .6rem;
}
.price-amount {
    font-family: var(--kp-font-heading); font-size: 2.8rem;
    font-weight: 600; letter-spacing: -.04em;
    color: var(--kp-color-ink); line-height: 1;
}
.price-period { font-size: .75rem; color: var(--kp-color-ink-light); margin-top: .3rem; }
.price-divider { height: 1px; background: var(--kp-color-border); margin: 1.4rem 0; }
.price-desc { font-size: .83rem; line-height: 1.7; color: var(--kp-color-ink-light); margin-bottom: 1.3rem; }
.price-features { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .6rem; margin-bottom: 1.8rem; }
.price-features li {
    font-size: .82rem; color: var(--kp-color-ink-light);
    display: flex; align-items: flex-start; gap: .55rem; line-height: 1.5;
}
.price-features li::before {
    content: '✓'; color: var(--kp-color-primary); font-weight: 600;
    font-size: .78rem; flex-shrink: 0; margin-top: .05rem;
}
.price-btn {
    display: block; text-align: center; padding: .85rem;
    border-radius: var(--kp-radius-pill); font-size: .84rem;
    font-weight: 500; text-decoration: none; transition: all .2s;
    border: 1.5px solid transparent;
}
.price-btn--outline { border-color: var(--kp-color-border); color: var(--kp-color-ink); }
.price-btn--outline:hover { border-color: var(--kp-color-primary); color: var(--kp-color-primary); }
.price-btn--white { background: var(--kp-color-white); color: var(--kp-color-primary); }
.price-btn--white:hover { background: #f0f9f4; }
.price-btn--dark { background: var(--kp-color-ink); color: var(--kp-color-white); }
.price-btn--dark:hover { background: #2a2a2a; }
.pricing-note { text-align: center; margin-top: 1.8rem; font-size: .8rem; color: var(--kp-color-ink-xlight); }
.pricing-note a { color: var(--kp-color-primary); font-weight: 500; }

/* ============================================================
   PROJECTS (CPT) SECTION
   ============================================================ */
.projects-grid {
    display: grid; grid-template-columns: repeat(3,1fr);
    gap: 1.5rem; margin-top: 3rem;
}
.project-card {
    background: var(--kp-color-bg);
    border: 1px solid var(--kp-color-border);
    border-radius: 16px; overflow: hidden;
    transition: transform .25s, box-shadow .25s;
    display: flex; flex-direction: column;
}
.project-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--kp-shadow-lg);
}
.project-thumb {
    height: 140px; display: flex; align-items: center;
    justify-content: center; font-size: 2.8rem; position: relative;
}
.project-thumb--audit   { background: linear-gradient(135deg,#eef6f1,#d4eddf); }
.project-thumb--welcome { background: linear-gradient(135deg,#f0f4ff,#dce6ff); }
.project-thumb--flows   { background: linear-gradient(135deg,#fff8ee,#ffeacc); }
.project-thumb--campaign{ background: linear-gradient(135deg,#fff0f0,#ffd6d6); }
.project-thumb--setup   { background: linear-gradient(135deg,#f4f0ff,#e3d9ff); }
.project-thumb--segment { background: linear-gradient(135deg,#f0fafb,#ccecf0); }
.project-thumb--default { background: linear-gradient(135deg,#f3f2ee,#e4e2db); }
.project-thumb img      { width: 100%; height: 100%; object-fit: cover; }
.project-body { padding: 1.3rem; flex: 1; display: flex; flex-direction: column; }
.project-category {
    font-size: .65rem; font-weight: 600; letter-spacing: .1em;
    text-transform: uppercase; color: var(--kp-color-primary); margin-bottom: .45rem;
}
.project-title {
    font-family: var(--kp-font-heading); font-size: 1.02rem;
    font-weight: 400; line-height: 1.4; color: var(--kp-color-ink);
    margin-bottom: .6rem;
}
.project-meta { display: flex; gap: 1rem; margin-bottom: .9rem; }
.project-meta-item {
    font-size: .7rem; color: var(--kp-color-ink-xlight);
    display: flex; align-items: center; gap: .3rem;
}
.project-divider { height: 1px; background: var(--kp-color-border); margin-bottom: 1rem; }
.project-footer {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: auto;
}
.project-price { display: flex; flex-direction: column; }
.project-price-val {
    font-family: var(--kp-font-heading); font-size: 1.3rem;
    font-weight: 600; color: var(--kp-color-ink); letter-spacing: -.02em;
    line-height: 1;
}
.project-price-label { font-size: .68rem; color: var(--kp-color-ink-xlight); margin-top: .15rem; }

/* Single project */
.single-project-hero { padding: 9rem 0 5rem; background: var(--kp-color-white); border-bottom: 1px solid var(--kp-color-border); }
.project-detail-grid { display: grid; grid-template-columns: 1fr 340px; gap: 4rem; align-items: start; }
.project-detail-sidebar { position: sticky; top: 90px; }
.project-order-card {
    background: var(--kp-color-white);
    border: 1px solid var(--kp-color-border);
    border-radius: 16px; padding: 2rem;
    box-shadow: var(--kp-shadow);
}
.project-order-price {
    font-family: var(--kp-font-heading); font-size: 2.5rem;
    font-weight: 600; letter-spacing: -.04em; color: var(--kp-color-ink);
    margin-bottom: .3rem;
}
.project-order-meta { display: flex; flex-direction: column; gap: .5rem; margin: 1.2rem 0; }
.project-order-meta-item { font-size: .83rem; color: var(--kp-color-ink-light); display: flex; align-items: center; gap: .5rem; }
.project-order-divider { height: 1px; background: var(--kp-color-border); margin: 1.2rem 0; }
.project-includes { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .55rem; margin-bottom: 1.5rem; }
.project-includes li {
    font-size: .82rem; color: var(--kp-color-ink-light);
    display: flex; align-items: center; gap: .5rem;
}
.project-includes li::before { content: '✓'; color: var(--kp-color-primary); font-weight: 600; }

/* ============================================================
   TESTIMONIALS / RESULTS
   ============================================================ */
.results-grid {
    display: grid; grid-template-columns: repeat(3,1fr);
    gap: 1.5rem; margin-top: 3rem;
}
.result-card {
    background: var(--kp-color-white);
    border: 1px solid var(--kp-color-border);
    border-radius: 16px; padding: 2rem;
    transition: transform .25s, box-shadow .25s;
}
.result-card:hover { transform: translateY(-4px); box-shadow: var(--kp-shadow-lg); }
.result-card--featured {
    grid-column: span 2;
    background: var(--kp-color-primary); border-color: var(--kp-color-primary);
}
.result-card--featured .result-client,
.result-card--featured .result-metric-label { color: rgba(255,255,255,.6); }
.result-card--featured .result-quote { color: rgba(255,255,255,.9); }
.result-card--featured .result-metric { color: var(--kp-color-white); }
.result-client {
    font-size: .7rem; font-weight: 500; letter-spacing: .1em;
    text-transform: uppercase; color: var(--kp-color-ink-xlight); margin-bottom: .9rem;
}
.result-quote {
    font-family: var(--kp-font-heading); font-size: 1rem;
    line-height: 1.6; color: var(--kp-color-ink);
    font-style: italic; margin-bottom: 1.5rem;
}
.result-metrics { display: flex; gap: 2rem; }
.result-metric {
    font-family: var(--kp-font-heading); font-size: 1.9rem;
    font-weight: 600; color: var(--kp-color-primary);
    letter-spacing: -.04em; line-height: 1;
}
.result-metric-label { font-size: .7rem; color: var(--kp-color-ink-light); margin-top: .25rem; }

/* ============================================================
   LEAD MAGNET
   ============================================================ */
.leadmag-section {
    background: var(--kp-color-white);
    border-top: 1px solid var(--kp-color-border);
    border-bottom: 1px solid var(--kp-color-border);
    padding: 5rem 0;
}
.leadmag-inner {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 5rem; align-items: center;
}
.leadmag-book {
    background: linear-gradient(135deg, var(--kp-color-primary) 0%, #0d4a2f 100%);
    border-radius: var(--kp-radius); padding: 2.5rem 2rem;
    box-shadow: 8px 12px 40px rgba(26,107,69,.25), -4px -4px 0 #c6e0d3;
    position: relative;
}
.leadmag-book-label {
    font-size: .65rem; font-weight: 600; letter-spacing: .12em;
    text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: .4rem;
}
.leadmag-book-title {
    font-family: var(--kp-font-heading); font-size: 1.5rem;
    color: var(--kp-color-white); line-height: 1.3; margin-bottom: 1.4rem;
}
.leadmag-book-items { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .55rem; }
.leadmag-book-items li {
    font-size: .78rem; color: rgba(255,255,255,.72);
    display: flex; align-items: center; gap: .5rem;
}
.leadmag-book-items li::before { content: '→'; color: #c6e0d3; font-size: .7rem; }
.leadmag-free-badge {
    position: absolute; top: -14px; right: -14px;
    background: #f5a623; color: #fff;
    font-family: var(--kp-font-heading); font-style: italic;
    font-size: 1rem; width: 58px; height: 58px;
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 16px rgba(245,166,35,.4);
}
.leadmag-title {
    font-family: var(--kp-font-heading); font-size: 2rem;
    line-height: 1.2; margin-bottom: .9rem;
}
.leadmag-desc { font-size: .88rem; line-height: 1.8; color: var(--kp-color-ink-light); margin-bottom: 1.8rem; }
.leadmag-form { display: flex; flex-direction: column; gap: .75rem; }
.kp-input {
    background: var(--kp-color-bg); border: 1.5px solid var(--kp-color-border);
    border-radius: 10px; padding: .9rem 1.2rem;
    font-family: var(--kp-font-body); font-size: .88rem;
    color: var(--kp-color-ink); font-weight: 300; outline: none;
    transition: border-color .2s; width: 100%;
}
.kp-input:focus { border-color: var(--kp-color-primary); }
.kp-input::placeholder { color: var(--kp-color-ink-xlight); }
.leadmag-note { font-size: .72rem; color: var(--kp-color-ink-xlight); }

/* ============================================================
   PROCESS SECTION
   ============================================================ */
.process-grid {
    display: grid; grid-template-columns: repeat(4,1fr);
    gap: 0; margin-top: 4rem;
    border-left: 1px solid rgba(255,255,255,.08);
}
.process-step {
    padding: 2.2rem 1.8rem 2.2rem 2rem;
    border-right: 1px solid rgba(255,255,255,.08);
}
.process-num {
    font-family: var(--kp-font-heading); font-style: italic;
    font-size: 2.8rem; font-weight: 400;
    color: rgba(255,255,255,.1); line-height: 1; margin-bottom: 1.3rem;
}
.process-title {
    font-family: var(--kp-font-heading); font-size: 1.05rem;
    font-weight: 400; color: var(--kp-color-white); margin-bottom: .6rem;
}
.process-desc { font-size: .8rem; line-height: 1.8; color: rgba(255,255,255,.4); margin: 0; }
.kp-section--dark .kp-section-eyebrow { color: #c6e0d3; }
.kp-section--dark .kp-section-title { color: var(--kp-color-white); }
.kp-section--dark .kp-section-title em { color: #c6e0d3; }

/* ============================================================
   CONTACT / CTA
   ============================================================ */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: start; }
.contact-details { margin-top: 1.5rem; display: flex; flex-direction: column; gap: .75rem; }
.contact-detail { font-size: .84rem; color: var(--kp-color-ink-light); display: flex; align-items: center; gap: .6rem; }
.contact-detail strong { color: var(--kp-color-ink); font-weight: 500; }
.contact-form { display: flex; flex-direction: column; gap: .85rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; }
textarea.kp-input { resize: vertical; min-height: 110px; }

/* ============================================================
   BLOG / ARCHIVE
   ============================================================ */
.blog-layout { display: grid; grid-template-columns: 1fr var(--kp-sidebar-width); gap: 4rem; padding: 5rem 0; }
.blog-layout--no-sidebar { grid-template-columns: 1fr; }
.posts-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 2rem; }
.posts-grid--single { grid-template-columns: 1fr; }
.post-card {
    background: var(--kp-color-white);
    border: 1px solid var(--kp-color-border);
    border-radius: var(--kp-radius); overflow: hidden;
    transition: transform .25s, box-shadow .25s;
    display: flex; flex-direction: column;
}
.post-card:hover { transform: translateY(-4px); box-shadow: var(--kp-shadow-lg); }
.post-card-thumb { height: 200px; overflow: hidden; background: var(--kp-color-bg2); }
.post-card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.post-card:hover .post-card-thumb img { transform: scale(1.04); }
.post-card-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.post-card-meta {
    display: flex; gap: 1rem; margin-bottom: .7rem;
    font-size: .7rem; color: var(--kp-color-ink-xlight); align-items: center;
}
.post-card-category { color: var(--kp-color-primary); font-weight: 500; }
.post-card-title {
    font-family: var(--kp-font-heading); font-size: 1.15rem;
    font-weight: 400; line-height: 1.4; color: var(--kp-color-ink);
    margin-bottom: .6rem; text-decoration: none; display: block;
}
.post-card-title:hover { color: var(--kp-color-primary); }
.post-card-excerpt { font-size: .83rem; line-height: 1.7; color: var(--kp-color-ink-light); flex: 1; margin-bottom: 1.2rem; }
.post-card-footer {
    display: flex; justify-content: space-between;
    align-items: center; padding-top: 1rem;
    border-top: 1px solid var(--kp-color-border);
    margin-top: auto;
}
.post-card-author { display: flex; align-items: center; gap: .5rem; }
.post-card-author img { width: 28px; height: 28px; border-radius: 50%; object-fit: cover; }
.post-card-author-name { font-size: .75rem; color: var(--kp-color-ink-light); }
.post-read-more { font-size: .78rem; color: var(--kp-color-primary); font-weight: 500; }
.post-read-more:hover { text-decoration: underline; }

/* Pagination */
.kp-pagination { display: flex; gap: .5rem; justify-content: center; margin-top: 3rem; }
.kp-pagination a, .kp-pagination span {
    padding: .5rem .9rem; border-radius: 8px;
    font-size: .82rem; border: 1px solid var(--kp-color-border);
    background: var(--kp-color-white); color: var(--kp-color-ink-light);
    text-decoration: none; transition: all .2s;
}
.kp-pagination .current, .kp-pagination a:hover {
    background: var(--kp-color-primary); color: var(--kp-color-white);
    border-color: var(--kp-color-primary);
}

/* ============================================================
   SINGLE POST
   ============================================================ */
.single-post-hero {
    padding: 9rem 0 4rem; background: var(--kp-color-white);
    border-bottom: 1px solid var(--kp-color-border);
}
.single-post-meta {
    display: flex; gap: 1.2rem; align-items: center;
    margin-bottom: 1.5rem; flex-wrap: wrap;
}
.single-post-meta a { font-size: .75rem; color: var(--kp-color-primary); font-weight: 500; }
.single-post-meta span { font-size: .75rem; color: var(--kp-color-ink-xlight); }
.single-post-title { margin-bottom: 1.5rem; }
.single-post-author { display: flex; align-items: center; gap: 1rem; }
.single-post-author img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.single-post-author-info { display: flex; flex-direction: column; }
.single-post-author-name { font-size: .88rem; font-weight: 500; color: var(--kp-color-ink); }
.single-post-author-role { font-size: .75rem; color: var(--kp-color-ink-xlight); }
.single-post-layout { display: grid; grid-template-columns: 1fr var(--kp-sidebar-width); gap: 4rem; padding: 4rem 0 6rem; }
.single-post-layout--no-sidebar { grid-template-columns: 1fr; }
.single-post-layout--no-sidebar .entry-content { max-width: 740px; margin: 0 auto; }
.single-post-featured-img { border-radius: var(--kp-radius); overflow: hidden; margin-bottom: 3rem; max-height: 500px; }
.single-post-featured-img img { width: 100%; height: 100%; object-fit: cover; }
.post-share { display: flex; align-items: center; gap: 1rem; margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--kp-color-border); }
.post-share-label { font-size: .78rem; color: var(--kp-color-ink-xlight); }
.post-share a { font-size: .78rem; color: var(--kp-color-ink-light); font-weight: 500; padding: .4rem .9rem; border: 1px solid var(--kp-color-border); border-radius: var(--kp-radius-pill); transition: all .2s; }
.post-share a:hover { border-color: var(--kp-color-primary); color: var(--kp-color-primary); }
.post-nav { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 3rem; }
.post-nav-item { background: var(--kp-color-white); border: 1px solid var(--kp-color-border); border-radius: var(--kp-radius); padding: 1.3rem; text-decoration: none; transition: all .2s; }
.post-nav-item:hover { border-color: var(--kp-color-primary); }
.post-nav-item--next { text-align: right; }
.post-nav-dir { font-size: .68rem; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: var(--kp-color-ink-xlight); margin-bottom: .4rem; }
.post-nav-title { font-family: var(--kp-font-heading); font-size: .95rem; color: var(--kp-color-ink); }

/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar { display: flex; flex-direction: column; gap: 2rem; }
.widget {
    background: var(--kp-color-white);
    border: 1px solid var(--kp-color-border);
    border-radius: var(--kp-radius); padding: 1.6rem;
}
.widget-title {
    font-family: var(--kp-font-heading); font-size: 1rem;
    font-weight: 400; color: var(--kp-color-ink);
    margin-bottom: 1.2rem; padding-bottom: .8rem;
    border-bottom: 1px solid var(--kp-color-border);
}
.widget ul { list-style: none; padding: 0; }
.widget ul li { padding: .45rem 0; border-bottom: 1px solid var(--kp-color-border); }
.widget ul li:last-child { border-bottom: none; }
.widget ul li a { font-size: .84rem; color: var(--kp-color-ink-light); transition: color .2s; }
.widget ul li a:hover { color: var(--kp-color-primary); }
.widget-search .search-form { display: flex; }
.widget-search .search-field {
    flex: 1; border: 1.5px solid var(--kp-color-border);
    border-right: none; border-radius: 8px 0 0 8px;
    padding: .65rem 1rem; font-size: .84rem; outline: none;
}
.widget-search .search-submit {
    background: var(--kp-color-primary); color: #fff; border: none;
    padding: .65rem 1rem; border-radius: 0 8px 8px 0; cursor: pointer;
    font-size: .84rem; transition: background .2s;
}
.widget-search .search-submit:hover { background: #145235; }
.sidebar-cta-widget {
    background: linear-gradient(135deg, var(--kp-color-primary), #0d4a2f);
    border: none; color: var(--kp-color-white); text-align: center;
}
.sidebar-cta-widget .widget-title { color: var(--kp-color-white); border-color: rgba(255,255,255,.15); }
.sidebar-cta-widget p { color: rgba(255,255,255,.7); font-size: .82rem; }

/* ============================================================
   SINGLE PAGE TEMPLATE
   ============================================================ */
.page-hero { padding: 9rem 0 5rem; background: var(--kp-color-white); border-bottom: 1px solid var(--kp-color-border); }
.page-content { padding: 5rem 0; max-width: 760px; margin: 0 auto; }
.page-content-wide { max-width: var(--kp-max-width); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
    border-top: 1px solid var(--kp-color-border);
    background: var(--kp-color-white);
}
.footer-widgets {
    display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 3rem; padding: 4rem 0 3rem;
}
.footer-widget-title {
    font-family: var(--kp-font-heading); font-size: 1rem;
    font-weight: 400; color: var(--kp-color-ink); margin-bottom: 1.2rem;
}
.footer-widget-desc { font-size: .82rem; line-height: 1.8; color: var(--kp-color-ink-xlight); margin-bottom: 1rem; }
.footer-links { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .5rem; }
.footer-links a { font-size: .82rem; color: var(--kp-color-ink-xlight); text-decoration: none; transition: color .2s; }
.footer-links a:hover { color: var(--kp-color-primary); }
.footer-bottom {
    border-top: 1px solid var(--kp-color-border);
    display: flex; justify-content: space-between;
    align-items: center; padding: 1.5rem 0;
}
.footer-bottom p { font-size: .75rem; color: var(--kp-color-ink-xlight); margin: 0; }
.footer-logo-text { font-family: var(--kp-font-heading); font-style: italic; font-size: 1.1rem; color: var(--kp-color-ink); }

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes kpFadeUp   { from { opacity:0; transform:translateY(24px); } to { opacity:1; transform:translateY(0); } }
@keyframes kpFadeLeft { from { opacity:0; transform:translateX(24px); } to { opacity:1; transform:translateX(0); } }

/* ============================================================
   WOOCOMMERCE COMPATIBILITY
   ============================================================ */
.woocommerce-page .kp-container { max-width: var(--kp-max-width); }

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
.screen-reader-text {
    clip: rect(1px,1px,1px,1px); height: 1px; overflow: hidden;
    position: absolute; width: 1px; word-wrap: normal;
}
:focus-visible { outline: 2px solid var(--kp-color-primary); outline-offset: 3px; }
.skip-link { position: absolute; top: -40px; left: 0; background: var(--kp-color-primary); color: #fff; padding: .5rem 1rem; z-index: 9999; transition: top .2s; }
.skip-link:focus { top: 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
    .footer-widgets { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 960px) {
    .header-inner { padding: 0 1.5rem; }
    .primary-navigation { display: none; }
    .primary-navigation.is-open {
        display: flex; flex-direction: column; align-items: flex-start;
        position: fixed; top: 70px; left: 0; right: 0;
        background: var(--kp-color-white);
        border-bottom: 1px solid var(--kp-color-border);
        padding: 1.5rem; gap: 0; z-index: 999;
        box-shadow: var(--kp-shadow);
    }
    .primary-navigation.is-open ul { flex-direction: column; gap: 0; width: 100%; }
    .primary-navigation.is-open a { padding: .75rem 0; border-bottom: 1px solid var(--kp-color-border); display: block; font-size: .95rem; }
    .menu-toggle { display: block; }
    .header-cta { display: none; }
    .hero-inner { grid-template-columns: 1fr; gap: 3rem; padding: 8rem 0 4rem; }
    .hero-card { max-width: 100%; }
    .services-list .service-row { grid-template-columns: 48px 1fr; gap: 1.2rem; }
    .service-tags { display: none; }
    .pricing-grid, .projects-grid { grid-template-columns: 1fr; }
    .results-grid { grid-template-columns: 1fr; }
    .result-card--featured { grid-column: span 1; }
    .leadmag-inner { grid-template-columns: 1fr; gap: 3rem; }
    .process-grid { grid-template-columns: 1fr 1fr; }
    .contact-grid { grid-template-columns: 1fr; gap: 3rem; }
    .blog-layout, .single-post-layout { grid-template-columns: 1fr; }
    .posts-grid { grid-template-columns: 1fr; }
    .project-detail-grid { grid-template-columns: 1fr; }
    .project-detail-sidebar { position: static; }
    .kp-container { padding: 0 1.2rem; }
    .kp-section { padding: 4.5rem 0; }
    .footer-widgets { grid-template-columns: 1fr 1fr; gap: 2rem; padding: 3rem 0 2rem; }
    .footer-bottom { flex-direction: column; gap: .75rem; text-align: center; }
    .form-row { grid-template-columns: 1fr; }
    .post-nav { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
    .hero-actions { flex-direction: column; }
    .hero-actions .kp-btn { text-align: center; }
    .footer-widgets { grid-template-columns: 1fr; }
}
