/* ============================================================
   RAJA AMANULLAH CUSTOM THEME — THEME CSS
   All component styles extracted from inline styles.
   Organised by: Global → Header → Footer → Front Page →
   Services → Portfolio → Blog → About → Contact →
   Single Posts → Archives → Sidebar → Search → 404 →
   Comments → Animations
   ============================================================ */

/* ============================================================
   CSS CUSTOM PROPERTIES (DESIGN TOKENS)
   ============================================================ */
:root {
    --clr-primary:       #1a73e8;
    --clr-primary-dark:  #0d47a1;
    --clr-dark:          #0a1428;
    --clr-body:          #475569;
    --clr-muted:         #64748b;
    --clr-lighter:       #94a3b8;
    --clr-border:        #e2e8f0;
    --clr-bg-light:      #f9fafb;
    --clr-bg-tag:        #f0f4f8;
    --clr-white:         #ffffff;

    /* accent palette used across cards */
    --clr-a1: #1a73e8;
    --clr-a2: #ff6b6b;
    --clr-a3: #10b981;
    --clr-a4: #f59e0b;
    --clr-a5: #8b5cf6;
    --clr-a6: #06b6d4;

    --radius-sm:  6px;
    --radius-md:  8px;
    --radius-lg:  12px;
    --radius-xl:  16px;
    --radius-2xl: 20px;
    --radius-pill: 50px;

    --shadow-xs:  0 2px 10px rgba(0,0,0,.04);
    --shadow-sm:  0 4px 15px rgba(0,0,0,.05);
    --shadow-md:  0 8px 25px rgba(0,0,0,.08);
    --shadow-lg:  0 20px 40px rgba(26,115,232,.15);
    --shadow-xl:  0 25px 50px rgba(26,115,232,.15);

    --transition: all 0.3s ease;
    --transition-bounce: all 0.4s cubic-bezier(0.34,1.56,0.64,1);

    --gradient-primary: linear-gradient(135deg, var(--clr-primary) 0%, var(--clr-primary-dark) 100%);
    --gradient-hero:    linear-gradient(135deg, #ffffff 0%, #f8fafb 100%);
    --gradient-footer:  linear-gradient(135deg, #0a1428 0%, #1a1f35 100%);
}

/* ============================================================
   GLOBAL / UTILITY
   ============================================================ */
.skip-to-content {
    position: absolute;
    top: -100px;
    left: 0;
    background: var(--clr-primary);
    color: #fff;
    padding: .5rem 1rem;
    z-index: 9999;
    border-radius: 0 0 var(--radius-sm) 0;
    transition: top .3s;
}
.skip-to-content:focus { top: 0; }

/* Containers */
.container        { max-width: 1200px; margin: 0 auto; padding: 0 1.25rem; }
.container-narrow { max-width: 900px;  margin: 0 auto; padding: 0 1.25rem; }
.container-wide   { max-width: 1400px; margin: 0 auto; padding: 0 1.25rem; }

/* Sections */
.section-pad   { padding: 6rem 0; }
.section-pad-lg{ padding: 8rem 0; }
.section-pad-sm{ padding: 4rem 0; }

.section-white  { background: var(--clr-white); }
.section-light  { background: var(--clr-bg-light); }
.section-hero   { background: var(--gradient-hero); position: relative; overflow: hidden; }

/* Section header */
.section-header           { text-align: center; margin-bottom: 5rem; }
.section-header .eyebrow  { color: var(--clr-primary); font-weight: 700; font-size: .9rem; text-transform: uppercase; letter-spacing: 2px; display: block; margin-bottom: 1rem; }
.section-header h2        { font-size: 3.5rem; font-weight: 900; color: var(--clr-dark); margin: 0 0 1.5rem; line-height: 1.2; }
.section-header p         { font-size: 1.15rem; color: var(--clr-muted); max-width: 650px; margin: 0 auto; line-height: 1.8; }
.section-header .divider  { width: 60px; height: 4px; background: var(--gradient-primary); margin: 0 auto 1.5rem; border-radius: 2px; }

/* Buttons */
.btn {
    display: inline-block;
    padding: 14px 36px;
    font-weight: 700;
    font-size: 1rem;
    border-radius: var(--radius-md);
    text-decoration: none;
    cursor: pointer;
    transition: var(--transition-bounce);
    border: none;
}
.btn-primary {
    background: var(--gradient-primary);
    color: #fff;
    box-shadow: 0 8px 25px rgba(26,115,232,.25);
    position: relative;
    z-index: 1;
}
.btn-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 35px rgba(26,115,232,.35);
    color: #fff !important;
    background: var(--gradient-primary);
}
/* Ensure text stays on top */
.btn-primary::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: inherit;
    z-index: -1;
    border-radius: inherit;
}
.btn-outline {
    background: #fff;
    color: var(--clr-primary);
    border: 2px solid var(--clr-primary);
}
.btn-outline:hover  { background: var(--clr-primary); color: #fff; transform: translateY(-3px); }
.btn-green {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: #fff;
    box-shadow: 0 8px 20px rgba(16,185,129,.25);
}
.btn-green:hover    { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(16,185,129,.35); }
.btn-white {
    background: #fff;
    color: var(--clr-primary);
    font-weight: 700;
    padding: .75rem 1.5rem;
    border-radius: var(--radius-md);
    text-decoration: none;
    display: inline-block;
    transition: var(--transition);
}
.btn-lg { padding: 16px 48px; font-size: 1.05rem; }
.btn-sm { padding: 8px 20px;  font-size: .9rem; }

/* Tags / Badges */
.badge {
    display: inline-block;
    padding: .4rem .8rem;
    border-radius: 4px;
    font-size: .8rem;
    font-weight: 600;
    text-decoration: none;
}
.badge-primary { background: var(--clr-bg-tag); color: var(--clr-primary); }
.badge-dark    { background: var(--gradient-primary); color: #fff; border-radius: 20px; font-size: .8rem; font-weight: 700; text-transform: uppercase; padding: .5rem 1.2rem; }
.badge-tech    { background: #e8f4ff; color: var(--clr-primary-dark); padding: .3rem .6rem; border-radius: 3px; font-size: .75rem; font-weight: 600; }
.badge-tag-pill{ background: #fff; color: var(--clr-primary); padding: .35rem .75rem; border-radius: 4px; font-size: .8rem; text-decoration: none; border: 1px solid var(--clr-border); display: inline-block; transition: var(--transition); }
.badge-tag-pill:hover { background: var(--clr-primary); color: #fff; border-color: var(--clr-primary); }

/* Status badge (hero "Available" style) */
.status-badge {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    background: rgba(26,115,232,.08);
    padding: .75rem 1.5rem;
    border-radius: var(--radius-pill);
    border: 1px solid rgba(26,115,232,.2);
    margin-bottom: 2rem;
}
.status-badge .dot {
    width: 8px; height: 8px;
    background: var(--clr-primary);
    border-radius: 50%;
    animation: pulse 2s ease-in-out infinite;
}
.status-badge span { color: var(--clr-primary); font-weight: 600; font-size: .85rem; text-transform: uppercase; letter-spacing: 1px; }

/* Error status badge */
.status-badge-error {
    background: rgba(239,68,68,.08);
    border-color: rgba(239,68,68,.2);
}
.status-badge-error .dot { background: #ef4444; }
.status-badge-error span { color: #ef4444; }

/* Pagination */
.nav-links, .page-numbers { display: flex; justify-content: center; gap: .5rem; margin-top: 3rem; flex-wrap: wrap; }
.page-numbers { list-style: none; padding: 0; }
.page-numbers li a,
.page-numbers li span,
.nav-links a,
.nav-links span {
    display: inline-block;
    padding: .5rem .9rem;
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: .9rem;
    text-decoration: none;
    color: var(--clr-body);
    border: 1px solid var(--clr-border);
    transition: var(--transition);
}
.page-numbers li .current,
.page-numbers li a:hover,
.nav-links a:hover { background: var(--clr-primary); color: #fff; border-color: var(--clr-primary); }

/* CTA centered block */
.cta-block { text-align: center; }
.cta-block h2 { font-size: 3rem; font-weight: 900; margin-bottom: 1.5rem; color: var(--clr-dark); }
.cta-block p  { font-size: 1.15rem; color: var(--clr-muted); margin-bottom: 2.5rem; line-height: 1.8; }

/* ============================================================
   DECORATIVE BACKGROUND BLOBS
   ============================================================ */
.blob { position: absolute; border-radius: 50%; filter: blur(80px); pointer-events: none; }
.blob-blue-tr  { top: 10%; right: -10%; width: 400px; height: 400px; background: rgba(26,115,232,.08); }
.blob-blue-bl  { bottom: -20%; left: -5%; width: 300px; height: 300px; background: rgba(26,115,232,.05); }
.blob-red-bl   { bottom: -20%; left: -5%; width: 300px; height: 300px; background: rgba(255,107,107,.05); }
.blob-tl       { top: -100px; right: -100px; width: 300px; height: 300px; background: rgba(26,115,232,.05); }
.blob-br       { bottom: -50px; left: -50px; width: 250px; height: 250px; background: rgba(16,185,129,.05); }
.blob-stats    { top: -50%; right: -20%; width: 500px; height: 500px; background: rgba(255,255,255,.05); }

/* ============================================================
   HERO SECTION — GEOMETRIC SHAPES
   ============================================================ */
.hero-shape {
    position: absolute;
    opacity: .11;
    pointer-events: none;
}
.shape-sq-blue  { top: 10%; left: 5%;   width: 120px; height: 120px; background: var(--gradient-primary); animation: rotateShape 20s linear infinite; }
.shape-ci-red   { top: 15%; right: 10%; width: 180px; height: 180px; background: linear-gradient(135deg,#ff6b6b,#ff5252); border-radius: 50%; animation: floatShape 15s ease-in-out infinite; opacity: .10; }
.shape-pe-green { bottom: 15%; left: 8%; width: 150px; height: 150px; background: linear-gradient(135deg,#10b981,#059669); clip-path: polygon(50% 0%,100% 38%,82% 100%,18% 100%,0% 38%); animation: floatShapeReverse 18s ease-in-out infinite; }
.shape-sq-orange{ bottom: 20%; right: 5%; width: 200px; height: 200px; background: linear-gradient(135deg,#f59e0b,#f97316); animation: rotateShapeReverse 25s linear infinite; opacity: .09; }
.shape-ci-purple{ top: 40%; left: 15%; width: 100px; height: 100px; background: linear-gradient(135deg,#8b5cf6,#7c3aed); border-radius: 50%; animation: pulseShape 12s ease-in-out infinite; opacity: .12; }
.shape-tr-cyan  { top: 30%; right: 15%; width: 140px; height: 140px; background: linear-gradient(135deg,#06b6d4,#0891b2); clip-path: polygon(50% 0%,0% 100%,100% 100%); animation: floatShape 20s ease-in-out infinite 2s; }
.shape-tr-pink  { bottom: 30%; right: 20%; width: 110px; height: 110px; background: linear-gradient(135deg,#ec4899,#db2777); clip-path: polygon(50% 0%,0% 100%,100% 100%); animation: rotateShape 22s linear infinite 1s; opacity: .10; }
.shape-tr-blue  { top: 55%; left: 12%; width: 95px; height: 95px; background: var(--gradient-primary); clip-path: polygon(50% 0%,0% 100%,100% 100%); animation: floatShape 22s ease-in-out infinite 1.5s; opacity: .10; }
.hero-grid-overlay {
    position: absolute; inset: 0; pointer-events: none; opacity: .5;
    background-image:
        linear-gradient(0deg, transparent 24%, rgba(26,115,232,.03) 25%, rgba(26,115,232,.03) 26%, transparent 27%, transparent 74%, rgba(26,115,232,.03) 75%, rgba(26,115,232,.03) 76%, transparent 77%, transparent),
        linear-gradient(90deg, transparent 24%, rgba(26,115,232,.03) 25%, rgba(26,115,232,.03) 26%, transparent 27%, transparent 74%, rgba(26,115,232,.03) 75%, rgba(26,115,232,.03) 76%, transparent 77%, transparent);
    background-size: 100px 100px;
}

/* Small decorative shapes on service pages */
.deco-sq { position: absolute; top: 10%; left: 5%;   width: 120px; height: 120px; background: var(--gradient-primary); opacity: .12; pointer-events: none; }
.deco-ci { position: absolute; top: 15%; right: 10%; width: 180px; height: 180px; background: linear-gradient(135deg,#10b981,#059669); border-radius: 50%; opacity: .10; pointer-events: none; }
.deco-pe { position: absolute; bottom: 15%; left: 8%; width: 150px; height: 150px; background: linear-gradient(135deg,#f59e0b,#f97316); clip-path: polygon(50% 0%,100% 38%,82% 100%,18% 100%,0% 38%); opacity: .11; pointer-events: none; }

/* ============================================================
   SITE HEADER
   ============================================================ */
.site-header {
    background: var(--clr-white);
    border-bottom: 1px solid var(--clr-border);
    position: sticky;
    top: 0;
    z-index: 100;
    box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
.header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 0;
    overflow: visible;
}

/* Logo */
.site-branding img { max-width: 100%; height: auto; max-height: 60px; }
.logo-text { font-size: 1.5rem; font-weight: 900; color: var(--clr-dark); text-decoration: none; }

/* Desktop nav */
.desktop-nav { display: flex !important; overflow: visible; }
.mobile-nav  { display: none !important; }

/* Top-level menu: flex row */
.nav-menu {
    display: flex;
    list-style: none;
    gap: 2rem;
    margin: 0;
    padding: 0;
    overflow: visible;
}
.nav-menu > li > a {
    color: var(--clr-body);
    text-decoration: none;
    font-weight: 500;
    transition: color .3s ease;
    position: relative;
    display: block;
}
.nav-menu > li > a:hover { color: var(--clr-primary); }
.nav-menu > li > a::after {
    content: '';
    position: absolute;
    bottom: -5px; left: 0;
    width: 0; height: 2px;
    background: var(--clr-primary);
    transition: width .3s ease;
}
.nav-menu > li > a:hover::after { width: 100%; }

/* Every li needs position:relative for absolute dropdown */
.nav-menu li { position: relative; }

/* Dropdown submenu — reset display to block (not flex) */
.nav-menu ul {
    display: block;          /* override any inherited flex */
    list-style: none;
    margin: 0;
    padding: 0;
    position: absolute;
    top: calc(100% + .5rem);
    left: 0;
    background: #fff;
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-md);
    min-width: 200px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: var(--transition);
    z-index: 9999;
    box-shadow: 0 8px 20px rgba(0,0,0,.1);
}
.nav-menu li:hover > ul { opacity: 1; visibility: visible; transform: translateY(0); }

/* Dropdown items */
.nav-menu ul li {
    display: block;          /* ensure each item is block, not flex item */
    padding: 0;
    margin: 0;
    border: none;
}
.nav-menu ul li a {
    display: block;
    padding: 12px 20px;
    color: var(--clr-body);
    text-decoration: none;
    font-weight: 500;
    font-size: .95rem;
    transition: var(--transition);
    white-space: nowrap;
    width: 100%;
}
.nav-menu ul li:first-child a { border-radius: 8px 8px 0 0; }
.nav-menu ul li:last-child  a { border-radius: 0 0 8px 8px; }
.nav-menu ul li a:hover     { background: #f0f0f0; color: var(--clr-primary); padding-left: 24px; }
.nav-menu ul li a::after    { content: none !important; }

/* Header CTA */
.header-cta a {
    background: var(--gradient-primary);
    color: #fff;
    padding: 12px 28px;
    border-radius: var(--radius-sm);
    text-decoration: none;
    font-weight: 600;
    font-size: .95rem;
    transition: var(--transition);
}
.header-cta a:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(26,115,232,.3); }

/* Mobile toggle */
.mobile-menu-toggle {
    display: none !important;
    background: none; border: none; cursor: pointer; padding: .5rem; z-index: 101;
}
.hamburger-line { display: block; width: 24px; height: 2px; background: var(--clr-dark); margin: 6px 0; transition: var(--transition); }

/* ============================================================
   SITE FOOTER
   ============================================================ */
.site-footer-modern {
    background: var(--gradient-footer);
    color: #fff;
    padding-top: 4rem;
    padding-bottom: 0;
}
.footer-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 3rem;
    padding: 3rem 0;
    margin-bottom: 3rem;
}
.footer-about h3 { font-size: 1.4rem; font-weight: 900; margin: 0 0 1rem; color: #fff; }
.footer-about .divider-blue { width: 50px; height: 4px; background: var(--gradient-primary); border-radius: 2px; margin-bottom: 1.5rem; }
.footer-about p  { font-size: .95rem; line-height: 1.6; color: #b0b8c8; margin-bottom: 1.5rem; }

/* Social links */
.footer-social { display: flex; gap: 1rem; margin-top: 1.5rem; }
.footer-social a {
    display: inline-flex; align-items: center; justify-content: center;
    width: 40px; height: 40px;
    background: rgba(26,115,232,.15);
    color: var(--clr-primary);
    border-radius: 50%;
    transition: var(--transition);
    text-decoration: none;
    font-weight: bold;
}
.footer-social a:hover { background: var(--clr-primary); color: #fff; transform: translateY(-3px); }

/* Footer columns */
.footer-col h4 { font-size: 1.1rem; font-weight: 800; margin-bottom: 1.5rem; color: #fff; }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col ul li { margin-bottom: .75rem; }
.footer-col ul li a {
    color: #b0b8c8; text-decoration: none; font-size: .95rem;
    transition: var(--transition);
    display: flex; align-items: center; gap: .5rem;
}
.footer-col ul li a .arrow { color: var(--clr-primary); }
.footer-col ul li a:hover  { color: #6bbfff; transform: translateX(2px); }

/* Footer contact */
.footer-contact-label { font-size: .85rem; color: #64748b; text-transform: uppercase; margin-bottom: .5rem; font-weight: 600; }
.footer-contact a { color: var(--clr-primary); text-decoration: none; font-weight: 600; font-size: .95rem; display: block; margin-bottom: 1.5rem; }

.footer-divider { border-top: 1px solid rgba(255,255,255,.1); }

/* Footer bottom */
.footer-bottom { background: rgba(0,0,0,.3); padding: 2rem 0; }
.footer-bottom-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 2rem; }
.footer-copy { margin: 0; color: #8892a0; font-size: .9rem; }
.footer-links { display: flex; gap: 2rem; flex-wrap: wrap; }
.footer-links a { color: #8892a0; text-decoration: none; font-size: .9rem; transition: var(--transition); }
.footer-links a:hover { color: #6bbfff; }

/* ============================================================
   HERO SECTION (FRONT PAGE)
   ============================================================ */
.hero-advanced {
    background: var(--gradient-hero);
    color: var(--clr-dark);
    padding: 120px 0;
    position: relative;
    overflow: hidden;
    min-height: 100vh;
    display: flex;
    align-items: center;
}
.hero-inner { position: relative; z-index: 2; }
.hero-row { display: grid; grid-template-columns: 55% 45%; gap: 4rem; align-items: center; margin-bottom: 4rem; }
.hero-content { animation: slideInLeft 1.2s cubic-bezier(0.34,1.56,0.64,1); }
.hero-badge {
    display: inline-flex; align-items: center; gap: .75rem;
    background: rgba(26,115,232,.08);
    padding: .75rem 1.5rem;
    border-radius: var(--radius-pill);
    margin-bottom: 2rem;
    border: 1px solid rgba(26,115,232,.2);
    animation: slideUp 1s ease-out .2s backwards;
}
.hero-badge .dot { display: inline-block; width: 8px; height: 8px; background: var(--clr-primary); border-radius: 50%; animation: pulse 2s ease-in-out infinite; }
.hero-badge .label { color: var(--clr-primary); font-weight: 600; font-size: .85rem; text-transform: uppercase; letter-spacing: 1px; }
.hero-title {
    font-size: 4rem; font-weight: 900; line-height: 1.15; margin-bottom: 1.5rem;
    animation: slideUp 1s ease-out .3s backwards;
    background: linear-gradient(135deg, var(--clr-dark) 0%, var(--clr-primary) 100%);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-sub {
    font-size: 1.3rem; line-height: 1.8; color: var(--clr-body); margin-bottom: 2.5rem;
    animation: slideUp 1s ease-out .4s backwards;
}
.hero-cta { display: flex; gap: 1.5rem; animation: slideUp 1s ease-out .5s backwards; flex-wrap: wrap; }
.hero-image-wrap { position: relative; animation: slideInRight 1.2s cubic-bezier(0.34,1.56,0.64,1); display: flex; justify-content: center; align-items: center; }
.hero-image-inner { width: 100%; animation: floatSlow 6s ease-in-out infinite; }
.hero-image-inner img { width: 100%; height: auto; display: block; filter: drop-shadow(0 20px 50px rgba(0,0,0,.15)); }

/* Hero stats bar */
.hero-stats {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 3.5rem;
    padding-top: 3rem;
    margin-top: 3rem;
    border-top: 1px solid rgba(26,115,232,.1);
    animation: slideUp 1s ease-out .6s backwards;
}
.hero-stat-number { font-size: 2.2rem; font-weight: 900; color: var(--clr-primary); margin-bottom: .5rem; }
.hero-stat-label  { color: var(--clr-muted); margin: 0; font-size: .9rem; }

/* ============================================================
   PAGE HERO (INNER PAGES)
   ============================================================ */
.page-hero { padding: 6rem 0; position: relative; overflow: hidden; }
.page-hero-center { text-align: center; max-width: 800px; margin: 0 auto; }
.page-hero-center h1 { font-size: 3.5rem; font-weight: 900; margin-bottom: 1.5rem; color: var(--clr-dark); line-height: 1.2; }
.page-hero-center p  { font-size: 1.25rem; color: var(--clr-muted); margin: 0; line-height: 1.8; }
.page-hero-count { margin-top: 1.5rem; color: var(--clr-primary); font-weight: 600; }

/* ============================================================
   CARD — SHARED CARD BASE
   ============================================================ */
.card-base {
    background: var(--clr-white);
    border-radius: var(--radius-xl);
    overflow: hidden;
    border: 1px solid var(--clr-border);
    box-shadow: var(--shadow-sm);
    transition: var(--transition-bounce);
}
.card-base:hover { transform: translateY(-10px); box-shadow: var(--shadow-xl); border-color: var(--clr-primary); }
.card-base:hover img { transform: scale(1.06); }

/* ============================================================
   SERVICE CARDS (FRONT PAGE & ARCHIVE)
   ============================================================ */
.services-grid  { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px,1fr)); gap: 2.5rem; }
.service-card   { background: #fff; border-radius: var(--radius-xl); overflow: hidden; position: relative; cursor: pointer; transition: var(--transition-bounce); box-shadow: var(--shadow-sm); height: 100%; display: flex; flex-direction: column; }
.service-card:hover { transform: translateY(-12px); box-shadow: var(--shadow-xl); }
.service-card-image { position: relative; height: 250px; overflow: hidden; background: #f0f0f0; }
.service-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.service-card:hover .service-card-image img { transform: scale(1.06); }
.service-card-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: #fff; }
.service-icon-badge {
    position: absolute; bottom: 15px; left: 15px;
    width: 64px; height: 64px;
    border-radius: var(--radius-lg);
    display: flex; align-items: center; justify-content: center;
    color: #fff; box-shadow: 0 8px 20px rgba(0,0,0,.15);
    border: 3px solid #fff;
}
.service-icon-badge svg {
    display: block;
    flex-shrink: 0;
}
.service-card-body { padding: 2rem; flex: 1; display: flex; flex-direction: column; }
.service-card-body h3 { font-size: 1.3rem; margin-bottom: 1rem; color: var(--clr-dark); font-weight: 800; margin-top: 0; }
.service-card-body p  { color: var(--clr-muted); margin-bottom: 1.5rem; line-height: 1.7; font-size: .95rem; flex: 1; }
.service-card-link    { font-weight: 700; text-decoration: none; display: inline-flex; align-items: center; gap: .6rem; }

/* Services archive grid (3 col) */
.services-archive-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2.5rem; }

/* ============================================================
   PORTFOLIO CARDS
   ============================================================ */
.portfolio-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px,1fr)); gap: 2.5rem; }
.portfolio-card {
    background: #fff; border-radius: var(--radius-xl); overflow: hidden;
    box-shadow: var(--shadow-sm); transition: var(--transition-bounce);
    height: 100%; display: flex; flex-direction: column;
    padding-top: 6px; /* colored top border applied inline per card */
}
.portfolio-card:hover { transform: translateY(-12px); box-shadow: var(--shadow-xl); }
.portfolio-card-image { position: relative; overflow: hidden; background: var(--clr-border); aspect-ratio: 16/9; }
.portfolio-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.portfolio-card:hover .portfolio-card-image img { transform: scale(1.08); }
.portfolio-card-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.3) 100%); }
.portfolio-card-body { padding: 2.5rem; flex: 1; display: flex; flex-direction: column; }
.portfolio-card-category { font-size: .85rem; font-weight: 600; text-transform: uppercase; }
.portfolio-card-body h3  { font-size: 1.3rem; margin: 1rem 0; color: var(--clr-dark); font-weight: 800; }
.portfolio-card-body p   { color: var(--clr-muted); margin-bottom: 1.5rem; line-height: 1.6; font-size: .95rem; flex: 1; }
.portfolio-card-techs    { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.portfolio-card-link     { font-weight: 700; text-decoration: none; display: inline-flex; align-items: center; gap: .5rem; }

/* Portfolio page 3-col grid */
.portfolio-page-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2.5rem; }

/* ============================================================
   BLOG / POST CARDS
   ============================================================ */
.blog-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px,1fr)); gap: 2.5rem; margin-bottom: 3rem; }
.blog-card {
    background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius-xl); overflow: hidden;
    cursor: pointer; transition: var(--transition-bounce);
    box-shadow: var(--shadow-sm); height: 100%; display: flex; flex-direction: column;
}
.blog-card:hover { transform: translateY(-10px); box-shadow: var(--shadow-xl); border-color: var(--clr-primary); }
.blog-card:hover img { transform: scale(1.06); }
.blog-card-image { position: relative; height: 200px; overflow: hidden; background: #f0f0f0; }
.blog-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.blog-card-category-badge {
    position: absolute; top: 12px; right: 12px;
    color: #fff; padding: .5rem 1rem; border-radius: 20px;
    font-size: .75rem; font-weight: 700; text-transform: uppercase;
}
.blog-card-body     { padding: 2rem; flex: 1; display: flex; flex-direction: column; }
.blog-card-meta     { display: flex; gap: 1rem; margin-bottom: 1rem; font-size: .85rem; color: var(--clr-muted); }
.blog-card-title    { font-size: 1.2rem; margin-bottom: .75rem; color: var(--clr-dark); font-weight: 800; margin-top: 0; line-height: 1.4; }
.blog-card-excerpt  { color: var(--clr-muted); margin-bottom: 1.5rem; line-height: 1.6; font-size: .95rem; flex: 1; }
.blog-card-footer   { display: flex; justify-content: space-between; align-items: center; padding-top: 1rem; border-top: 1px solid var(--clr-border); color: var(--clr-muted); font-size: .85rem; }
.blog-card-read     { color: var(--clr-primary); font-weight: 700; text-decoration: none; transition: var(--transition); }

/* Search result cards */
.search-result-card { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius-lg); overflow: hidden; transition: var(--transition); box-shadow: var(--shadow-xs); }
.search-result-card:hover { transform: translateY(-4px); box-shadow: 0 12px 30px rgba(26,115,232,.12); border-color: var(--clr-primary); }
.search-result-inner { display: flex; gap: 1.25rem; padding: 1.5rem; align-items: flex-start; }
.search-result-thumb { flex-shrink: 0; width: 90px; height: 90px; border-radius: var(--radius-md); overflow: hidden; background: var(--clr-border); }
.search-result-thumb img { width: 100%; height: 100%; object-fit: cover; }
.search-result-thumb-placeholder { width: 100%; height: 100%; background: var(--gradient-primary); display: flex; align-items: center; justify-content: center; }
.search-result-content  { flex: 1; min-width: 0; }
.search-result-title    { font-size: 1rem; font-weight: 800; color: var(--clr-dark); margin: 0 0 .5rem; line-height: 1.4; }
.search-result-title a  { color: inherit; text-decoration: none; transition: var(--transition); }
.search-result-title a:hover { color: var(--clr-primary); }
.search-result-excerpt  { color: var(--clr-muted); font-size: .85rem; margin: 0 0 .75rem; line-height: 1.6; }
.search-result-footer   { display: flex; align-items: center; justify-content: space-between; }
.search-result-date     { color: var(--clr-lighter); font-size: .78rem; }
.search-result-grid     { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }

/* ============================================================
   FEATURES SECTION
   ============================================================ */
.features-grid  { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: 2.5rem; }
.feature-card   { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius-xl); overflow: hidden; transition: var(--transition); box-shadow: var(--shadow-xs); }
.feature-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--clr-primary); }
.feature-card-icon  { display: flex; align-items: center; justify-content: center; padding: 2rem 2rem 0; }
.feature-card-body  { padding: 1.5rem 2rem 2rem; text-align: center; }
.feature-card-body h3 { font-size: 1.3rem; margin-bottom: 1rem; color: var(--clr-dark); font-weight: 800; margin-top: 0; }
.feature-card-body p  { color: var(--clr-muted); margin: 0; line-height: 1.6; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px,1fr)); gap: 2.5rem; }
.testimonial-card {
    background: #fff; border-radius: var(--radius-2xl); overflow: hidden;
    transition: var(--transition-bounce); box-shadow: var(--shadow-md);
    position: relative; display: flex; flex-direction: column; height: 100%;
}
.testimonial-card:hover { transform: translateY(-8px); box-shadow: var(--shadow-xl); }
.testimonial-top-bar { height: 4px; }
.testimonial-body    { padding: 2.5rem; display: flex; flex-direction: column; height: 100%; }
.testimonial-stars   { display: flex; gap: .25rem; }
.testimonial-rating-row { margin-bottom: 1.5rem; display: flex; align-items: center; gap: .75rem; }
.testimonial-rating-num { font-weight: 700; color: var(--clr-dark); font-size: .9rem; }
.testimonial-quote   { font-size: 1rem; line-height: 1.8; margin-bottom: 2rem; color: var(--clr-body); font-style: italic; flex-grow: 1; position: relative; }
.testimonial-quote .open-quote { position: absolute; left: -.5rem; top: -1rem; font-size: 3rem; opacity: .15; }
.testimonial-client  { border-top: 1px solid var(--clr-border); padding-top: 1.5rem; display: flex; align-items: center; gap: 1.2rem; }
.testimonial-avatar  { width: 56px; height: 56px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 2rem; flex-shrink: 0; }
.testimonial-name    { font-weight: 700; margin: 0; color: var(--clr-dark); font-size: .95rem; }
.testimonial-role    { margin: .25rem 0 0; font-size: .85rem; font-weight: 600; }
.testimonial-company { color: var(--clr-muted); margin: .25rem 0 0; font-size: .8rem; }
.testimonials-bg     { position: relative; overflow: hidden; }

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-split { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; margin-bottom: 5rem; }
.about-split.animate { animation: slideInLeft 1s ease-out; }
.about-image-placeholder { background: linear-gradient(135deg, #f0f4f8 0%, #e8eef5 100%); border-radius: var(--radius-2xl); aspect-ratio: 1; display: flex; align-items: center; justify-content: center; font-size: 100px; }
.about-image-placeholder.animate { animation: slideInRight 1s ease-out; }

.skills-grid  { display: grid; grid-template-columns: repeat(2,1fr); gap: 3rem; margin-bottom: 4rem; }
.skill-card   { background: #fff; padding: 2.5rem; border-radius: var(--radius-xl); border: 1px solid var(--clr-border); box-shadow: var(--shadow-sm); }
.skill-card h3 { font-size: 1.3rem; font-weight: 800; margin-bottom: 1rem; color: var(--clr-dark); }
.skill-card p  { color: var(--clr-muted); line-height: 1.7; margin-bottom: 1.5rem; }
.skill-tags    { display: flex; gap: .75rem; flex-wrap: wrap; }
.skill-tag     { background: var(--clr-bg-tag); color: var(--clr-primary); padding: .5rem 1rem; border-radius: 20px; font-size: .85rem; font-weight: 600; }

/* Timeline */
.timeline-item      { display: grid; grid-template-columns: 1fr 2rem 1fr; gap: 2rem; margin-bottom: 3rem; align-items: center; }
.timeline-item:last-child { margin-bottom: 0; }
.timeline-right     { text-align: right; padding-right: 1rem; }
.timeline-left      { padding-left: 1rem; }
.timeline-dot       { width: 2rem; height: 2rem; background: var(--clr-primary); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.timeline-dot-inner { width: .75rem; height: .75rem; background: #fff; border-radius: 50%; }
.timeline-item h3   { font-size: 1.3rem; font-weight: 800; color: var(--clr-dark); margin-bottom: .5rem; }
.timeline-item p    { color: var(--clr-muted); margin: 0; }

/* Stats blue bar */
.stats-bar { padding: 6rem 0; background: var(--gradient-primary); color: #fff; position: relative; overflow: hidden; }
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 2rem; text-align: center; position: relative; z-index: 2; }
.stat-item h3  { font-size: 3rem; font-weight: 900; margin-bottom: .5rem; }
.stat-item p   { font-size: 1.1rem; opacity: .9; margin: 0; }

/* Philosophy cards */
.philosophy-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2.5rem; }
.philosophy-card { background: var(--clr-bg-light); padding: 2.5rem; border-radius: var(--radius-xl); border: 1px solid var(--clr-border); text-align: center; }
.philosophy-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.philosophy-icon { font-size: 3rem; margin-bottom: 1.5rem; }
.philosophy-card h3 { font-size: 1.3rem; font-weight: 800; margin-bottom: 1rem; color: var(--clr-dark); }
.philosophy-card p  { color: var(--clr-muted); line-height: 1.7; margin: 0; }

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-grid  { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; }
.contact-form-wrap { animation: slideInLeft 1s ease-out; }
.contact-form-wrap h2 { font-size: 2rem; font-weight: 900; margin-bottom: 2rem; color: var(--clr-dark); }
.contact-info-wrap  { animation: slideInRight 1s ease-out; }
.contact-info-wrap h2 { font-size: 2rem; font-weight: 900; margin-bottom: 2rem; color: var(--clr-dark); }

/* Contact info cards */
.contact-card         { padding: 2rem; border-radius: var(--radius-lg); margin-bottom: 2rem; }
.contact-card-blue    { background: var(--clr-bg-light); border-left: 4px solid var(--clr-primary); }
.contact-card-green   { background: var(--clr-bg-light); border-left: 4px solid #10b981; }
.contact-card-primary { background: var(--gradient-primary); color: #fff; }
.contact-card-social  { background: var(--clr-bg-light); }
.contact-card-label   { font-size: .85rem; color: var(--clr-muted); text-transform: uppercase; margin: 0 0 .75rem; font-weight: 600; }
.contact-card-primary .contact-card-label { color: rgba(255,255,255,.8); }
.contact-card-value   { color: var(--clr-primary); text-decoration: none; font-weight: 600; font-size: 1.1rem; display: inline-block; transition: var(--transition); }
.contact-card-value-green { color: #10b981; }
.contact-card-sub     { margin: .75rem 0 0; color: var(--clr-muted); font-size: .9rem; }
.contact-card-avail h3 { margin: 0; font-size: 1.3rem; font-weight: 800; margin-bottom: .75rem; color: #fff; }
.contact-card-avail p  { margin: 0; line-height: 1.6; color: rgba(255,255,255,.9); }

/* Social icons row (contact page) */
.social-icons-row { display: flex; gap: 1rem; }
.social-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 45px; height: 45px;
    background: #fff; color: var(--clr-primary);
    border-radius: var(--radius-md); transition: var(--transition); text-decoration: none;
    font-weight: bold; border: 2px solid transparent;
}
.social-icon:hover { background: var(--clr-primary); color: #fff; border-color: var(--clr-primary); transform: translateY(-3px); }

/* Contact form fields */
.cf-form  { display: flex; flex-direction: column; gap: 1.5rem; }
.cf-label { display: block; margin-bottom: .5rem; font-weight: 600; color: var(--clr-dark); }
.cf-input,
.cf-textarea,
.cf-select {
    width: 100%; padding: 14px; border: 1px solid var(--clr-border);
    border-radius: var(--radius-md); font-size: 1rem;
    transition: var(--transition); font-family: inherit;
}
.cf-input:focus,
.cf-textarea:focus,
.cf-select:focus {
    outline: none;
    border-color: var(--clr-primary);
    box-shadow: 0 0 0 3px rgba(26,115,232,.1);
}
.cf-textarea { resize: vertical; }
.cf-grid-2   { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.cf-submit   { width: 100%; padding: 14px; font-size: 1.05rem; font-weight: 700; cursor: pointer; border: none; }

/* WPForms styling in Contact sections (match cf-* theme fields) */
.contact-form-wrap .wpforms-container {
    margin: 0;
}
.contact-form-wrap .wpforms-container .wpforms-form {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}
.contact-form-wrap .wpforms-container .wpforms-field {
    padding: 0;
}
.contact-form-wrap .wpforms-container .wpforms-field-label {
    display: block;
    margin-bottom: .5rem;
    font-weight: 600;
    color: var(--clr-dark);
}
.contact-form-wrap .wpforms-container input[type="text"],
.contact-form-wrap .wpforms-container input[type="email"],
.contact-form-wrap .wpforms-container input[type="url"],
.contact-form-wrap .wpforms-container input[type="tel"],
.contact-form-wrap .wpforms-container input[type="number"],
.contact-form-wrap .wpforms-container textarea,
.contact-form-wrap .wpforms-container select {
    width: 100% !important;
    max-width: 100% !important;
    padding: 14px !important;
    border: 1px solid var(--clr-border) !important;
    border-radius: var(--radius-md) !important;
    font-size: 1rem !important;
    color: var(--clr-dark) !important;
    background: var(--clr-white) !important;
    transition: var(--transition) !important;
    font-family: inherit !important;
}
.contact-form-wrap .wpforms-container textarea {
    min-height: 140px;
    resize: vertical;
}
.contact-form-wrap .wpforms-container input::placeholder,
.contact-form-wrap .wpforms-container textarea::placeholder {
    color: var(--clr-lighter);
}
.contact-form-wrap .wpforms-container input:focus,
.contact-form-wrap .wpforms-container textarea:focus,
.contact-form-wrap .wpforms-container select:focus {
    outline: none !important;
    border-color: var(--clr-primary) !important;
    box-shadow: 0 0 0 3px rgba(26,115,232,.1) !important;
}
.contact-form-wrap .wpforms-container .wpforms-field-required {
    color: #ef4444;
}
.contact-form-wrap .wpforms-container .wpforms-field-description {
    color: var(--clr-muted);
    font-size: .85rem;
    margin-top: .4rem;
}
.contact-form-wrap .wpforms-container .wpforms-field-name .wpforms-field-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin: 0 !important;
}
.contact-form-wrap .wpforms-container .wpforms-field-name .wpforms-field-row-block {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}
.contact-form-wrap .wpforms-container .wpforms-field-name .wpforms-field-row-block input {
    margin-bottom: .35rem !important;
}
.contact-form-wrap .wpforms-container .wpforms-field-name .wpforms-field-sublabel {
    display: block;
    margin: 0;
    font-size: .9rem;
    font-weight: 500;
    color: var(--clr-body);
    line-height: 1.4;
}
.contact-form-wrap .wpforms-container .wpforms-error {
    border-color: #ef4444 !important;
}
.contact-form-wrap .wpforms-container label.wpforms-error {
    margin-top: .45rem;
    font-size: .85rem !important;
    color: #ef4444 !important;
}
.contact-form-wrap .wpforms-container .wpforms-submit-container {
    padding: 0;
}
.contact-form-wrap .wpforms-container .wpforms-submit {
    width: 100% !important;
    padding: 14px !important;
    border: none !important;
    border-radius: var(--radius-md) !important;
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    background: var(--gradient-primary) !important;
    color: #fff !important;
    box-shadow: 0 8px 25px rgba(26,115,232,.25) !important;
    transition: var(--transition-bounce) !important;
}
.contact-form-wrap .wpforms-container .wpforms-submit:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 35px rgba(26,115,232,.35) !important;
}
.contact-form-wrap .wpforms-container .wpforms-submit:disabled {
    opacity: .75;
    transform: none;
}

/* FAQ grid */
.faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; }
.faq-card { background: #fff; padding: 2rem; border-radius: var(--radius-lg); border: 1px solid var(--clr-border); }
.faq-card h3 { font-size: 1.1rem; font-weight: 800; color: var(--clr-dark); margin-bottom: .75rem; }
.faq-card p  { color: var(--clr-muted); line-height: 1.7; margin: 0; }

/* ============================================================
   SINGLE SERVICE PAGE
   ============================================================ */
.single-service-hero { background: var(--gradient-hero); padding: 3rem 0; position: relative; overflow: hidden; }
.single-service-hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; position: relative; z-index: 2; }
.single-service-title { animation: slideInLeft 1s ease-out; }
.single-service-title h1  { font-size: 3.2rem; font-weight: 900; margin-bottom: 1rem; color: var(--clr-dark); line-height: 1.2; }
.single-service-title p   { font-size: 1.15rem; color: var(--clr-body); margin-bottom: 1.5rem; line-height: 1.8; }
.single-service-form-wrap { animation: slideInRight 1s ease-out; }

/* Proposal form card */
.proposal-form-card { background: #fff; color: var(--clr-dark); padding: 2rem; border-radius: var(--radius-xl); box-shadow: 0 20px 60px rgba(0,0,0,.1); }
.proposal-form-card h2 { font-size: 1.5rem; font-weight: 900; margin-bottom: 1.5rem; text-align: center; color: var(--clr-dark); }
.pf-form { display: flex; flex-direction: column; gap: 1rem; }
.pf-label { display: block; font-weight: 600; margin-bottom: .4rem; color: var(--clr-dark); font-size: .9rem; }
.pf-input, .pf-textarea, .pf-select {
    width: 100%; padding: 10px; border: 1px solid var(--clr-border);
    border-radius: var(--radius-sm); font-size: .95rem; font-family: inherit; transition: var(--transition);
}
.pf-input:focus, .pf-textarea:focus, .pf-select:focus {
    outline: none; border-color: var(--clr-primary);
    box-shadow: 0 0 0 3px rgba(26,115,232,.1);
}
.pf-grid-2    { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.pf-textarea  { resize: vertical; }
.pf-submit    { width: 100%; padding: 12px; border: none; border-radius: var(--radius-sm); font-size: .95rem; font-weight: 700; cursor: pointer; margin-top: .5rem; }

/* WPForms in single service estimate card */
.single-service-form-wrap .wpforms-container {
    margin: 0;
}
.single-service-form-wrap .wpforms-container .wpforms-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.single-service-form-wrap .wpforms-container .wpforms-field {
    padding: 0;
}
.single-service-form-wrap .wpforms-container .wpforms-field-label {
    display: block;
    font-weight: 600;
    margin-bottom: .4rem;
    color: var(--clr-dark);
    font-size: .9rem;
}
.single-service-form-wrap .wpforms-container input[type="text"],
.single-service-form-wrap .wpforms-container input[type="email"],
.single-service-form-wrap .wpforms-container input[type="url"],
.single-service-form-wrap .wpforms-container input[type="tel"],
.single-service-form-wrap .wpforms-container input[type="number"],
.single-service-form-wrap .wpforms-container textarea,
.single-service-form-wrap .wpforms-container select {
    width: 100% !important;
    max-width: 100% !important;
    padding: 10px !important;
    border: 1px solid var(--clr-border) !important;
    border-radius: var(--radius-sm) !important;
    font-size: .95rem !important;
    color: var(--clr-dark) !important;
    background: var(--clr-white) !important;
    font-family: inherit !important;
    transition: var(--transition) !important;
}
.single-service-form-wrap .wpforms-container input:focus,
.single-service-form-wrap .wpforms-container textarea:focus,
.single-service-form-wrap .wpforms-container select:focus {
    outline: none !important;
    border-color: var(--clr-primary) !important;
    box-shadow: 0 0 0 3px rgba(26,115,232,.1) !important;
}
.single-service-form-wrap .wpforms-container textarea {
    min-height: 110px;
    resize: vertical;
}
.single-service-form-wrap .wpforms-container .wpforms-field-name .wpforms-field-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
    margin: 0 !important;
}
.single-service-form-wrap .wpforms-container .wpforms-field-name .wpforms-field-row-block {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}
.single-service-form-wrap .wpforms-container .wpforms-field-name .wpforms-field-sublabel {
    display: block;
    margin: .3rem 0 0;
    color: var(--clr-body);
    font-size: .85rem;
}
.single-service-form-wrap .wpforms-container .wpforms-submit-container {
    padding: .5rem 0 0;
}
.single-service-form-wrap .wpforms-container .wpforms-submit {
    width: 100% !important;
    padding: 12px !important;
    border: none !important;
    border-radius: var(--radius-sm) !important;
    font-size: .95rem !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    color: #fff !important;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
    box-shadow: 0 8px 20px rgba(16,185,129,.25) !important;
    transition: var(--transition-bounce) !important;
}
.single-service-form-wrap .wpforms-container .wpforms-submit:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 30px rgba(16,185,129,.35) !important;
}
.single-service-form-wrap .wpforms-container .wpforms-field-required {
    color: #ef4444;
}
.single-service-form-wrap .wpforms-container label.wpforms-error {
    margin-top: .45rem;
    font-size: .82rem !important;
    color: #ef4444 !important;
}

/* ============================================================
   SINGLE PROJECT (pf_project)
   ============================================================ */
.project-single-modern {}

.project-hero {
    position: relative;
    overflow: hidden;
    padding: 4rem 0;
}
.project-hero-grid {
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 3rem;
    align-items: center;
    position: relative;
    z-index: 2;
}
.project-hero-grid.no-thumb {
    grid-template-columns: 1fr;
}
.project-hero-cats {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
    margin-bottom: 1.25rem;
}
.project-entry-title {
    font-size: 3.2rem;
    font-weight: 900;
    color: var(--clr-dark);
    margin: 0 0 1rem;
    line-height: 1.15;
}
.project-hero-subtitle {
    color: var(--clr-body);
    font-size: 1.1rem;
    line-height: 1.8;
    margin: 0 0 1.5rem;
    max-width: 680px;
}
.project-hero-meta {
    display: flex;
    gap: .8rem;
    flex-wrap: wrap;
}
.project-meta-pill {
    background: #fff;
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-pill);
    padding: .55rem 1rem;
    color: var(--clr-body);
    font-size: .88rem;
    box-shadow: var(--shadow-xs);
}
/* Responsive portfolio hero — adapts to ANY image aspect ratio.
   Width fills the column; height follows the image's intrinsic aspect ratio
   (no crop). For very tall / portrait images, max-height caps the container
   so the image never dominates the viewport. object-fit: contain ensures
   the image is never distorted when the cap kicks in. */
.project-hero-image {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-xl);
    background: var(--clr-border);
    display: flex;
    align-items: center;
    justify-content: center;
    max-height: 75vh;
}
.project-hero-image img {
    display: block;
    width: 100%;
    height: auto;
    max-width: 100%;
    max-height: 75vh;
    object-fit: contain;
    margin: 0 auto;
}

/* Tablet — stack the project hero grid, tighten image cap. */
@media (max-width: 900px) {
    .project-hero-grid { grid-template-columns: 1fr; gap: 2rem; }
    .project-hero-image,
    .project-hero-image img { max-height: 60vh; }
}

/* Mobile — softer radius and smaller image cap. */
@media (max-width: 600px) {
    .project-hero       { padding: 2.5rem 0; }
    .project-hero-image { border-radius: var(--radius-lg); }
    .project-hero-image,
    .project-hero-image img { max-height: 50vh; }
}

.project-content-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 2.25rem;
    align-items: start;
}
.project-content-card {
    background: #fff;
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-xl);
    padding: 2rem;
    box-shadow: var(--shadow-sm);
}
.project-content-side {
    position: sticky;
    top: 110px;
}
/* Full-width layout (sidebar removed) */
.project-content-full {
    width: 100%;
}
.project-details-bar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1.5rem;
    margin-top: 2rem;
    padding: 1.5rem;
    background: #fff;
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xs);
}
.project-details-group h3 {
    font-size: .85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--clr-muted);
    margin: 0 0 .75rem;
}
.project-info-card {
    background: #fff;
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    box-shadow: var(--shadow-xs);
    margin-bottom: 1rem;
}
.project-info-card h3 {
    margin: 0 0 .9rem;
    font-size: 1rem;
    font-weight: 800;
    color: var(--clr-dark);
}
.project-info-list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.project-info-list li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: .65rem 0;
    border-bottom: 1px solid #f1f5f9;
}
.project-info-list li:last-child {
    border-bottom: none;
}
.project-info-list span {
    color: var(--clr-muted);
    font-size: .85rem;
}
.project-info-list strong {
    color: var(--clr-dark);
    font-size: .9rem;
}
.project-techs-row {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    margin: 0;
}
.project-entry-footer {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--clr-border);
}
.related-projects-wrap .section-header {
    margin-bottom: 3rem;
}

/* ============================================================
   SINGLE BLOG POST
   ============================================================ */
.single-post-modern {}
.post-hero         { padding: 4rem 0; background: #fff; border-bottom: 1px solid var(--clr-border); }
.post-hero-grid    { display: grid; grid-template-columns: 1.1fr .9fr; gap: 3rem; align-items: center; }
.post-hero-grid.no-thumb { grid-template-columns: 1fr; }
.post-hero-content { min-width: 0; }
.post-categories   { display: flex; justify-content: flex-start; gap: .75rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.post-title        { font-size: 3rem; font-weight: 900; color: var(--clr-dark); margin: 0 0 1.25rem; line-height: 1.2; text-align: left; }
.post-meta         { display: flex; justify-content: flex-start; align-items: center; gap: 1.25rem; flex-wrap: wrap; color: var(--clr-muted); font-size: .95rem; }
.post-meta span    { display: inline-flex; align-items: center; }
.post-updated-date { color: var(--clr-primary); font-size: .85em; }
.blog-card-dates   { display: flex; flex-direction: column; gap: .25rem; font-size: .85rem; color: var(--clr-muted); }
.blog-card-dates .post-updated-date { font-size: 1em; }
.post-hero-media   { min-width: 0; }
/* Responsive featured-image container — adapts to ANY image aspect ratio.
   Width fills the column; height follows the image's intrinsic aspect ratio
   (no crop). For very tall / portrait images, max-height caps the container
   so the image never dominates the viewport. object-fit: contain ensures
   the image is never distorted when the cap kicks in. */
.post-hero-image {
    position: relative;
    overflow: hidden;
    background: var(--clr-border);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    max-height: 75vh;
}
.post-hero-image img {
    display: block;
    width: 100%;
    height: auto;
    max-width: 100%;
    max-height: 75vh;
    object-fit: contain;
    margin: 0 auto;
}
.post-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.2) 100%);
    pointer-events: none;
    border-radius: inherit;
}

/* Tablet — stack the post hero grid, tighten image cap. */
@media (max-width: 900px) {
    .post-hero-grid    { grid-template-columns: 1fr; gap: 2rem; }
    .post-hero-image,
    .post-hero-image img { max-height: 60vh; }
}

/* Mobile — tighter section padding + smaller image cap + softer radius. */
@media (max-width: 600px) {
    .post-hero        { padding: 2.5rem 0; }
    .post-title       { font-size: 2rem; line-height: 1.25; }
    .post-hero-image  { border-radius: var(--radius-lg); }
    .post-hero-image,
    .post-hero-image img { max-height: 50vh; }
}
.post-content-wrap { padding: 3rem 0; background: #fff; border-bottom: 1px solid var(--clr-border); }
.entry-content     { color: var(--clr-body); font-size: 1.05rem; line-height: 1.8; }
.entry-content h2  { font-size: 1.8rem; font-weight: 900; color: var(--clr-dark); margin-top: 2rem; margin-bottom: 1rem; }
.entry-content h3  { font-size: 1.4rem; font-weight: 800; color: var(--clr-dark); margin-top: 1.5rem; margin-bottom: .75rem; }
.entry-content a   { color: var(--clr-primary); text-decoration: none; font-weight: 600; transition: var(--transition); }
.entry-content a:hover { color: var(--clr-primary-dark); text-decoration: underline; }
.entry-content ul, .entry-content ol { margin: 1.5rem 0; padding-left: 2rem; }
.entry-content li  { margin-bottom: .75rem; }
.entry-content blockquote { border-left: 4px solid var(--clr-primary); padding: 1.5rem; margin: 2rem 0; font-style: italic; color: var(--clr-muted); background: var(--clr-bg-light); }
.entry-content code { background: var(--clr-bg-tag); padding: .25rem .5rem; border-radius: 4px; font-family: 'Courier New', monospace; color: #c41a16; }
.entry-content pre  { background: #1a1a1a; color: #e8e8e8; padding: 1.5rem; border-radius: var(--radius-md); overflow-x: auto; margin: 2rem 0; }
.post-footer-section { padding: 3rem 0; background: var(--clr-bg-light); }
.post-tags-row    { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 3rem; padding-bottom: 3rem; border-bottom: 1px solid var(--clr-border); }
.post-tags-label  { font-weight: 600; color: var(--clr-dark); }
.post-nav-grid    { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.post-nav-card    { background: #fff; padding: 1.5rem; border-radius: var(--radius-md); border: 1px solid var(--clr-border); }
.post-nav-card.next { text-align: right; }
.post-nav-label   { color: var(--clr-muted); font-size: .85rem; margin: 0 0 .75rem; font-weight: 600; }
.post-nav-link    { color: var(--clr-primary); text-decoration: none; font-weight: 600; font-size: .95rem; }
.related-posts-section { padding: 4rem 0; background: #fff; }
.related-posts-grid    { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; }

/* ============================================================
   SIDEBAR
   ============================================================ */
.primary-sidebar {}
.sidebar-widget { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius-lg); padding: 1.5rem; margin-bottom: 2rem; }
.widget-title   { font-size: 1.1rem; font-weight: 800; color: var(--clr-dark); margin-bottom: 1.25rem; padding-bottom: .75rem; border-bottom: 2px solid var(--clr-primary); }
.sidebar-post-list { list-style: none; margin: 0; padding: 0; }
.sidebar-post-list li { padding: .75rem 0; border-bottom: 1px solid #f1f5f9; }
.sidebar-post-list li:last-child { border-bottom: none; }
.sidebar-post-list a  { color: var(--clr-dark); text-decoration: none; font-size: .9rem; font-weight: 600; line-height: 1.4; transition: var(--transition); }
.sidebar-post-list a:hover { color: var(--clr-primary); }
.sidebar-post-date { color: var(--clr-muted); font-size: .8rem; margin: .25rem 0 0; }
.sidebar-cat-list  { list-style: none; margin: 0; padding: 0; }
.sidebar-cat-list li { padding: .6rem 0; border-bottom: 1px solid #f1f5f9; }
.sidebar-cat-link  { display: flex; justify-content: space-between; align-items: center; color: var(--clr-body); text-decoration: none; font-size: .9rem; transition: var(--transition); }
.sidebar-cat-link:hover { color: var(--clr-primary); }
.sidebar-cat-count { background: var(--clr-bg-tag); color: var(--clr-primary); padding: .2rem .5rem; border-radius: 20px; font-size: .75rem; font-weight: 700; }
.sidebar-tags      { display: flex; flex-wrap: wrap; gap: .5rem; }
.sidebar-cta       { background: var(--gradient-primary); border-radius: var(--radius-lg); padding: 2rem; text-align: center; color: #fff; margin-bottom: 2rem; }
.sidebar-cta h3    { font-size: 1.2rem; font-weight: 800; margin-bottom: .75rem; color: #fff; }
.sidebar-cta p     { font-size: .9rem; margin-bottom: 1.5rem; opacity: .9; line-height: 1.6; }

/* ============================================================
   SEARCH PAGE
   ============================================================ */
.search-hero   { padding: 5rem 0; border-bottom: 1px solid var(--clr-border); }
.search-title  { font-size: 2.5rem; font-weight: 900; color: var(--clr-dark); margin-bottom: 1rem; line-height: 1.2; text-align: center; }
.search-title .query { color: var(--clr-primary); }
.search-count  { color: var(--clr-muted); font-size: 1.1rem; text-align: center; }
.search-form-wrap { max-width: 560px; margin: 2rem auto 0; }
.search-form       { position: relative; }
.search-input {
    width: 100%; padding: 14px 60px 14px 18px;
    font-size: 1rem; border: 2px solid var(--clr-border);
    border-radius: var(--radius-md); outline: none;
    font-family: inherit; transition: var(--transition);
}
.search-input:focus { border-color: var(--clr-primary); box-shadow: 0 0 0 3px rgba(26,115,232,.1); }
.search-btn {
    position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
    background: var(--clr-primary); color: #fff; border: none;
    border-radius: var(--radius-sm); padding: 8px 14px; cursor: pointer; transition: var(--transition);
}
.search-btn:hover { background: var(--clr-primary-dark); }
.search-no-results { text-align: center; padding: 4rem 2rem; }
.search-no-results .icon { font-size: 4rem; margin-bottom: 1.5rem; }
.search-no-results h2 { font-size: 1.5rem; font-weight: 800; color: var(--clr-dark); margin-bottom: 1rem; }
.search-no-results p  { color: var(--clr-muted); margin-bottom: 2rem; max-width: 450px; margin-left: auto; margin-right: auto; }
.search-no-results-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   404 PAGE
   ============================================================ */
.page-404-section { min-height: 80vh; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; padding: 6rem 0; }
.page-404-center  { text-align: center; position: relative; z-index: 2; }
.num-404 {
    font-size: 9rem; font-weight: 900; line-height: 1; margin-bottom: 1rem;
    background: linear-gradient(135deg, var(--clr-dark) 0%, var(--clr-primary) 100%);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
    animation: slideUp .8s ease-out .1s backwards;
}
.page-404-title { font-size: 2.2rem; font-weight: 900; color: var(--clr-dark); margin-bottom: 1rem; line-height: 1.3; animation: slideUp .8s ease-out .2s backwards; }
.page-404-desc  { font-size: 1.1rem; color: var(--clr-muted); line-height: 1.8; margin-bottom: 2.5rem; animation: slideUp .8s ease-out .3s backwards; }
.page-404-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; animation: slideUp .8s ease-out .5s backwards; }

/* ============================================================
   COMMENTS
   ============================================================ */
.comments-area    { margin-top: 4rem; }
.comments-title   { font-size: 1.8rem; font-weight: 800; color: var(--clr-dark); margin-bottom: 2rem; }
.comment-list     { list-style: none; padding: 0; margin: 0; }
.comment-body-wrap{ background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius-lg); padding: 1.5rem; margin-bottom: 1.5rem; }
.comment-author-name { font-weight: 700; color: var(--clr-dark); }
.comment-date     { color: var(--clr-muted); font-size: .85rem; margin-left: .5rem; }
.comment-text     { color: var(--clr-body); line-height: 1.7; margin: .75rem 0 1rem; }
.comment-reply a  { color: var(--clr-primary); font-weight: 600; font-size: .9rem; text-decoration: none; }
.children .comment-body-wrap { margin-left: 2rem; }

/* Comment form */
.comment-form-title   { font-size: 1.5rem; font-weight: 800; color: var(--clr-dark); margin-bottom: 1.5rem; }
.comment-form         { display: flex; flex-direction: column; gap: 1.5rem; }
.comment-form-fields  { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1.5rem; }
.comment-form p       { margin: 0; }
.comment-form input,
.comment-form textarea{
    width: 100%; padding: .75rem; border: 1px solid var(--clr-border);
    border-radius: var(--radius-md); font-size: 1rem; font-family: inherit; transition: var(--transition);
}
.comment-form input:focus,
.comment-form textarea:focus { outline: none; border-color: var(--clr-primary); box-shadow: 0 0 0 3px rgba(26,115,232,.1); }
.comment-form .submit  { background: var(--gradient-primary); color: #fff; padding: .85rem 2rem; border: none; border-radius: var(--radius-md); font-size: 1rem; font-weight: 700; cursor: pointer; transition: var(--transition-bounce); }
.comment-form .submit:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(26,115,232,.3); }
.no-comments { color: var(--clr-muted); font-size: 1rem; text-align: center; padding: 2rem 0; }

/* ============================================================
   ARCHIVE PAGES (BLOG, SERVICES, etc.)
   ============================================================ */
.archive-hero   { padding: 6rem 0; }
.archive-search { padding: 3rem 0; background: var(--clr-bg-light); border-bottom: 1px solid var(--clr-border); }
.archive-search .search-form-wrap { max-width: 600px; margin: 0 auto; }
.archive-posts-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2.5rem; }
.archive-featured   { padding: 5rem 0; background: #fff; border-bottom: 1px solid var(--clr-border); }
.archive-featured-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.archive-featured-content .btn { margin-top: .5rem; }
.archive-pagination { margin-top: 4rem; text-align: center; }

/* Technologies filter */
.tech-filter-grid { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; }
.tech-filter-tag  { background: #fff; color: var(--clr-primary); padding: .75rem 1.5rem; border-radius: var(--radius-pill); text-decoration: none; font-weight: 600; border: 2px solid var(--clr-primary); transition: var(--transition); display: inline-block; }
.tech-filter-tag:hover { background: var(--clr-primary); color: #fff; }

/* Process / how-it-works */
.process-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; text-align: center; }
.process-step { background: #fff; padding: 0 1.5rem 2rem; border-radius: var(--radius-xl); border: 1px solid var(--clr-border); position: relative; overflow: hidden; text-align: center; }
.process-num {
    position: absolute;
    top: 1rem;
    right: 1.25rem;
    font-size: 1rem;
    font-weight: 900;
    line-height: 1;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--clr-bg-tag);
    color: var(--clr-primary);
}
.process-step h3 { font-size: 1.2rem; font-weight: 800; color: var(--clr-dark); margin: 1.25rem 0 .75rem; }
.process-step p  { color: var(--clr-muted); line-height: 1.6; margin: 0; text-align: left; }

/* ============================================================
   ANIMATIONS — KEYFRAMES
   ============================================================ */
@keyframes floatSlow         { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-30px); } }
@keyframes floatShape        { 0%,100%{ transform: translateY(0) translateX(0); } 25%{ transform: translateY(-40px) translateX(20px); } 50%{ transform: translateY(-80px) translateX(0); } 75%{ transform: translateY(-40px) translateX(-20px); } }
@keyframes floatShapeReverse { 0%,100%{ transform: translateY(0) translateX(0); } 25%{ transform: translateY(40px) translateX(-20px); } 50%{ transform: translateY(80px) translateX(0); } 75%{ transform: translateY(40px) translateX(20px); } }
@keyframes rotateShape       { 0%{ transform: rotate(0deg) scale(1); } 50%{ transform: rotate(180deg) scale(1.05); } 100%{ transform: rotate(360deg) scale(1); } }
@keyframes rotateShapeReverse{ 0%{ transform: rotate(360deg) scale(1); } 50%{ transform: rotate(180deg) scale(.95); } 100%{ transform: rotate(0deg) scale(1); } }
@keyframes pulseShape        { 0%,100%{ transform: scale(1); opacity:.08; } 50%{ transform: scale(1.2); opacity:.12; } }
@keyframes slideUp           { from{ opacity:0; transform: translateY(40px); } to{ opacity:1; transform: translateY(0); } }
@keyframes slideInLeft       { from{ opacity:0; transform: translateX(-60px); } to{ opacity:1; transform: translateX(0); } }
@keyframes slideInRight      { from{ opacity:0; transform: translateX(60px); } to{ opacity:1; transform: translateX(0); } }
@keyframes fadeInUp          { from{ opacity:0; transform: translateY(30px); } to{ opacity:1; transform: translateY(0); } }
@keyframes pulse             { 0%,100%{ opacity:1; } 50%{ opacity:.5; } }

/* Staggered animation helpers */
.anim-delay-1  { animation-delay: .1s; }
.anim-delay-2  { animation-delay: .2s; }
.anim-delay-3  { animation-delay: .3s; }
.anim-delay-4  { animation-delay: .4s; }
.anim-delay-5  { animation-delay: .5s; }
.anim-delay-6  { animation-delay: .6s; }
.anim-in-up    { animation: fadeInUp .8s ease-out backwards; }
.anim-slide-up { animation: slideUp  .8s ease-out backwards; }

/* ============================================================
   GUTENBERG SERVICE BLOCKS
   ============================================================ */

/* Hero block */
.block-service-hero {
    padding: 6rem 0;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
}
.block-hero-inner  { position: relative; z-index: 2; }
.block-hero-content{ text-align: center; max-width: 900px; margin: 0 auto; }
.block-hero-title  { font-size: 3.5rem; font-weight: 900; margin-bottom: 1.5rem; color: var(--clr-dark); line-height: 1.2; }
.block-hero-subtitle { font-size: 1.2rem; color: var(--clr-muted); margin: 0; line-height: 1.8; }

/* Section title + divider used inside blocks */
.block-section-title  { font-size: 2.5rem; font-weight: 900; margin-bottom: 1.5rem; color: var(--clr-dark); position: relative; padding-bottom: 1rem; }
.block-section-divider{ width: 60px; height: 4px; background: var(--gradient-primary); border-radius: 2px; margin-bottom: 2rem; }

/* Overview */
.block-overview-content { font-size: 1.1rem; color: var(--clr-body); line-height: 1.9; margin-bottom: 2.5rem; }
.block-highlight {
    background: linear-gradient(135deg, #f0f4f8 0%, #e8eef5 100%);
    border-left: 4px solid var(--clr-primary);
    padding: 2rem; border-radius: var(--radius-lg);
    font-size: 1.05rem; font-weight: 600; color: var(--clr-dark);
    box-shadow: 0 4px 15px rgba(26,115,232,.1);
}
.block-highlight-label { color: var(--clr-primary); font-weight: 800; }

/* Process step accent bar */
.block-step-bar { position: absolute; bottom: 0; left: 0; right: 0; height: 4px; border-radius: 0 0 20px 20px; }

/* Pricing grid */
.pricing-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; }
.pricing-card {
    background: #fff; padding: 2.5rem; border-radius: var(--radius-lg);
    text-align: center; border: 1px solid var(--clr-border);
    box-shadow: var(--shadow-xs); transition: var(--transition);
}
.pricing-card--featured {
    border: 2px solid var(--clr-primary);
    box-shadow: 0 20px 60px rgba(26,115,232,.15);
    transform: translateY(-20px);
}
.pricing-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.pricing-card--featured:hover { transform: translateY(-26px); }
.pricing-badge { background: var(--gradient-primary); color: #fff; padding: .5rem 1rem; border-radius: 20px; display: inline-block; font-size: .85rem; font-weight: 700; margin-bottom: 1rem; }
.pricing-name  { font-size: 1.5rem; font-weight: 800; color: var(--clr-dark); margin-bottom: .75rem; }
.pricing-price { font-size: 3rem; font-weight: 900; color: var(--clr-primary); margin: 1rem 0; }
.pricing-desc  { color: var(--clr-muted); margin-bottom: 1.5rem; }
.pricing-features     { list-style: none; padding: 0; margin: 1.5rem 0; text-align: left; }
.pricing-features li  { display: flex; align-items: flex-start; gap: .65rem; margin-bottom: .75rem; font-size: .95rem; line-height: 1.4; }

/* Included — green tick */
.pricing-feature-yes  { color: var(--clr-body); }
.pricing-icon--yes    { color: #10b981; flex-shrink: 0; margin-top: 1px; }

/* Excluded — red cross, muted text */
.pricing-feature-no   { color: var(--clr-lighter); }
.pricing-icon--no     { color: #ef4444; flex-shrink: 0; margin-top: 1px; }

/* Legacy fallback (old .pricing-check) */
.pricing-check        { color: #10b981; flex-shrink: 0; margin-top: 1px; }
.pricing-icon         { flex-shrink: 0; margin-top: 1px; display: inline-flex; }

/* FAQ list */
.faq-list { display: flex; flex-direction: column; gap: 1.5rem; }

/* CTA banner block */
.block-service-cta {
    background: var(--gradient-primary);
    padding: 4rem 0;
    text-align: center;
    color: #fff;
    margin-bottom: 3rem;
}
.block-service-cta .cta-block h2 { color: #fff; }
.block-service-cta .cta-block p  { color: rgba(255,255,255,.95); }

/* ============================================================
   ADDITIONAL UTILITY CLASSES
   (eliminates last static inline styles)
   ============================================================ */

/* Card / article link wrappers */
.card-link-block { text-decoration: none; color: inherit; display: block; height: 100%; }

/* Inline flex row utilities */
.flex-row-wrap   { display: flex; gap: .5rem; flex-wrap: wrap; }
.flex-row-cta    { display: flex; gap: 1.5rem; flex-wrap: wrap; margin-top: 2rem; }

/* Section intro text */
.section-intro { text-align: center; font-size: 1.1rem; color: var(--clr-muted); line-height: 1.8; margin: 0; padding: 3rem 0; border-bottom: 1px solid var(--clr-border); }

/* Archive section headings */
.archive-heading { font-size: 2.5rem; font-weight: 900; margin-bottom: 3rem; color: var(--clr-dark); }

/* comment layout */
.comment-inner   { display: flex; align-items: flex-start; gap: 1rem; }
.comment-body    { flex: 1; }
.comment-pending { color: var(--clr-muted); font-style: italic; }

/* hero relative container */
.container-rel   { position: relative; z-index: 2; }

/* testimonials eyebrow */
.testimonials-eyebrow {
    display: inline-block;
    background: rgba(26,115,232,.08);
    border: 1px solid rgba(26,115,232,.2);
    padding: .75rem 1.5rem;
    border-radius: var(--radius-pill);
    margin-bottom: 1.5rem;
    color: var(--clr-primary);
    font-weight: 700;
    font-size: .85rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* index.php intro */
.site-intro      { text-align: center; padding: 3rem 0; }
.site-intro h1   { font-size: 2rem; font-weight: 900; color: var(--clr-dark); margin-bottom: 1rem; }
.site-intro p    { color: var(--clr-muted); font-size: 1.1rem; }

/* pricing grid responsive */
@media (max-width: 768px) {
    .pricing-grid { grid-template-columns: 1fr !important; }
    .pricing-card--featured { transform: none !important; }
    .pricing-card--featured:hover { transform: translateY(-6px) !important; }
    .block-hero-title { font-size: 2.5rem !important; }
    .features-grid[style] { grid-template-columns: 1fr !important; }
}

/* Blog search results widget */
#blog-search-results { margin-top: 1rem; display: none; }

/* ============================================================
   UTILITY CLASSES — supplementary
   ============================================================ */

/* Full-size link overlay (used on card images) */
.link-fill        { display: block; width: 100%; height: 100%; }
.img-fallback     { width: 100%; height: 100%; background: linear-gradient(135deg, var(--clr-primary), var(--clr-primary-dark)); }
.img-fallback-flex{ width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: #fff; }

/* Small text / note */
.text-note        { font-size: .85rem; margin-top: 1rem; color: var(--clr-muted); }

/* White text */
.text-white       { color: #fff !important; }
.text-white-soft  { color: rgba(255,255,255,.9); }

/* section spacer overrides */
.mt-4  { margin-top: 4rem; }
.mt-3  { margin-top: 3rem; }
.mb-3  { margin-bottom: 3rem; }

/* Post author link in post meta */
.post-author-link { color: var(--clr-muted); text-decoration: none; font-weight: 600; transition: var(--transition); }
.post-author-link:hover { color: var(--clr-primary); }

/* Card title links */
.card-title-link  { color: inherit; text-decoration: none; transition: color .3s; }
.card-title-link:hover { color: var(--clr-primary); }

/* Block step bar (service blocks) */
.block-step-bar   { height: 3px; border-radius: 2px; margin-top: 1.5rem; }

/* Blocks service hero */
.block-service-hero { position: relative; overflow: hidden; }

/* feature-icon-circle defined below */

/* Badge display:inline-block helper */
.badge-inline { display: inline-block; margin-bottom: .75rem; }

/* Section heading white (used in CTA blocks) */
.heading-white    { color: #fff; }

/* Button full-width variant */
.btn-full         { width: 100%; text-align: center; display: block; }

/* Index.php wrappers */
.post-single-wrap { padding: 2rem 0; }

/* Service card title inside archive listing */
.service-card-title { font-size: 1.2rem; font-weight: 800; margin-bottom: .75rem; }

/* ============================================================
   FINAL UTILITY PATCH
   ============================================================ */
.card-body-pad     { padding: 2rem; }
.card-body-padtop  { padding-top: 1rem; border-top: 1px solid var(--clr-border); }
.cta-block-spaced  { margin-top: 4rem; }
.cta-block-spaced2 { margin-top: 3rem; }
.flex-row-wrap-mb  { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1rem; }
.flex-row-wrap-mb2 { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.block-process-container { position: relative; z-index: 2; }
.btn-full-center   { width: 100%; text-align: center; display: block; color: #fff !important; }
.card-img-placeholder { width: 100%; height: 100%; background: var(--gradient-primary); }
.card-portfolio-image-fixed { height: 240px; }
.portfolio-card-text h3  { font-size: 1.25rem; font-weight: 800; color: var(--clr-dark); margin: 0 0 .75rem; line-height: 1.4; }
.portfolio-card-text h3 a{ color: inherit; text-decoration: none; }
.portfolio-card-text p   { color: var(--clr-muted); margin: 0 0 1.5rem; line-height: 1.6; font-size: .95rem; }
.no-projects { text-align: center; padding: 4rem 0; }
.no-projects h2 { color: var(--clr-dark); margin-bottom: 1rem; }
.no-projects p  { color: var(--clr-muted); }
.portfolio-card-text-title   { font-size: 1.25rem; font-weight: 800; color: var(--clr-dark); margin: 0 0 .75rem; line-height: 1.4; }
.portfolio-card-text-title .card-title-link { color: inherit; text-decoration: none; transition: var(--transition); }
.portfolio-card-text-title .card-title-link:hover { color: var(--clr-primary); }
.portfolio-card-text-excerpt { color: var(--clr-muted); margin: 0 0 1.5rem; line-height: 1.6; font-size: .95rem; }

/* ============================================================
   FINAL UTILITY ADDITIONS
   ============================================================ */

/* Image cover (used on portfolio / service image containers) */
.img-cover        { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.img-cover-static { width: 100%; height: 100%; object-fit: cover; }

/* Link card overlay (no-style full-height card links) */
.link-card-wrap   { text-decoration: none; color: inherit; display: block; height: 100%; }

/* Card inner padding */
.card-inner-pad   { padding: 1.5rem; }

/* Featured image card wrapper */
.feat-image-card  { margin-bottom: 3rem; border-radius: 16px; overflow: hidden; box-shadow: 0 10px 40px rgba(0,0,0,.1); }

/* Post categories left-aligned variant */
.post-categories-row { display: flex; justify-content: flex-start; gap: .75rem; flex-wrap: wrap; margin-bottom: 1rem; }

/* Search container centered */
.search-hero-inner { text-align: center; }

/* Archive services intro */
.archive-intro-section { border-bottom: 1px solid var(--clr-border); }
.archive-intro-text    { font-size: 1.1rem; color: var(--clr-muted); line-height: 1.8; margin: 0; text-align: center; }

/* Content-portfolio card specific */
.portfolio-mini-card-image { position: relative; height: 200px; overflow: hidden; background: var(--clr-border); }
.portfolio-mini-card-body  { padding: 1.5rem; }
.portfolio-mini-card-title { font-size: 1.05rem; font-weight: 800; color: var(--clr-dark); margin: 0 0 .5rem; line-height: 1.4; }
.portfolio-mini-cat-wrap   { margin-bottom: .75rem; }
.section-heading-sm { font-size: 1.8rem; font-weight: 900; color: var(--clr-dark); margin-bottom: 2.5rem; text-align: center; }

/* About page profile image */
.about-image-wrap {
    border-radius: var(--radius-2xl);
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.12);
    aspect-ratio: 1;
}
.about-profile-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.6s ease;
}
.about-image-wrap:hover .about-profile-img {
    transform: scale(1.03);
}

/* Skill card icon wrapper */
.skill-icon-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: var(--radius-lg);
    margin-bottom: 1.25rem;
}

/* Philosophy icon — SVG version */
.philosophy-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    margin: 1.5rem auto 0;
}

/* ============================================================
   SERVICE SINGLE PAGE — entry content full width
   ============================================================ */
.service-entry-content {
    max-width: 100%;
}
.service-entry-content p,
.service-entry-content li {
    font-size: 1.05rem;
    line-height: 1.8;
    color: var(--clr-body);
}

/* ============================================================
   PROCESS STEP — icon wrap above number
   ============================================================ */
.process-icon-wrap {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 1.5rem auto 0;
    box-shadow: 0 8px 20px rgba(0,0,0,.12);
    flex-shrink: 0;
}
.process-icon-wrap svg {
    display: block;
    flex-shrink: 0;
}

/* ============================================================
   BLOCK OVERVIEW — wide container variant
   ============================================================ */
.block-overview-inner {
    max-width: 860px;
    margin: 0 auto;
}

/* Highlight box SVG icon */
.block-highlight {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
}
.block-highlight-content {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: .35rem;
    min-width: 0;
}
.block-highlight-icon {
    flex-shrink: 0;
    color: var(--clr-primary);
    margin-top: 2px;
}
.block-highlight-label {
    font-weight: 800;
    color: var(--clr-primary);
}
.block-highlight-text {
    display: block;
    color: var(--clr-dark);
    line-height: 1.8;
    word-break: break-word;
}

/* Feature icon circle — definitive, used in both blocks and front-page features */
.feature-icon-circle {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    margin: 1.5rem auto 0;
    box-shadow: 0 8px 20px rgba(0,0,0,.12);
    flex-shrink: 0;
}
.feature-icon-circle svg {
    display: block;
    flex-shrink: 0;
}

/* Responsive: service single hero stacks on mobile */
@media (max-width: 768px) {
    .single-service-hero-grid {
        grid-template-columns: 1fr !important;
    }
    .process-grid {
        grid-template-columns: 1fr 1fr !important;
    }
}
@media (max-width: 480px) {
    .process-grid {
        grid-template-columns: 1fr !important;
    }
    .pricing-grid {
        grid-template-columns: 1fr !important;
    }
}

/* ============================================================
   PROFESSIONAL CODE BLOCK STYLING
   Covers:
   — Gutenberg native Code block  (.wp-block-code)
   — Gutenberg Preformatted block (.wp-block-preformatted)
   — Classic editor <pre><code>
   — Inline <code> anywhere on the site
   — .entry-content code / pre (overrides the basic rules above)
   ============================================================ */

/* ── CSS custom properties for the code theme ── */
:root {
    --code-bg:          #0d1117;   /* GitHub dark background         */
    --code-border:      #30363d;   /* subtle border                  */
    --code-text:        #e6edf3;   /* default text                   */
    --code-comment:     #8b949e;   /* comments / line numbers        */
    --code-string:      #a5d6ff;   /* strings                        */
    --code-keyword:     #ff7b72;   /* keywords / tags                */
    --code-function:    #d2a8ff;   /* functions                      */
    --code-number:      #79c0ff;   /* numbers / constants            */
    --code-variable:    #ffa657;   /* variables / attributes         */
    --code-header-bg:   #161b22;   /* top bar background             */
    --code-header-text: #8b949e;   /* top bar label                  */
    --code-radius:      10px;
    --code-font:        'SFMono-Regular', Consolas, 'Liberation Mono',
                        Menlo, Courier, monospace;
    --code-font-size:   .875rem;
    --code-line-height: 1.7;
}

/* ── Inline code ──────────────────────────────────────────── */
code,
.entry-content code,
p code,
li code,
td code,
h1 code, h2 code, h3 code, h4 code {
    font-family:      var(--code-font);
    font-size:        .85em;
    background:       #f0f3f6;
    color:            #c0392b;
    padding:          .2em .45em;
    border-radius:    4px;
    border:           1px solid #e1e4e8;
    white-space:      nowrap;
    font-weight:      500;
    line-height:      1;
    vertical-align:   baseline;
}

/* Don't double-style code inside pre */
pre code,
.wp-block-code code {
    background:    transparent !important;
    border:        none !important;
    color:         inherit !important;
    padding:       0 !important;
    font-size:     inherit !important;
    white-space:   pre !important;
    border-radius: 0 !important;
    font-weight:   400;
    vertical-align: unset;
}

/* ── Block wrapper ────────────────────────────────────────── */
.wp-block-code,
.wp-block-preformatted,
.entry-content pre,
pre {
    position:      relative;
    background:    var(--code-bg);
    border:        1px solid var(--code-border);
    border-radius: var(--code-radius);
    margin:        2rem 0;
    overflow:      hidden;         /* clip the header bar corners   */
    box-shadow:    0 4px 24px rgba(0,0,0,.25);
}

/* ── No fake window-chrome bar — dots removed ─────────────── */
.wp-block-code::before,
.wp-block-preformatted::before,
.entry-content pre::before,
pre::before {
    content: none;
    display: none;
}

/* ── The actual <code> / text area ───────────────────────── */
.wp-block-code code,
.wp-block-preformatted,
.entry-content pre code,
pre code {
    display:       block;
    padding:       1.25rem 1.5rem;
    overflow-x:    auto;
    font-family:   var(--code-font);
    font-size:     var(--code-font-size);
    line-height:   var(--code-line-height);
    color:         var(--code-text);
    tab-size:      4;
    -moz-tab-size: 4;
}

/* Scrollbar styling inside code blocks */
.wp-block-code code::-webkit-scrollbar,
pre code::-webkit-scrollbar         { height: 6px; }
.wp-block-code code::-webkit-scrollbar-track,
pre code::-webkit-scrollbar-track   { background: var(--code-bg); }
.wp-block-code code::-webkit-scrollbar-thumb,
pre code::-webkit-scrollbar-thumb   { background: var(--code-border); border-radius: 3px; }

/* ── Language label (shown via data-language attribute) ───── */
.wp-block-code[class*="language-"]::after,
.wp-block-code[data-language]::after {
    content:     attr(data-language);
    position:    absolute;
    top:         .5rem;
    right:       1rem;
    font-family: var(--code-font);
    font-size:   .72rem;
    font-weight: 600;
    color:       var(--code-comment);
    text-transform: uppercase;
    letter-spacing: .06em;
    pointer-events: none;
}

/* Language label from the class e.g. language-php / language-js */
.wp-block-code.language-php::after    { content: 'PHP'; }
.wp-block-code.language-javascript::after,
.wp-block-code.language-js::after     { content: 'JS'; }
.wp-block-code.language-typescript::after,
.wp-block-code.language-ts::after     { content: 'TS'; }
.wp-block-code.language-css::after    { content: 'CSS'; }
.wp-block-code.language-html::after,
.wp-block-code.language-markup::after { content: 'HTML'; }
.wp-block-code.language-bash::after,
.wp-block-code.language-shell::after  { content: 'Shell'; }
.wp-block-code.language-json::after   { content: 'JSON'; }
.wp-block-code.language-sql::after    { content: 'SQL'; }
.wp-block-code.language-python::after { content: 'Python'; }

/* ── Basic token colours (works without Prism / highlight.js)
       Covers the most common patterns in PHP/JS/CSS/HTML        */

/* Strings */
.wp-block-code .token.string,
.wp-block-code .hljs-string         { color: var(--code-string); }
/* Keywords */
.wp-block-code .token.keyword,
.wp-block-code .hljs-keyword        { color: var(--code-keyword); }
/* Comments */
.wp-block-code .token.comment,
.wp-block-code .hljs-comment        { color: var(--code-comment); font-style: italic; }
/* Functions */
.wp-block-code .token.function,
.wp-block-code .hljs-title.function_{ color: var(--code-function); }
/* Numbers */
.wp-block-code .token.number,
.wp-block-code .hljs-number         { color: var(--code-number); }
/* Variables / attributes */
.wp-block-code .token.variable,
.wp-block-code .token.attr-name,
.wp-block-code .hljs-variable,
.wp-block-code .hljs-attr           { color: var(--code-variable); }
/* Tags */
.wp-block-code .token.tag,
.wp-block-code .hljs-tag            { color: var(--code-keyword); }
/* Punctuation */
.wp-block-code .token.punctuation   { color: var(--code-text); }
/* Built-ins / class names */
.wp-block-code .token.class-name,
.wp-block-code .hljs-built_in       { color: #ffa657; }

/* ── Responsive: allow horizontal scroll on mobile ───────── */
@media (max-width: 768px) {
    .wp-block-code code,
    .entry-content pre code,
    pre code {
        font-size: .8rem;
        padding:   1rem;
    }
}

/* ── Gutenberg editor: mirror the frontend style ─────────── */
.editor-styles-wrapper .wp-block-code {
    background:    var(--code-bg) !important;
    border:        1px solid var(--code-border) !important;
    border-radius: var(--code-radius) !important;
}
.editor-styles-wrapper .wp-block-code code {
    color:      var(--code-text) !important;
    font-size:  var(--code-font-size) !important;
    font-family: var(--code-font) !important;
}

/* =============================================
   Services Archive — FAQ Section
   ============================================= */
.services-faq {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-top: 2rem;
}

.faq-item {
    border-bottom: 1px solid #e5e7eb;
    padding: 1.5rem 0;
}

.faq-item:first-child {
    border-top: 1px solid #e5e7eb;
}

.faq-item h3 {
    font-size: 1.05rem;
    font-weight: 600;
    color: #1a1a2e;
    margin: 0 0 0.6rem 0;
    line-height: 1.5;
}

.faq-item p {
    font-size: 0.95rem;
    color: #555;
    margin: 0;
    line-height: 1.7;
}

/* =============================================
   Blog & Portfolio Archive — SEO Improvements
   ============================================= */
.blog-topic-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1rem;
}

.blog-topic-tags .badge {
    text-decoration: none;
    transition: opacity 0.2s;
}

.blog-topic-tags .badge:hover {
    opacity: 0.8;
}

.archive-intro-section .archive-intro-text {
    font-size: 1.05rem;
    color: #444;
    line-height: 1.8;
    margin: 0 0 1rem 0;
}
/* ================================================
   NEW SERVICE BLOCKS - STYLES
   Add to: assets/css/theme.css
   ================================================ */

/* -------------------------------------------------------
   BLOCK: HERO STATS
   Display credibility metrics in hero section
------------------------------------------------------- */
.block-hero-stats {
    margin: 2rem 0;
    padding: 1.5rem 0;
    border-top: 1px solid rgba(0,0,0,0.1);
    border-bottom: 1px solid rgba(0,0,0,0.1);
}

.hero-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 2rem;
    text-align: center;
}

.stat-item {
    padding: 0.5rem;
}

.stat-number {
    font-size: 2.5rem;
    font-weight: 900;
    color: var(--clr-primary);
    line-height: 1;
    margin-bottom: 0.5rem;
}

.stat-label {
    font-size: 0.95rem;
    color: var(--clr-muted);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Mobile adjustments */
@media (max-width: 768px) {
    .hero-stats-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }
    
    .stat-number {
        font-size: 2rem;
    }
    
    .stat-label {
        font-size: 0.85rem;
    }
}

/* -------------------------------------------------------
   BLOCK: TESTIMONIALS
   Client reviews with ratings
------------------------------------------------------- */
.block-testimonials {
    background: #fff;
}

.testimonials-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 2rem;
}

.testimonials-carousel {
    display: flex;
    gap: 2rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 1rem;
    -webkit-overflow-scrolling: touch;
}

.testimonials-carousel .testimonial-card {
    flex: 0 0 90%;
    scroll-snap-align: center;
}

.testimonial-card {
    background: #fff;
    padding: 2rem;
    border-radius: 12px;
    border: 1px solid var(--clr-border);
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
}

.testimonial-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.1);
}

.testimonial-rating {
    font-size: 1.5rem;
    color: #f5a623;
    margin-bottom: 1rem;
    letter-spacing: 2px;
}

.testimonial-quote {
    font-size: 1.1rem;
    line-height: 1.7;
    color: var(--clr-text);
    margin: 0 0 1.5rem 0;
    font-style: italic;
    flex-grow: 1;
}

.testimonial-quote::before {
    content: '"';
    font-size: 3rem;
    color: var(--clr-primary);
    opacity: 0.2;
    line-height: 0;
    position: relative;
    top: 20px;
}

.testimonial-author {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--clr-border);
}

.author-photo {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--clr-primary);
}

.author-info {
    flex-grow: 1;
}

.author-name {
    font-weight: 700;
    color: var(--clr-dark);
    font-size: 1rem;
    margin-bottom: 0.25rem;
}

.author-company {
    font-size: 0.9rem;
    color: var(--clr-muted);
}

.testimonial-link {
    display: inline-block;
    margin-top: 1rem;
    color: var(--clr-primary);
    font-weight: 600;
    text-decoration: none;
    font-size: 0.95rem;
    transition: color 0.2s ease;
}

.testimonial-link:hover {
    color: var(--clr-dark);
}

/* -------------------------------------------------------
   BLOCK: PORTFOLIO SHOWCASE
   Featured projects grid
------------------------------------------------------- */
.block-portfolio {
    background: var(--clr-bg-light);
}

.portfolio-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 2.5rem;
}

.portfolio-card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.portfolio-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 30px rgba(0,0,0,0.15);
}

.portfolio-image {
    display: block;
    position: relative;
    overflow: hidden;
    aspect-ratio: 16/10;
}

.portfolio-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.portfolio-card:hover .portfolio-image img {
    transform: scale(1.05);
}

.portfolio-content {
    padding: 1.75rem;
}

.portfolio-content h3 {
    font-size: 1.4rem;
    margin-bottom: 0.75rem;
    line-height: 1.3;
}

.portfolio-content h3 a {
    color: var(--clr-dark);
    text-decoration: none;
    transition: color 0.2s ease;
}

.portfolio-content h3 a:hover {
    color: var(--clr-primary);
}

.portfolio-excerpt {
    color: var(--clr-muted);
    line-height: 1.6;
    margin-bottom: 1rem;
    font-size: 0.95rem;
}

.portfolio-tech,
.portfolio-client {
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
    color: var(--clr-text);
}

.portfolio-tech strong,
.portfolio-client strong {
    color: var(--clr-dark);
}

.portfolio-link {
    display: inline-block;
    margin-top: 1rem;
    color: var(--clr-primary);
    font-weight: 600;
    text-decoration: none;
    font-size: 0.95rem;
    transition: color 0.2s ease;
}

.portfolio-link:hover {
    color: var(--clr-dark);
}

/* -------------------------------------------------------
   BLOCK: CLIENT LOGOS
   Brand associations grid
------------------------------------------------------- */
.block-client-logos {
    background: #fafbfc;
    border-top: 1px solid var(--clr-border);
    border-bottom: 1px solid var(--clr-border);
}

.logos-grid {
    display: grid;
    gap: 2rem;
    align-items: center;
    justify-items: center;
}

.logos-cols-4 { grid-template-columns: repeat(4, 1fr); }
.logos-cols-5 { grid-template-columns: repeat(5, 1fr); }
.logos-cols-6 { grid-template-columns: repeat(6, 1fr); }
.logos-cols-8 { grid-template-columns: repeat(8, 1fr); }

.logo-item {
    width: 100%;
    max-width: 150px;
    padding: 1rem;
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.logo-item img {
    width: 100%;
    height: auto;
    display: block;
}

.logos-grayscale .logo-item img {
    filter: grayscale(100%);
    opacity: 0.6;
}

.logos-grayscale .logo-item:hover img {
    filter: grayscale(0%);
    opacity: 1;
    transform: scale(1.05);
}

.logo-item a {
    display: block;
}

/* Mobile responsive */
@media (max-width: 768px) {
    .logos-cols-6,
    .logos-cols-8 {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .logos-cols-4,
    .logos-cols-5 {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* -------------------------------------------------------
   BLOCK: TRUST BADGES
   Guarantees and certifications
------------------------------------------------------- */
.block-trust-badges {
    background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
    padding: 3rem 0;
}

.badges-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 2rem;
}

.badge-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.5rem;
    background: #fff;
    border-radius: 8px;
    border: 1px solid var(--clr-border);
    transition: box-shadow 0.3s ease;
}

.badge-item:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}

.badge-icon {
    flex-shrink: 0;
    color: var(--clr-primary);
    width: 40px;
    height: 40px;
}

.badge-icon svg {
    width: 100%;
    height: 100%;
}

.badge-content {
    flex-grow: 1;
}

.badge-title {
    font-weight: 700;
    color: var(--clr-dark);
    font-size: 1.05rem;
    margin-bottom: 0.5rem;
    line-height: 1.3;
}

.badge-desc {
    font-size: 0.9rem;
    color: var(--clr-muted);
    line-height: 1.5;
}

/* -------------------------------------------------------
   BLOCK: COMPARISON TABLE
   Service packages comparison
------------------------------------------------------- */
.block-comparison {
    background: var(--clr-bg-light);
}

.comparison-table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.comparison-table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}

.comparison-table thead th {
    background: var(--clr-dark);
    color: #fff;
    padding: 2rem 1.5rem;
    font-weight: 700;
    text-align: center;
    vertical-align: top;
}

.comparison-table thead th:first-child {
    background: #fff;
    color: var(--clr-dark);
    text-align: left;
    border-right: 1px solid var(--clr-border);
}

.comparison-table thead th.highlight {
    background: var(--clr-primary);
    position: relative;
}

.comparison-table thead th.highlight::after {
    content: 'POPULAR';
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    background: #fff;
    color: var(--clr-primary);
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.5px;
}

.package-header {
    text-align: center;
}

.package-name {
    font-size: 1.3rem;
    margin-bottom: 0.5rem;
}

.package-price {
    font-size: 2rem;
    font-weight: 900;
    margin-top: 0.5rem;
}

.comparison-table tbody tr {
    border-bottom: 1px solid var(--clr-border);
}

.comparison-table tbody tr:hover {
    background: #f8f9fa;
}

.comparison-table tbody td {
    padding: 1.25rem 1.5rem;
    text-align: center;
    vertical-align: middle;
}

.comparison-table tbody td.feature-name {
    text-align: left;
    font-weight: 600;
    color: var(--clr-dark);
    border-right: 1px solid var(--clr-border);
}

.comparison-table tbody td.highlight {
    background: rgba(26,115,232,0.03);
}

.comparison-table tfoot td {
    padding: 2rem 1.5rem;
    background: #fafbfc;
}

.comparison-table tfoot td.highlight {
    background: rgba(26,115,232,0.05);
}

.btn-block {
    display: block;
    width: 100%;
    text-align: center;
    padding: 0.75rem 1.5rem;
}

/* Mobile responsive */
@media (max-width: 768px) {
    .comparison-table {
        font-size: 0.9rem;
    }
    
    .comparison-table thead th,
    .comparison-table tbody td,
    .comparison-table tfoot td {
        padding: 1rem 0.75rem;
    }
    
    .package-name {
        font-size: 1.1rem;
    }
    
    .package-price {
        font-size: 1.5rem;
    }
}

/* -------------------------------------------------------
   BUTTON HOVER FIX
   Fix disappearing text on hover
------------------------------------------------------- */
.btn-primary {
    background: var(--gradient-primary);
    color: #fff;
    box-shadow: 0 8px 25px rgba(26,115,232,.25);
    position: relative;
    z-index: 1;
}

.btn-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 35px rgba(26,115,232,.35);
    color: #fff !important;
    background: var(--gradient-primary);
}

/* Ensure text is always on top */
.btn-primary::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: inherit;
    z-index: -1;
    border-radius: inherit;
}

/* -------------------------------------------------------
   SECTION UTILITIES
   Additional helper classes
------------------------------------------------------- */
.section-gray {
    background: #f8f9fa;
}

.section-white {
    background: #fff;
}

.section-header {
    text-align: center;
    margin-bottom: 3rem;
}

.section-header h2 {
    font-size: 2.5rem;
    font-weight: 900;
    color: var(--clr-dark);
    margin-bottom: 1rem;
    line-height: 1.2;
}

.section-header p {
    font-size: 1.15rem;
    color: var(--clr-muted);
    max-width: 700px;
    margin: 0 auto;
    line-height: 1.7;
}
