/*
 Theme Name:   KBStudio Child
 Theme URI:    https://kbstudio.it
 Description:  GeneratePress child theme for KBStudio - Bilingual Consulting Website (IT/EN)
 Author:       Kristijan Boros
 Author URI:   https://kbstudio.it
 Template:     generatepress
 Version:      1.6.0
 License:      GNU General Public License v2 or later
 License URI:  https://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  kbstudio-child
*/

/* ==========================================================================
   CSS Custom Properties - Navy & White Palette
   ========================================================================== */

:root {
    /* Primary Colors */
    --kbs-navy: #0A1628;
    --kbs-navy-light: #1B2A4A;
    --kbs-navy-dark: #060F1C;
    --kbs-white: #FFFFFF;
    --kbs-off-white: #F8F9FA;

    /* Accent */
    --kbs-accent: #2563EB;
    --kbs-accent-hover: #1D4ED8;

    /* Neutral */
    --kbs-gray-100: #F3F4F6;
    --kbs-gray-200: #E5E7EB;
    --kbs-gray-300: #D1D5DB;
    --kbs-gray-500: #6B7280;
    --kbs-gray-700: #374151;
    --kbs-gray-900: #111827;

    /* Typography */
    --kbs-font-primary: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --kbs-font-heading: 'Plus Jakarta Sans', var(--kbs-font-primary);

    /* Spacing */
    --kbs-section-padding: clamp(4rem, 8vw, 8rem);
    --kbs-container-width: 1200px;
}

/* ==========================================================================
   Base Styles
   ========================================================================== */

body {
    font-family: var(--kbs-font-primary);
    color: var(--kbs-gray-900);
    background-color: var(--kbs-white);
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--kbs-font-heading);
    color: var(--kbs-navy);
    font-weight: 700;
}

/* ==========================================================================
   Section Base
   ========================================================================== */

.kbs-section {
    padding: var(--kbs-section-padding) 0;
}

.kbs-section--navy {
    background-color: var(--kbs-navy);
    color: var(--kbs-white);
}

.kbs-section--navy h2,
.kbs-section--navy h3 {
    color: var(--kbs-white);
}

.kbs-section--light {
    background-color: var(--kbs-off-white);
}

.kbs-container {
    max-width: var(--kbs-container-width);
    margin: 0 auto;
    padding: 0 1.5rem;
}

/* ==========================================================================
   Section: Hero / Chi Sono
   ========================================================================== */

.kbs-hero {
    min-height: 80vh;
    display: flex;
    align-items: center;
    background-color: var(--kbs-navy);
    color: var(--kbs-white);
}

.kbs-hero h1 {
    color: var(--kbs-white);
    font-size: clamp(2.5rem, 5vw, 4rem);
    line-height: 1.1;
    margin-bottom: 1.5rem;
}

.kbs-hero p {
    font-size: clamp(1.125rem, 2vw, 1.25rem);
    color: var(--kbs-gray-300);
    max-width: 600px;
}

/* ==========================================================================
   Badges & Tags
   ========================================================================== */

.kbs-hero__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1.5rem;
}

.kbs-badge {
    display: inline-block;
    padding: 0.375rem 0.875rem;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    background: rgba(37, 99, 235, 0.15);
    color: var(--kbs-accent);
    border: 1px solid rgba(37, 99, 235, 0.3);
    border-radius: 2rem;
}

.kbs-service-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--kbs-gray-200);
}

.kbs-tag {
    display: inline-block;
    padding: 0.25rem 0.625rem;
    font-size: 0.6875rem;
    font-weight: 600;
    color: var(--kbs-gray-700);
    background: var(--kbs-gray-100);
    border-radius: 0.25rem;
}

/* ==========================================================================
   Case Study Metrics
   ========================================================================== */

.kbs-case-card__metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.kbs-metric {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--kbs-accent);
    background: rgba(37, 99, 235, 0.08);
    border-radius: 0.25rem;
}

/* ==========================================================================
   Section: Servizi
   ========================================================================== */

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

.kbs-service-card {
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.75rem;
    padding: 2rem;
    transition: box-shadow 0.3s ease, transform 0.2s ease;
}

.kbs-service-card:hover {
    box-shadow: 0 10px 40px rgba(10, 22, 40, 0.1);
    transform: translateY(-2px);
}

/* ==========================================================================
   Section: Case Studies
   ========================================================================== */

.kbs-case-studies-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 2rem;
}

.kbs-case-card {
    border-radius: 0.75rem;
    overflow: hidden;
    background: var(--kbs-white);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.kbs-case-card__image {
    aspect-ratio: 16 / 9;
    object-fit: cover;
    width: 100%;
}

.kbs-case-card__content {
    padding: 1.5rem;
}

/* ==========================================================================
   Section: Testimonials
   ========================================================================== */

.kbs-testimonial {
    background: var(--kbs-white);
    border-left: 4px solid var(--kbs-accent);
    padding: 2rem;
    border-radius: 0 0.75rem 0.75rem 0;
    margin-bottom: 1.5rem;
}

.kbs-testimonial__quote {
    font-size: 1.125rem;
    font-style: italic;
    color: var(--kbs-gray-700);
    margin-bottom: 1rem;
}

.kbs-testimonial__author {
    font-weight: 600;
    color: var(--kbs-navy);
}

/* ==========================================================================
   Section: Contatti
   ========================================================================== */

.kbs-contact-form input,
.kbs-contact-form textarea {
    width: 100%;
    padding: 0.875rem 1rem;
    border: 1px solid var(--kbs-gray-300);
    border-radius: 0.5rem;
    font-family: var(--kbs-font-primary);
    font-size: 1rem;
    transition: border-color 0.2s ease;
}

.kbs-contact-form input:focus,
.kbs-contact-form textarea:focus {
    outline: none;
    border-color: var(--kbs-accent);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

/* ==========================================================================
   Buttons
   ========================================================================== */

.kbs-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.875rem 2rem;
    border-radius: 0.5rem;
    font-weight: 600;
    font-size: 1rem;
    text-decoration: none;
    transition: all 0.2s ease;
    cursor: pointer;
    border: none;
}

.kbs-btn--primary {
    background-color: var(--kbs-accent);
    color: var(--kbs-white);
}

.kbs-btn--primary:hover {
    background-color: var(--kbs-accent-hover);
}

.kbs-btn--outline {
    background: transparent;
    border: 2px solid var(--kbs-white);
    color: var(--kbs-white);
}

.kbs-btn--outline:hover {
    background: var(--kbs-white);
    color: var(--kbs-navy);
}

/* ==========================================================================
   Language Switcher
   ========================================================================== */

.kbs-lang-switcher {
    display: flex;
    gap: 0.25rem;
    align-items: center;
    margin-left: auto;
}

/* ----- Polylang native output (renders <ul>) ----- */

.kbs-lang-switcher ul {
    display: flex;
    gap: 0.25rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.kbs-lang-switcher li {
    margin: 0;
}

.kbs-lang-switcher li a {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.625rem;
    font-size: 0.8125rem;
    font-weight: 600;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-radius: 0.375rem;
    color: var(--kbs-gray-500);
    background: transparent;
    border: 1px solid transparent;
    transition: all 0.2s ease;
}

.kbs-lang-switcher li.current-lang a,
.kbs-lang-switcher li a:hover {
    color: var(--kbs-navy);
    background: var(--kbs-gray-100);
    border-color: var(--kbs-gray-200);
}

/* Polylang flag images */
.kbs-lang-switcher li a img {
    width: 20px;
    height: 15px;
    border-radius: 2px;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
    vertical-align: middle;
}

/* ----- Fallback: custom SVG flags output ----- */

.kbs-lang-switcher__link {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.625rem;
    font-size: 0.8125rem;
    font-weight: 600;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-radius: 0.375rem;
    color: var(--kbs-gray-500);
    background: transparent;
    border: 1px solid transparent;
    transition: all 0.2s ease;
}

.kbs-lang-switcher__link:hover,
.kbs-lang-switcher__link.active {
    color: var(--kbs-navy);
    background: var(--kbs-gray-100);
    border-color: var(--kbs-gray-200);
}

.kbs-flag {
    width: 20px;
    height: 15px;
    border-radius: 2px;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
    flex-shrink: 0;
}

/* ----- Dark background context (hero, navy sections) ----- */

.kbs-section--navy .kbs-lang-switcher li a,
.kbs-section--navy .kbs-lang-switcher__link {
    color: var(--kbs-gray-300);
}

.kbs-section--navy .kbs-lang-switcher li.current-lang a,
.kbs-section--navy .kbs-lang-switcher li a:hover,
.kbs-section--navy .kbs-lang-switcher__link.active,
.kbs-section--navy .kbs-lang-switcher__link:hover {
    color: var(--kbs-white);
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
}

/* ----- Header positioning (GeneratePress) ----- */

.site-header .kbs-lang-switcher {
    position: absolute;
    right: 1.5rem;
    top: 50%;
    transform: translateY(-50%);
    z-index: 100;
}

/* ==========================================================================
   Responsive
   ========================================================================== */

/* ==========================================================================
   Section Headers
   ========================================================================== */

.kbs-section__header {
    text-align: center;
    margin-bottom: 3rem;
}

.kbs-section__title {
    font-size: clamp(2rem, 4vw, 2.75rem);
    margin-bottom: 0.75rem;
}

.kbs-section__desc {
    font-size: 1.125rem;
    color: var(--kbs-gray-500);
    max-width: 600px;
    margin: 0 auto;
}

.kbs-section--navy .kbs-section__desc {
    color: var(--kbs-gray-300);
}

.kbs-section__footer {
    text-align: center;
    margin-top: 3rem;
}

/* ==========================================================================
   Hero Grid
   ========================================================================== */

.kbs-hero__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}

.kbs-hero__eyebrow {
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--kbs-accent);
    margin-bottom: 1rem;
}

.kbs-hero__actions {
    display: flex;
    gap: 1rem;
    margin-top: 2rem;
    flex-wrap: wrap;
}

/* ==========================================================================
   Case Study Cards (extended)
   ========================================================================== */

.kbs-case-card__category {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--kbs-accent);
    margin-bottom: 0.5rem;
}

.kbs-case-card__title {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
}

.kbs-case-card__excerpt {
    color: var(--kbs-gray-500);
    font-size: 0.9375rem;
    margin-bottom: 1rem;
}

.kbs-case-card__link {
    font-weight: 600;
    color: var(--kbs-accent);
    text-decoration: none;
    font-size: 0.9375rem;
}

.kbs-case-card__link:hover {
    color: var(--kbs-accent-hover);
}

/* ==========================================================================
   Blog Grid
   ========================================================================== */

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

.kbs-blog-card {
    background: var(--kbs-white);
    border-radius: 0.75rem;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    transition: box-shadow 0.3s ease, transform 0.2s ease;
}

.kbs-blog-card:hover {
    box-shadow: 0 10px 40px rgba(10, 22, 40, 0.1);
    transform: translateY(-2px);
}

.kbs-blog-card__image {
    aspect-ratio: 16 / 9;
    object-fit: cover;
    width: 100%;
}

.kbs-blog-card__content {
    padding: 1.5rem;
}

.kbs-blog-card__date {
    font-size: 0.8125rem;
    color: var(--kbs-gray-500);
    display: block;
    margin-bottom: 0.5rem;
}

.kbs-blog-card__title {
    font-size: 1.125rem;
    margin-bottom: 0.5rem;
}

.kbs-blog-card__title a {
    color: var(--kbs-navy);
    text-decoration: none;
}

.kbs-blog-card__title a:hover {
    color: var(--kbs-accent);
}

.kbs-blog-card__excerpt {
    color: var(--kbs-gray-500);
    font-size: 0.9375rem;
    margin-bottom: 1rem;
}

.kbs-blog-card__link {
    font-weight: 600;
    color: var(--kbs-accent);
    text-decoration: none;
    font-size: 0.9375rem;
}

.kbs-blog-empty {
    text-align: center;
    color: var(--kbs-gray-500);
    font-size: 1.125rem;
}

/* ==========================================================================
   Testimonials Grid
   ========================================================================== */

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

.kbs-testimonial__footer {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.kbs-testimonial__avatar {
    border-radius: 50%;
    object-fit: cover;
}

.kbs-testimonial__role {
    display: block;
    font-size: 0.875rem;
    color: var(--kbs-gray-500);
}

/* ==========================================================================
   Contact Grid
   ========================================================================== */

.kbs-contact-grid {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 4rem;
    align-items: start;
}

.kbs-contact-info__item {
    margin-bottom: 2rem;
}

.kbs-contact-info__item h3 {
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--kbs-gray-500);
    margin-bottom: 0.25rem;
}

.kbs-contact-info__item a {
    color: var(--kbs-navy);
    text-decoration: none;
    font-weight: 500;
}

.kbs-contact-info__item a:hover {
    color: var(--kbs-accent);
}

.kbs-form-group {
    margin-bottom: 1.25rem;
}

.kbs-form-group label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--kbs-gray-700);
    margin-bottom: 0.375rem;
}

/* ==========================================================================
   Page Hero (standalone pages)
   ========================================================================== */

.kbs-page-hero {
    padding: var(--kbs-section-padding) 0;
    text-align: center;
}

.kbs-page-hero__title {
    color: var(--kbs-white);
    font-size: clamp(2.25rem, 4vw, 3rem);
    margin-bottom: 0.75rem;
}

.kbs-page-hero__subtitle {
    color: var(--kbs-gray-300);
    font-size: 1.125rem;
    max-width: 640px;
    margin: 0 auto;
}

/* ==========================================================================
   About Grid
   ========================================================================== */

.kbs-about-grid {
    display: grid;
    grid-template-columns: 3fr 2fr;
    gap: 4rem;
    align-items: start;
}

.kbs-about-portrait {
    border-radius: 0.75rem;
    width: 100%;
    height: auto;
}

/* ==========================================================================
   Expertise Grid
   ========================================================================== */

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

.kbs-expertise-card {
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.75rem;
    padding: 1.5rem;
}

.kbs-expertise-card h3 {
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--kbs-accent);
    margin-bottom: 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid var(--kbs-accent);
}

.kbs-expertise-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.kbs-expertise-card li {
    padding: 0.375rem 0;
    font-size: 0.9375rem;
    color: var(--kbs-gray-700);
    border-bottom: 1px solid var(--kbs-gray-100);
}

.kbs-expertise-card li:last-child {
    border-bottom: none;
}

/* ==========================================================================
   AI Pillars (About Page)
   ========================================================================== */

.kbs-ai-pillars {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 2rem;
}

.kbs-ai-pillar {
    padding: 2rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.03);
    transition: background 0.3s ease, border-color 0.3s ease;
}

.kbs-ai-pillar:hover {
    background: rgba(255, 255, 255, 0.06);
    border-color: var(--kbs-accent);
}

.kbs-ai-pillar__number {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--kbs-accent);
    letter-spacing: 0.1em;
    margin-bottom: 1rem;
}

.kbs-ai-pillar__title {
    font-size: 1.25rem;
    color: var(--kbs-white);
    margin-bottom: 0.75rem;
}

.kbs-ai-pillar__desc {
    font-size: 0.9375rem;
    color: var(--kbs-gray-300);
    line-height: 1.6;
}

/* ==========================================================================
   Scroll Animations
   ========================================================================== */

.kbs-animate {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease calc(var(--delay, 0s)),
                transform 0.6s ease calc(var(--delay, 0s));
}

.kbs-animate--visible {
    opacity: 1;
    transform: translateY(0);
}

/* ==========================================================================
   Full-width templates - chirurgico, solo content area
   ==========================================================================
   IMPORTANTE: NON tocchiamo .grid-container globalmente perché GeneratePress
   lo usa per header/menu/footer. Lasciamo l'header/footer normali e usiamo
   il trick `100vw` SOLO sulle sezioni KBS per farle uscire full-bleed.
   ========================================================================== */

/* Prevent the 100vw trick from causing horizontal scrollbar */
html.kbs-no-overflow,
body.kbs-fullwidth-template {
    overflow-x: hidden;
}

/* Reset only the inside-article + entry-content padding/margin (so our sections
   start flush with the GP content area, no awkward top spacing). */
.kbs-fullwidth-template .inside-article {
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
}

.kbs-fullwidth-template .entry-content {
    margin: 0;
    padding: 0;
}

.kbs-fullwidth-template .entry-content > * {
    margin-top: 0;
    margin-bottom: 0;
}

/* Hide WordPress page title (templates render their own hero). */
.kbs-fullwidth-template .entry-header,
.kbs-fullwidth-template .page-header,
.kbs-fullwidth-template .entry-title {
    display: none;
}

/* Remove the vertical separator GeneratePress draws between articles. */
.kbs-fullwidth-template .separate-containers .inside-article {
    margin-bottom: 0;
}

/* Trim the site-content vertical padding so the navy hero starts flush. */
.kbs-fullwidth-template .site-content,
.kbs-fullwidth-template .site-content > .grid-container {
    padding-top: 0;
    padding-bottom: 0;
}

/* The KEY trick: extend SECTION BACKGROUND beyond container without touching
   element layout. We use a giant inset box-shadow (matching section background)
   plus clip-path to mask vertically. Element stays put, background bleeds. */

.kbs-fullwidth-template .kbs-page-hero,
.kbs-fullwidth-template .kbs-hero,
.kbs-fullwidth-template .kbs-section--navy {
    box-shadow: 0 0 0 100vmax var(--kbs-navy);
    -webkit-clip-path: inset(0 -100vmax);
    clip-path: inset(0 -100vmax);
}

.kbs-fullwidth-template .kbs-section--light,
.kbs-fullwidth-template .kbs-einv-filter-bar {
    box-shadow: 0 0 0 100vmax var(--kbs-off-white);
    -webkit-clip-path: inset(0 -100vmax);
    clip-path: inset(0 -100vmax);
}

.kbs-fullwidth-template .kbs-einv-sources {
    box-shadow: 0 0 0 100vmax var(--kbs-navy-dark);
    -webkit-clip-path: inset(0 -100vmax);
    clip-path: inset(0 -100vmax);
}

/* Sticky filter bar needs higher specificity to keep its sticky positioning. */
.kbs-fullwidth-template .kbs-einv-filter-bar {
    position: sticky;
    top: 0;
    z-index: 10;
}

/* Inner container keeps its 1200px constraint and horizontal padding. */
.kbs-fullwidth-template .kbs-container {
    max-width: var(--kbs-container-width);
    margin-left: auto;
    margin-right: auto;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    box-sizing: border-box;
}

/* On larger screens give a bit more side breathing room. */
@media (min-width: 1280px) {
    .kbs-fullwidth-template .kbs-container {
        padding-left: 2rem;
        padding-right: 2rem;
    }
}

/* ==========================================================================
   Front Page Teasers Grid
   ========================================================================== */

.kbs-teasers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
}

.kbs-teaser {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 2rem;
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.75rem;
    text-decoration: none;
    color: inherit;
    transition: all 0.25s ease;
}

.kbs-teaser:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 32px rgba(10, 22, 40, 0.08);
    border-color: var(--kbs-accent);
}

.kbs-teaser h3 {
    font-size: 1.25rem;
    color: var(--kbs-navy);
    margin: 0;
}

.kbs-teaser p {
    font-size: 0.9375rem;
    color: var(--kbs-gray-500);
    margin: 0;
    flex-grow: 1;
}

.kbs-teaser__link {
    font-weight: 600;
    color: var(--kbs-accent);
    font-size: 0.9375rem;
    margin-top: auto;
}

.kbs-teaser--feature {
    background: linear-gradient(135deg, var(--kbs-navy) 0%, var(--kbs-navy-light) 100%);
    border-color: var(--kbs-navy);
    color: var(--kbs-white);
}

.kbs-teaser--feature h3,
.kbs-teaser--feature p {
    color: var(--kbs-white);
}

.kbs-teaser--feature .kbs-teaser__link {
    color: #93C5FD;
}

/* ==========================================================================
   CTA Band
   ========================================================================== */

.kbs-cta-band {
    text-align: center;
}

.kbs-cta-band h2 {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    margin-bottom: 1rem;
}

.kbs-cta-band p {
    color: var(--kbs-gray-300);
    max-width: 640px;
    margin: 0 auto 2rem;
    font-size: 1.125rem;
}

/* ==========================================================================
   Compliance Hub
   ========================================================================== */

.kbs-compliance-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.5rem;
}

.kbs-compliance-card {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 2rem;
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.75rem;
    text-decoration: none;
    color: inherit;
    transition: all 0.25s ease;
    position: relative;
}

a.kbs-compliance-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 32px rgba(10, 22, 40, 0.08);
    border-color: var(--kbs-accent);
}

.kbs-compliance-card__tag {
    align-self: flex-start;
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.25rem 0.625rem;
    border-radius: 0.25rem;
    background: rgba(37, 99, 235, 0.1);
    color: var(--kbs-accent);
}

.kbs-compliance-card--placeholder {
    opacity: 0.65;
}

.kbs-compliance-card--placeholder .kbs-compliance-card__tag {
    background: var(--kbs-gray-100);
    color: var(--kbs-gray-500);
}

.kbs-compliance-card h3 {
    font-size: 1.25rem;
    color: var(--kbs-navy);
    margin: 0;
}

.kbs-compliance-card p {
    font-size: 0.9375rem;
    color: var(--kbs-gray-500);
    margin: 0;
    flex-grow: 1;
}

.kbs-compliance-card__link {
    font-weight: 600;
    color: var(--kbs-accent);
    font-size: 0.9375rem;
}

/* ==========================================================================
   Electronic Invoicing Atlas
   ========================================================================== */

.kbs-einv-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1.5rem;
    margin: 2.5rem auto 0;
    max-width: 960px;
}

.kbs-einv-stat {
    padding: 1.25rem 1.5rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 0.75rem;
}

.kbs-einv-stat__value {
    display: block;
    font-family: var(--kbs-font-heading);
    font-size: 2rem;
    font-weight: 800;
    color: var(--kbs-white);
    line-height: 1;
    margin-bottom: 0.5rem;
}

.kbs-einv-stat__label {
    font-size: 0.8125rem;
    color: var(--kbs-gray-300);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
}

/* ----- Filter bar ----- */

.kbs-einv-filter-bar {
    position: sticky;
    top: 0;
    z-index: 10;
    background: var(--kbs-white);
    border-bottom: 1px solid var(--kbs-gray-200);
    padding: 1.25rem 0;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.kbs-einv-controls {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.kbs-einv-search {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--kbs-gray-300);
    border-radius: 0.5rem;
    font-size: 0.9375rem;
    font-family: inherit;
    transition: all 0.2s ease;
}

.kbs-einv-search:focus {
    outline: none;
    border-color: var(--kbs-accent);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.kbs-einv-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
}

.kbs-einv-tab {
    padding: 0.5rem 1rem;
    background: var(--kbs-gray-100);
    border: 1px solid transparent;
    border-radius: 2rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--kbs-gray-700);
    cursor: pointer;
    font-family: inherit;
    transition: all 0.2s ease;
}

.kbs-einv-tab:hover {
    background: var(--kbs-gray-200);
}

.kbs-einv-tab.is-active {
    background: var(--kbs-navy);
    color: var(--kbs-white);
    border-color: var(--kbs-navy);
}

.kbs-einv-statuses {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.kbs-einv-status-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.375rem 0.75rem;
    background: var(--kbs-gray-100);
    border-radius: 0.375rem;
    font-size: 0.8125rem;
    font-weight: 600;
    cursor: pointer;
    user-select: none;
    transition: all 0.2s ease;
}

.kbs-einv-status-toggle input {
    accent-color: var(--kbs-accent);
    cursor: pointer;
}

.kbs-einv-status-toggle:has(input:not(:checked)) {
    opacity: 0.45;
}

/* ----- Country grid ----- */

.kbs-einv-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 1.25rem;
}

.kbs-einv-card {
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.75rem;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    transition: all 0.2s ease;
}

.kbs-einv-card:hover {
    border-color: var(--kbs-accent);
    box-shadow: 0 8px 20px rgba(10, 22, 40, 0.06);
}

.kbs-einv-card[hidden] {
    display: none !important;
}

.kbs-einv-card__head {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--kbs-gray-100);
}

.kbs-einv-card__flag {
    font-size: 2.25rem;
    line-height: 1;
}

.kbs-einv-card__name {
    font-size: 1.125rem;
    margin: 0 0 0.25rem 0;
    color: var(--kbs-navy);
}

.kbs-einv-status {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.2rem 0.55rem;
    border-radius: 0.25rem;
}

.kbs-einv-status--mandatory { background: #DCFCE7; color: #166534; }
.kbs-einv-status--upcoming  { background: #FEF3C7; color: #92400E; }
.kbs-einv-status--voluntary { background: #DBEAFE; color: #1E40AF; }
.kbs-einv-status--planning  { background: #F3F4F6; color: #4B5563; }

.kbs-einv-card--mandatory { border-top: 3px solid #16A34A; }
.kbs-einv-card--upcoming  { border-top: 3px solid #F59E0B; }
.kbs-einv-card--voluntary { border-top: 3px solid #3B82F6; }
.kbs-einv-card--planning  { border-top: 3px solid #9CA3AF; }

.kbs-einv-card__data {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
    margin: 0;
}

.kbs-einv-card__data > div {
    display: grid;
    grid-template-columns: 90px 1fr;
    gap: 0.75rem;
    align-items: baseline;
    padding: 0.375rem 0;
    border-bottom: 1px dashed var(--kbs-gray-100);
}

.kbs-einv-card__data > div:last-child {
    border-bottom: none;
}

.kbs-einv-card__data dt {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--kbs-gray-500);
    margin: 0;
}

.kbs-einv-card__data dd {
    font-size: 0.875rem;
    color: var(--kbs-gray-900);
    margin: 0;
    line-height: 1.4;
}

.kbs-einv-card__notes {
    font-size: 0.8125rem;
    color: var(--kbs-gray-500);
    line-height: 1.55;
    padding-top: 0.75rem;
    border-top: 1px solid var(--kbs-gray-100);
    margin: 0;
}

.kbs-einv-empty {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--kbs-gray-500);
    font-size: 1rem;
}

/* ----- Sources ----- */

.kbs-einv-sources {
    background: var(--kbs-navy-dark);
    color: var(--kbs-white);
}

.kbs-einv-sources h2 {
    color: var(--kbs-white);
    margin-bottom: 0.75rem;
}

.kbs-einv-sources__intro {
    color: var(--kbs-gray-300);
    max-width: 720px;
    margin-bottom: 2rem;
}

.kbs-einv-sources__list {
    columns: 2;
    gap: 2rem;
    list-style: none;
    padding: 0;
    margin: 0 0 2rem 0;
}

.kbs-einv-sources__list li {
    margin-bottom: 0.625rem;
    break-inside: avoid;
}

.kbs-einv-sources__list a {
    color: #93C5FD;
    text-decoration: none;
    font-size: 0.9375rem;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s ease;
}

.kbs-einv-sources__list a:hover {
    border-bottom-color: #93C5FD;
}

.kbs-einv-sources__note {
    color: var(--kbs-gray-500);
    font-size: 0.8125rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

/* ==========================================================================
   E-Invoicing Card - clickable + footer
   ========================================================================== */

.kbs-einv-card {
    cursor: pointer;
    outline: none;
}

.kbs-einv-card:focus-visible {
    box-shadow: 0 0 0 3px var(--kbs-accent);
}

.kbs-einv-card__footer {
    margin-top: auto;
    padding-top: 0.75rem;
    border-top: 1px solid var(--kbs-gray-100);
}

.kbs-einv-card__more {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--kbs-accent);
}

.kbs-einv-roadmap-cta {
    margin: 2rem auto 0;
    padding: 1.125rem 2rem;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 0.5rem;
    color: var(--kbs-gray-300);
    font-size: 0.9375rem;
    max-width: 960px;
    text-align: center;
}

.kbs-einv-roadmap-cta a {
    color: #93C5FD;
    text-decoration: none;
}

.kbs-einv-roadmap-cta a:hover {
    text-decoration: underline;
}

/* ==========================================================================
   E-Invoicing Modal (country details popup)
   ========================================================================== */

.kbs-einv-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    animation: kbsFadeIn 0.2s ease;
}

.kbs-einv-modal[hidden] {
    display: none !important;
}

.kbs-einv-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 22, 40, 0.7);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.kbs-einv-modal__panel {
    position: relative;
    width: 100%;
    max-width: 720px;
    max-height: 90vh;
    background: var(--kbs-white);
    border-radius: 0.75rem;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.4);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    animation: kbsSlideUp 0.25s ease;
}

@keyframes kbsFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes kbsSlideUp {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}

.kbs-einv-modal__close {
    position: absolute;
    top: 0.875rem;
    right: 0.875rem;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: var(--kbs-gray-100);
    color: var(--kbs-gray-700);
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
    z-index: 2;
    transition: background 0.2s ease;
}

.kbs-einv-modal__close:hover {
    background: var(--kbs-gray-200);
}

.kbs-einv-modal__content {
    padding: 2rem 2rem 2.5rem;
    overflow-y: auto;
    flex: 1 1 auto;
}

/* ----- Modal: header ----- */

.kbs-einv-detail__head {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding-bottom: 1.25rem;
    margin-bottom: 1.5rem;
    border-bottom: 2px solid var(--kbs-gray-100);
}

.kbs-einv-detail__flag {
    font-size: 3rem;
    line-height: 1;
}

.kbs-einv-detail__title {
    font-size: 1.75rem;
    color: var(--kbs-navy);
    margin: 0 0 0.5rem 0;
    font-family: var(--kbs-font-heading);
    font-weight: 800;
}

.kbs-einv-detail__sub {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

/* ----- Modal: data sections ----- */

.kbs-einv-detail__section {
    margin-bottom: 1.5rem;
}

.kbs-einv-detail__section h4 {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--kbs-accent);
    margin: 0 0 0.5rem 0;
    padding-bottom: 0.375rem;
    border-bottom: 1px solid var(--kbs-gray-100);
}

.kbs-einv-detail__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0.875rem 1.5rem;
}

.kbs-einv-detail__field {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.kbs-einv-detail__field dt {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--kbs-gray-500);
    margin: 0;
}

.kbs-einv-detail__field dd {
    font-size: 0.9375rem;
    color: var(--kbs-gray-900);
    margin: 0;
    line-height: 1.45;
}

.kbs-einv-detail__text {
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--kbs-gray-700);
    margin: 0;
}

.kbs-einv-detail__source {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--kbs-gray-100);
}

.kbs-einv-detail__source a {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    color: var(--kbs-accent);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.875rem;
    word-break: break-all;
}

.kbs-einv-detail__source a:hover {
    color: var(--kbs-accent-hover);
    text-decoration: underline;
}

@media (max-width: 600px) {
    .kbs-einv-modal__content {
        padding: 1.5rem 1.25rem 2rem;
    }
    .kbs-einv-detail__title {
        font-size: 1.375rem;
    }
}

/* ==========================================================================
   E-Invoicing Roadmap Timeline
   ========================================================================== */

.kbs-roadmap-intro {
    max-width: 800px;
    margin: 0 auto 3rem;
    text-align: center;
    color: var(--kbs-gray-500);
    font-size: 1.0625rem;
    line-height: 1.6;
}

.kbs-roadmap-legend {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
    margin: 0 auto 2.5rem;
}

.kbs-roadmap-legend__item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8125rem;
    color: var(--kbs-gray-700);
    font-weight: 500;
}

.kbs-roadmap-legend__dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
}

.kbs-roadmap-legend__dot--mandatory { background: #16A34A; }
.kbs-roadmap-legend__dot--upcoming  { background: #F59E0B; }
.kbs-roadmap-legend__dot--planning  { background: #6366F1; }
.kbs-roadmap-legend__dot--vida      { background: #DB2777; }

.kbs-roadmap {
    position: relative;
    max-width: 1140px;
    margin: 0 auto;
    padding: 1rem 0;
    width: 100%;
    box-sizing: border-box;
}

.kbs-roadmap::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 3px;
    background: linear-gradient(180deg, var(--kbs-accent) 0%, var(--kbs-navy-light) 100%);
    transform: translateX(-50%);
    border-radius: 3px;
}

.kbs-roadmap-year {
    position: relative;
    margin-bottom: 3rem;
}

.kbs-roadmap-year__label {
    position: relative;
    z-index: 2;
    display: block;
    width: 96px;
    margin: 0 auto 1.5rem;
    padding: 0.5rem 0;
    text-align: center;
    background: var(--kbs-navy);
    color: var(--kbs-white);
    font-family: var(--kbs-font-heading);
    font-weight: 800;
    font-size: 1.125rem;
    border-radius: 2rem;
    box-shadow: 0 4px 12px rgba(10, 22, 40, 0.2);
}

.kbs-roadmap-year--current .kbs-roadmap-year__label {
    background: var(--kbs-accent);
    box-shadow: 0 4px 16px rgba(37, 99, 235, 0.4);
}

.kbs-roadmap-quarter {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 80px 1fr;
    gap: 1rem;
    align-items: center;
    margin-bottom: 1rem;
}

.kbs-roadmap-quarter__label {
    grid-column: 2;
    text-align: center;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--kbs-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    background: var(--kbs-white);
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
    border: 1px solid var(--kbs-gray-200);
    z-index: 1;
}

.kbs-roadmap-event {
    position: relative;
    padding: 1rem 1.25rem;
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.625rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.kbs-roadmap-event:hover {
    box-shadow: 0 8px 20px rgba(10, 22, 40, 0.08);
    transform: translateY(-2px);
}

.kbs-roadmap-event--left {
    grid-column: 1;
    text-align: right;
}

.kbs-roadmap-event--right {
    grid-column: 3;
    text-align: left;
}

/* Connector dots */
.kbs-roadmap-event::after {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--kbs-accent);
    border: 3px solid var(--kbs-white);
    box-shadow: 0 0 0 1px var(--kbs-gray-200);
}

.kbs-roadmap-event--left::after  { right: -1.5rem; }
.kbs-roadmap-event--right::after { left:  -1.5rem; }

.kbs-roadmap-event--mandatory { border-left: 4px solid #16A34A; }
.kbs-roadmap-event--mandatory.kbs-roadmap-event--right { border-left: none; border-right: 4px solid #16A34A; }
.kbs-roadmap-event--mandatory::after { background: #16A34A; }

.kbs-roadmap-event--upcoming { border-left: 4px solid #F59E0B; }
.kbs-roadmap-event--upcoming.kbs-roadmap-event--right { border-left: none; border-right: 4px solid #F59E0B; }
.kbs-roadmap-event--upcoming::after { background: #F59E0B; }

.kbs-roadmap-event--planning { border-left: 4px solid #6366F1; }
.kbs-roadmap-event--planning.kbs-roadmap-event--right { border-left: none; border-right: 4px solid #6366F1; }
.kbs-roadmap-event--planning::after { background: #6366F1; }

.kbs-roadmap-event--vida { border-left: 4px solid #DB2777; background: linear-gradient(135deg, #FFFFFF 0%, #FDF2F8 100%); }
.kbs-roadmap-event--vida.kbs-roadmap-event--right { border-left: none; border-right: 4px solid #DB2777; }
.kbs-roadmap-event--vida::after { background: #DB2777; }

.kbs-roadmap-event__country {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--kbs-navy);
    margin-bottom: 0.375rem;
}

.kbs-roadmap-event__flag {
    font-size: 1.25rem;
    line-height: 1;
}

.kbs-roadmap-event__title {
    font-size: 0.9375rem;
    color: var(--kbs-gray-900);
    margin: 0 0 0.25rem 0;
    font-weight: 600;
    line-height: 1.35;
}

.kbs-roadmap-event__detail {
    font-size: 0.8125rem;
    color: var(--kbs-gray-500);
    line-height: 1.45;
    margin: 0;
}

/* Mobile: collapse to single column */
@media (max-width: 768px) {
    .kbs-roadmap::before {
        left: 24px;
    }
    .kbs-roadmap-year__label {
        margin-left: 0;
        margin-right: auto;
    }
    .kbs-roadmap-quarter {
        grid-template-columns: 80px 1fr;
        gap: 0.75rem;
    }
    .kbs-roadmap-quarter__label {
        grid-column: 1;
    }
    .kbs-roadmap-event--left,
    .kbs-roadmap-event--right {
        grid-column: 2;
        text-align: left;
        border-left: 4px solid var(--kbs-accent);
        border-right: none;
    }
    .kbs-roadmap-event--left::after,
    .kbs-roadmap-event--right::after {
        left: -1.45rem;
        right: auto;
    }
    .kbs-roadmap-event--mandatory.kbs-roadmap-event--right { border-right: none; border-left: 4px solid #16A34A; }
    .kbs-roadmap-event--upcoming.kbs-roadmap-event--right  { border-right: none; border-left: 4px solid #F59E0B; }
    .kbs-roadmap-event--planning.kbs-roadmap-event--right  { border-right: none; border-left: 4px solid #6366F1; }
    .kbs-roadmap-event--vida.kbs-roadmap-event--right      { border-right: none; border-left: 4px solid #DB2777; }
}

/* ==========================================================================
   Legal Pages (Privacy Policy, Cookie Policy)
   ========================================================================== */

.kbs-container--narrow {
    max-width: 760px;
}

.kbs-prose {
    font-size: 1rem;
    line-height: 1.75;
    color: var(--kbs-gray-700);
}

.kbs-prose h2 {
    font-size: 1.5rem;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--kbs-gray-100);
    color: var(--kbs-navy);
}

.kbs-prose h2:first-child {
    margin-top: 0;
}

.kbs-prose h3 {
    font-size: 1.125rem;
    margin-top: 1.75rem;
    margin-bottom: 0.625rem;
    color: var(--kbs-navy);
}

.kbs-prose p {
    margin: 0 0 1rem 0;
}

.kbs-prose p:has(em) {
    color: var(--kbs-gray-500);
    font-size: 0.875rem;
    border-left: 3px solid var(--kbs-accent);
    padding: 0.5rem 0 0.5rem 1rem;
    background: var(--kbs-gray-100);
    border-radius: 0 0.25rem 0.25rem 0;
}

.kbs-prose ul,
.kbs-prose ol {
    margin: 0 0 1.25rem 1.5rem;
    padding: 0;
}

.kbs-prose li {
    margin-bottom: 0.5rem;
}

.kbs-prose a {
    color: var(--kbs-accent);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.kbs-prose a:hover {
    color: var(--kbs-accent-hover);
}

.kbs-prose strong {
    color: var(--kbs-navy);
    font-weight: 600;
}

.kbs-prose__back {
    margin-top: 3rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--kbs-gray-200);
    font-size: 0.9375rem;
}

.kbs-prose__back a {
    color: var(--kbs-gray-500);
    text-decoration: none;
    font-weight: 500;
}

.kbs-prose__back a:hover {
    color: var(--kbs-accent);
}

/* CookieYes audit table inside the prose */
.kbs-prose .cky-audit-table,
.kbs-prose .cky-audit-table-element {
    margin: 1.5rem 0;
    border-radius: 0.5rem;
    overflow: hidden;
    border: 1px solid var(--kbs-gray-200);
}

.kbs-prose .cky-audit-table th {
    background: var(--kbs-navy) !important;
    color: var(--kbs-white) !important;
    font-weight: 600;
    text-align: left;
    padding: 0.75rem 1rem !important;
}

.kbs-prose .cky-audit-table td {
    padding: 0.75rem 1rem !important;
    font-size: 0.9375rem;
    border-bottom: 1px solid var(--kbs-gray-100);
}

/* ==========================================================================
   Sticky Compact Header - always visible, ~50px tall
   ==========================================================================
   Reduces GeneratePress default header (~70-80px) to a single thin row
   (~50px), pinned to the top of the viewport on scroll.
   The Atlas filter bar is offset accordingly so the two stack cleanly.
   ========================================================================== */

:root {
    --kbs-header-height: 50px;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--kbs-white);
    border-bottom: 1px solid var(--kbs-gray-200);
    transition: box-shadow 0.2s ease;
}

/* Subtle shadow appears once content scrolls underneath */
.site-header::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -6px;
    height: 6px;
    background: linear-gradient(180deg, rgba(10,22,40,0.06) 0%, rgba(10,22,40,0) 100%);
    pointer-events: none;
}

/* Compact inside-header: tight vertical padding so total height ~50px */
.site-header .inside-header {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
    min-height: 0 !important;
    align-items: center;
}

/* Brand: smaller title, hide tagline */
.site-header .main-title {
    font-size: 1.125rem !important;
    line-height: 1 !important;
    margin: 0 !important;
}
.site-header .main-title a {
    line-height: 1 !important;
}

.site-header .site-description {
    display: none !important;
}

/* Custom logo image stays compact */
.site-header .header-image,
.site-header .site-logo img {
    max-height: 34px !important;
    width: auto !important;
}

/* Compact navigation: thinner menu items */
.main-navigation .main-nav > ul > li > a {
    line-height: var(--kbs-header-height) !important;
    padding: 0 1rem !important;
    height: var(--kbs-header-height) !important;
}

/* Dropdown submenu items keep their natural height */
.main-navigation .main-nav ul ul a {
    line-height: 1.4 !important;
    height: auto !important;
}

/* Mobile menu toggle stays vertically centered */
.main-navigation .menu-toggle {
    line-height: var(--kbs-header-height) !important;
    height: var(--kbs-header-height) !important;
    padding: 0 1rem !important;
}

/* Account for WP admin bar (logged-in users only) */
.admin-bar .site-header {
    top: 32px;
}

@media (max-width: 782px) {
    .admin-bar .site-header {
        top: 46px;
    }
}

/* Atlas filter bar must sit BELOW the sticky header */
.kbs-einv-filter-bar {
    top: var(--kbs-header-height) !important;
    z-index: 90 !important;
}

.admin-bar .kbs-einv-filter-bar {
    top: calc(var(--kbs-header-height) + 32px) !important;
}

@media (max-width: 782px) {
    .admin-bar .kbs-einv-filter-bar {
        top: calc(var(--kbs-header-height) + 46px) !important;
    }
}

/* Smooth scroll-to-anchor with offset for the sticky header */
html {
    scroll-padding-top: calc(var(--kbs-header-height) + 1rem);
}

.admin-bar {
    scroll-padding-top: calc(var(--kbs-header-height) + 32px + 1rem);
}

/* ==========================================================================
   Footer - copyright + legal links (Privacy, Cookie, Manage)
   ========================================================================== */

.site-info .copyright,
.site-info .kbs-footer__brand {
    display: block;
    margin-bottom: 0.5rem;
}

.kbs-footer__legal {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: var(--kbs-gray-500);
}

.kbs-footer__legal a {
    color: var(--kbs-gray-500);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s ease, color 0.2s ease;
}

.kbs-footer__legal a:hover {
    color: var(--kbs-accent);
    border-bottom-color: var(--kbs-accent);
}

.kbs-footer__legal span[aria-hidden="true"] {
    color: var(--kbs-gray-300);
}

.kbs-cookie-manage {
    cursor: pointer;
}

/* ==========================================================================
   E-Invoicing Fundamentals - educational page
   ========================================================================== */

.kbs-fund-section {
    padding-top: 4rem;
    padding-bottom: 4rem;
}

/* Table of contents */
.kbs-fund-toc {
    max-width: 720px;
    margin: 0 auto;
    padding: 2rem;
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.kbs-fund-toc__title {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--kbs-accent);
    margin: 0 0 1rem 0;
    font-weight: 700;
}

.kbs-fund-toc__list {
    list-style: none;
    counter-reset: toc;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
}

.kbs-fund-toc__list li {
    counter-increment: toc;
    position: relative;
    padding-left: 2.5rem;
    font-size: 0.9375rem;
    line-height: 1.5;
}

.kbs-fund-toc__list li::before {
    content: counter(toc, decimal-leading-zero);
    position: absolute;
    left: 0;
    top: 0;
    font-weight: 700;
    font-family: var(--kbs-font-heading);
    color: var(--kbs-accent);
    font-size: 0.875rem;
}

.kbs-fund-toc__list a {
    color: var(--kbs-navy);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s ease;
}

.kbs-fund-toc__list a:hover {
    border-bottom-color: var(--kbs-accent);
    color: var(--kbs-accent);
}

/* Numbered content blocks - fill container width like other pages */
.kbs-fund-block {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 2rem;
    align-items: start;
    width: 100%;
}

.kbs-fund-block__num {
    font-family: var(--kbs-font-heading);
    font-weight: 800;
    font-size: 3.5rem;
    line-height: 1;
    color: var(--kbs-accent);
    opacity: 0.2;
    text-align: right;
    padding-top: 0.25rem;
}

.kbs-fund-block h2 {
    margin-top: 0;
    margin-bottom: 1rem;
    font-size: clamp(1.625rem, 3vw, 2.125rem);
}

.kbs-fund-block h3 {
    font-size: 1.25rem;
    margin: 0 0 0.5rem 0;
}

.kbs-fund-block p {
    color: var(--kbs-gray-700);
    line-height: 1.7;
    font-size: 1rem;
    margin-bottom: 1.25rem;
}

@media (max-width: 768px) {
    .kbs-fund-block {
        grid-template-columns: 1fr;
        gap: 0.5rem;
    }
    .kbs-fund-block__num {
        text-align: left;
        font-size: 2.5rem;
    }
}

/* Comparison: not e-invoice vs true e-invoice */
.kbs-fund-comparison {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
    margin: 2rem 0;
}

.kbs-fund-comparison__item {
    padding: 1.5rem;
    border-radius: 0.625rem;
    border: 1px solid var(--kbs-gray-200);
}

.kbs-fund-comparison__item h4 {
    font-size: 0.8125rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 0 0 1rem 0;
    padding-bottom: 0.625rem;
    border-bottom: 2px solid;
}

.kbs-fund-comparison__item--bad {
    background: #FEF2F2;
    border-color: #FECACA;
}
.kbs-fund-comparison__item--bad h4 {
    color: #B91C1C;
    border-bottom-color: #FCA5A5;
}

.kbs-fund-comparison__item--good {
    background: #ECFDF5;
    border-color: #A7F3D0;
}
.kbs-fund-comparison__item--good h4 {
    color: #047857;
    border-bottom-color: #6EE7B7;
}

.kbs-fund-comparison__item ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.kbs-fund-comparison__item li {
    padding: 0.375rem 0;
    font-size: 0.9375rem;
    color: var(--kbs-gray-900);
}

/* Drivers grid */
.kbs-fund-drivers {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.25rem;
    margin: 2rem 0;
}

.kbs-fund-driver {
    padding: 1.5rem;
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.625rem;
}

.kbs-fund-driver h4 {
    font-size: 1rem;
    color: var(--kbs-navy);
    margin: 0 0 0.625rem 0;
}

.kbs-fund-driver p {
    font-size: 0.875rem;
    color: var(--kbs-gray-500);
    line-height: 1.55;
    margin: 0;
}

/* 6-step flow */
.kbs-fund-flow {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem;
    margin: 2rem 0;
    counter-reset: flow;
}

.kbs-fund-flow__step {
    position: relative;
    padding: 1.5rem 1.25rem 1.25rem;
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.625rem;
    border-left: 3px solid var(--kbs-accent);
}

.kbs-fund-flow__num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--kbs-accent);
    color: var(--kbs-white);
    font-weight: 700;
    font-size: 0.8125rem;
    margin-bottom: 0.75rem;
    font-family: var(--kbs-font-heading);
}

.kbs-fund-flow__step h4 {
    font-size: 1rem;
    color: var(--kbs-navy);
    margin: 0 0 0.5rem 0;
}

.kbs-fund-flow__step p {
    font-size: 0.875rem;
    color: var(--kbs-gray-500);
    margin: 0;
    line-height: 1.55;
}

/* Network models */
.kbs-fund-model {
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.875rem;
    padding: 2rem;
    margin: 1.5rem 0;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.kbs-fund-model__head {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.kbs-fund-model__head h3 {
    margin: 0;
    font-size: 1.375rem;
}

.kbs-fund-model__tag {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
    padding: 0.25rem 0.625rem;
    border-radius: 0.25rem;
    background: rgba(37, 99, 235, 0.1);
    color: var(--kbs-accent);
}

.kbs-fund-model__intro {
    font-size: 0.9375rem;
    color: var(--kbs-gray-700);
    line-height: 1.65;
    margin: 0 0 1.5rem 0;
}

.kbs-fund-model__meta {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--kbs-gray-100);
    font-size: 0.875rem;
    color: var(--kbs-gray-700);
    display: grid;
    gap: 0.5rem;
    line-height: 1.55;
}

/* SVG diagram container */
.kbs-diagram {
    background: linear-gradient(180deg, #F8FAFC 0%, #F1F5F9 100%);
    border-radius: 0.625rem;
    padding: 1.5rem 1rem;
    margin: 0 0 1rem 0;
    overflow-x: auto;
}

.kbs-diagram svg {
    display: block;
    width: 100%;
    height: auto;
    max-height: 320px;
    margin: 0 auto;
    font-family: var(--kbs-font-primary);
}

.kbs-diagram__node rect {
    fill: var(--kbs-white);
    stroke: var(--kbs-gray-300);
    stroke-width: 1.5;
}

.kbs-diagram__node--corner rect {
    fill: #DBEAFE;
    stroke: #2563EB;
}

.kbs-diagram__node--ap rect {
    fill: #FEF3C7;
    stroke: #D97706;
}

.kbs-diagram__node--ta rect {
    fill: #FCE7F3;
    stroke: #DB2777;
}

.kbs-diagram__node text {
    font-size: 14px;
    font-weight: 600;
    fill: var(--kbs-navy);
}

.kbs-diagram__sub {
    font-size: 11px !important;
    font-weight: 500 !important;
    fill: var(--kbs-gray-500) !important;
}

.kbs-diagram__label {
    font-size: 12px;
    font-weight: 600;
    fill: var(--kbs-gray-700);
}

/* Networks */
.kbs-fund-networks {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 1.5rem;
    margin: 2rem 0;
}

.kbs-fund-network {
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.75rem;
    padding: 1.5rem;
}

.kbs-fund-network header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
    padding-bottom: 0.875rem;
    border-bottom: 1px solid var(--kbs-gray-100);
}

.kbs-fund-network h3 {
    font-size: 1.125rem;
    margin: 0;
}

.kbs-fund-network__scope {
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--kbs-gray-500);
}

.kbs-fund-network p {
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--kbs-gray-700);
    margin: 0 0 0.75rem 0;
}

.kbs-fund-network p:last-child {
    margin-bottom: 0;
}

/* Standards */
.kbs-fund-standards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1rem;
    margin: 2rem 0;
}

.kbs-fund-standard {
    padding: 1.25rem;
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.625rem;
    border-top: 3px solid var(--kbs-accent);
}

.kbs-fund-standard h4 {
    font-family: var(--kbs-font-heading);
    font-size: 1rem;
    color: var(--kbs-navy);
    margin: 0 0 0.625rem 0;
}

.kbs-fund-standard p {
    font-size: 0.875rem;
    color: var(--kbs-gray-700);
    line-height: 1.55;
    margin: 0;
}

/* ERP list */
.kbs-fund-erp-list {
    list-style: none;
    counter-reset: erp;
    padding: 0;
    margin: 1.5rem 0 1.5rem 0;
}

.kbs-fund-erp-list li {
    counter-increment: erp;
    position: relative;
    padding: 1.25rem 1.25rem 1.25rem 4rem;
    background: var(--kbs-white);
    border: 1px solid var(--kbs-gray-200);
    border-radius: 0.625rem;
    margin-bottom: 1rem;
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--kbs-gray-700);
}

.kbs-fund-erp-list li::before {
    content: counter(erp);
    position: absolute;
    left: 1rem;
    top: 1.25rem;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--kbs-accent);
    color: var(--kbs-white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-family: var(--kbs-font-heading);
}

.kbs-fund-erp-cta {
    margin-top: 2rem !important;
    padding: 1.25rem 1.5rem !important;
    background: linear-gradient(135deg, var(--kbs-navy) 0%, var(--kbs-navy-light) 100%);
    color: var(--kbs-white) !important;
    border-radius: 0.625rem;
    font-size: 1rem !important;
    line-height: 1.6 !important;
}

.kbs-fund-erp-cta strong {
    color: var(--kbs-white);
}

/* ==========================================================================
   Service card feature variant (AI/MCP highlight)
   ========================================================================== */

.kbs-service-card--feature {
    background: linear-gradient(135deg, var(--kbs-navy) 0%, var(--kbs-navy-light) 100%);
    border-color: var(--kbs-navy);
    color: var(--kbs-white);
}

.kbs-service-card--feature h3 {
    color: var(--kbs-white);
}

.kbs-service-card--feature p {
    color: var(--kbs-gray-300);
}

.kbs-service-card--feature .kbs-tag {
    background: rgba(255, 255, 255, 0.1);
    color: var(--kbs-white);
}

.kbs-service-card--feature .kbs-service-card__tags {
    border-top-color: rgba(255, 255, 255, 0.1);
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (min-width: 768px) {
    .kbs-einv-controls {
        flex-direction: row;
        align-items: center;
        flex-wrap: wrap;
    }
    .kbs-einv-search {
        flex: 1 1 280px;
        max-width: 320px;
    }
}

@media (max-width: 768px) {
    .kbs-einv-sources__list {
        columns: 1;
    }
}

@media (max-width: 1024px) {
    .kbs-hero__grid,
    .kbs-about-grid {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .kbs-hero__actions,
    .kbs-hero__badges {
        justify-content: center;
    }

    .kbs-hero__image {
        display: none;
    }

    .kbs-contact-grid {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
}

@media (max-width: 768px) {
    .kbs-services-grid,
    .kbs-case-studies-grid,
    .kbs-blog-grid,
    .kbs-testimonials-grid {
        grid-template-columns: 1fr;
    }
}
