/* ==========================================================================
   Kancelaria Barański — PREMIUM main.css
   Cormorant Garamond + Inter / Navy + Gold
   ========================================================================== */

:root {
    --kb-primary: #1B2A4A;
    --kb-primary-light: #243558;
    --kb-primary-dark: #111D33;
    --kb-accent: #C8A85C;
    --kb-accent-hover: #D4B76A;
    --kb-gold: #b49146;
    --kb-dark: #0F1923;
    --kb-bg: #F7F5F0;
    --kb-bg-alt: #EDE9E0;
    --kb-white: #FFFFFF;
    --kb-text: #2D2D2D;
    --kb-text-light: #6B7280;
    --kb-border: #D6D0C4;

    --font-display: 'Cormorant Garamond', Georgia, serif;
    --font-body: 'Inter', -apple-system, sans-serif;
    --fs-h1: clamp(2.25rem, 1.93rem + 1.57vw, 3.5rem);
    --fs-h2: clamp(1.75rem, 1.5rem + 1.1vw, 2.5rem);
    --fs-h3: clamp(1.1875rem, 1.1rem + 0.4vw, 1.4375rem);
    --fs-body: clamp(0.9375rem, 0.92rem + 0.1vw, 1rem);
    --fs-small: 0.8125rem;

    --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem; --space-4: 1rem;
    --space-6: 1.5rem; --space-8: 2rem; --space-10: 2.5rem; --space-12: 3rem;
    --space-16: 4rem; --space-20: 5rem;

    --section-sm: clamp(2.5rem, 5vw, 4rem);
    --section-md: clamp(3.5rem, 7vw, 5.5rem);
    --section-lg: clamp(4rem, 8vw, 7rem);

    --shadow-sm: 0 1px 3px rgba(15,25,35,0.08);
    --shadow-md: 0 4px 12px rgba(15,25,35,0.1);
    --shadow-lg: 0 12px 32px rgba(15,25,35,0.14);
    --shadow-xl: 0 20px 50px rgba(15,25,35,0.18);

    --radius: 4px;
    --radius-lg: 12px;
    --ease: cubic-bezier(0.25, 1, 0.5, 1);
    --dur-fast: 150ms; --dur-base: 200ms; --dur-slow: 300ms;
    --topbar-h: 36px;
    --header-h: 80px;
}

/* ==================== TOP BAR ==================== */
.kb-topbar {
    position: fixed; top: 0; left: 0; right: 0; z-index: 101;
    height: var(--topbar-h);
    background: var(--kb-primary-dark);
    border-bottom: 1px solid rgba(200,168,92,0.1);
    transition: transform var(--dur-slow) var(--ease);
}
.kb-topbar.hidden { transform: translateY(-100%); }
.kb-topbar__inner {
    display: flex; justify-content: space-between; align-items: center;
    height: 100%; font-size: 0.6875rem; color: rgba(255,255,255,0.55);
}
.kb-topbar__left, .kb-topbar__right { display: flex; align-items: center; gap: var(--space-6); }
.kb-topbar__item {
    display: inline-flex; align-items: center; gap: var(--space-2);
    white-space: nowrap; letter-spacing: 0.02em;
}
.kb-topbar__item svg { opacity: 0.5; color: var(--kb-accent); }
a.kb-topbar__item:hover { color: var(--kb-accent); }
a.kb-topbar__item:hover svg { opacity: 1; }

/* SKIP LINK (accessibility) */
.kb-skip-link {
    position: absolute; top: -100%; left: var(--space-4);
    padding: var(--space-2) var(--space-4);
    background: var(--kb-accent); color: var(--kb-dark);
    font-weight: 600; font-size: 0.875rem;
    z-index: 10000; border-radius: 0 0 var(--radius) var(--radius);
    transition: top var(--dur-fast);
}
.kb-skip-link:focus {
    top: 0;
}

/* RESET */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + var(--topbar-h)); }
body {
    font-family: var(--font-body);
    font-size: var(--fs-body);
    line-height: 1.75;
    color: var(--kb-text);
    background: var(--kb-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color var(--dur-base) var(--ease); }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, textarea, select { font-family: inherit; font-size: inherit; }

/* ==================== LAW BACKGROUND DECORATIONS ==================== */
/* Subtle repeating § pattern across entire page */
body::after {
    content: '';
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background-image: url("data:image/svg+xml,%3Csvg width='120' height='160' viewBox='0 0 120 160' xmlns='http://www.w3.org/2000/svg'%3E%3Ctext x='60' y='90' font-family='Georgia,serif' font-size='28' font-weight='300' fill='%231B2A4A' text-anchor='middle' opacity='0.012'%3E§%3C/text%3E%3C/svg%3E");
    pointer-events: none; z-index: 0;
}
body > * { position: relative; z-index: 1; }

/* TYPOGRAPHY */
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 600; line-height: 1.15; color: var(--kb-primary); }
.kb-h1 { font-size: var(--fs-h1); }
.kb-h2 { font-size: var(--fs-h2); margin-bottom: var(--space-6); }
.kb-h3 { font-size: var(--fs-h3); margin-bottom: var(--space-4); }
p { margin-bottom: var(--space-4); max-width: 65ch; text-align: justify; text-justify: inter-word; }
p:last-child { margin-bottom: 0; }
strong { font-weight: 600; }

/* LAYOUT */
.kb-container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 var(--space-6); }
.kb-container--narrow { max-width: 800px; }
.kb-section { padding: var(--section-md) 0; }
.kb-section--dark { background: var(--kb-primary); color: var(--kb-white); }
.kb-section--dark h2, .kb-section--dark h3 { color: var(--kb-white); }
.kb-section--alt { background: var(--kb-white); }
.kb-section__header { text-align: center; margin-bottom: var(--space-12); }
.kb-section__footer { text-align: center; margin-top: var(--space-8); }
.kb-label {
    display: inline-block; font-size: 0.6875rem; font-weight: 600;
    letter-spacing: 0.22em; text-transform: uppercase; color: var(--kb-accent);
    margin-bottom: var(--space-3);
}

/* BUTTONS */
.kb-btn {
    display: inline-flex; align-items: center; gap: var(--space-2);
    padding: 0.75rem 1.75rem; font-size: 0.75rem; font-weight: 600;
    letter-spacing: 0.08em; text-transform: uppercase;
    border-radius: var(--radius); transition: all var(--dur-base) var(--ease);
    background: var(--kb-primary); color: var(--kb-white); border: 2px solid var(--kb-primary);
}
.kb-btn:hover { background: var(--kb-primary-light); border-color: var(--kb-primary-light); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.kb-btn--accent { background: var(--kb-accent); border-color: var(--kb-accent); color: var(--kb-dark); }
.kb-btn--accent:hover { background: var(--kb-accent-hover); border-color: var(--kb-accent-hover); }
.kb-btn--outline { background: transparent; border-color: rgba(255,255,255,0.4); color: var(--kb-white); }
.kb-btn--outline:hover { background: var(--kb-white); color: var(--kb-primary); border-color: var(--kb-white); }
.kb-btn--sm { padding: 0.5rem 1.25rem; font-size: 0.6875rem; }
.kb-btn--outline-gold {
    background: transparent; border: 2px solid var(--kb-accent); color: var(--kb-accent);
    position: relative; overflow: hidden; z-index: 1;
}
.kb-btn--outline-gold::before {
    content: ''; position: absolute; inset: 0; background: var(--kb-accent);
    transform: scaleX(0); transform-origin: left; transition: transform 0.4s var(--ease); z-index: -1;
}
.kb-btn--outline-gold:hover { color: var(--kb-dark); }
.kb-btn--outline-gold:hover::before { transform: scaleX(1); }
.kb-btn--outline-gold:hover svg { transform: translateX(4px); }
.kb-btn--outline-gold svg { transition: transform var(--dur-base) var(--ease); }

/* Arrow link */
.kb-arrow-link {
    display: inline-flex; align-items: center; gap: var(--space-3);
    font-weight: 600; font-size: 0.75rem; color: var(--kb-accent);
    text-transform: uppercase; letter-spacing: 0.08em;
    margin-top: var(--space-6); transition: gap var(--dur-base) var(--ease);
}
.kb-arrow-link:hover { gap: var(--space-4); }
.kb-arrow-link__icon { display: flex; }

/* ==================== PRELOADER ==================== */
.kb-preloader {
    position: fixed; inset: 0; z-index: 9999;
    background: var(--kb-dark);
    display: flex; align-items: center; justify-content: center;
    transition: opacity 0.5s ease, visibility 0.5s ease;
}
.kb-preloader.loaded { opacity: 0; visibility: hidden; pointer-events: none; }
.kb-preloader__inner { width: 80px; height: 2px; background: rgba(255,255,255,0.1); border-radius: 2px; overflow: hidden; }
.kb-preloader__bar { width: 40%; height: 100%; background: var(--kb-accent); border-radius: 2px; animation: preload 0.8s ease infinite; }
@keyframes preload { 0% { transform: translateX(-100%); } 100% { transform: translateX(350%); } }

/* ==================== HEADER ==================== */
.kb-header {
    position: fixed; top: var(--topbar-h); left: 0; right: 0; z-index: 100;
    height: var(--header-h);
    background: rgba(255,255,255,0.97);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid transparent;
    transition: all var(--dur-slow) var(--ease);
}
.kb-header.scrolled { top: 0; height: 68px; border-bottom-color: var(--kb-border); box-shadow: var(--shadow-sm); }
.kb-header__inner { display: flex; align-items: center; justify-content: space-between; height: 100%; }
.kb-header__logo { display: flex; align-items: center; gap: var(--space-3); }
.kb-header__logo img { width: 42px; height: auto; border-radius: 6px; }
.kb-header__logo-text { line-height: 1.2; }
.kb-header__logo-text strong { display: block; font-size: 1.0625rem; color: var(--kb-primary); font-family: var(--font-display); font-weight: 700; }
.kb-header__logo-text small { font-size: 0.6875rem; color: var(--kb-text-light); letter-spacing: 0.1em; text-transform: uppercase; }
.kb-nav { display: flex; align-items: center; gap: var(--space-8); }
.kb-nav__list { display: flex; gap: var(--space-6); }
.kb-nav__link {
    font-size: 0.8125rem; font-weight: 500; color: var(--kb-text);
    padding: var(--space-2) 0; position: relative; letter-spacing: 0.02em;
}
.kb-nav__link::after {
    content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 2px;
    background: var(--kb-accent); transition: width var(--dur-base) var(--ease);
}
.kb-nav__link:hover::after, .kb-nav__link--active::after { width: 100%; }
.kb-nav__link--active { color: var(--kb-primary); font-weight: 600; }
.kb-nav__cta { margin-left: var(--space-4); }
.kb-hamburger {
    display: none; width: 44px; height: 44px; flex-direction: column;
    justify-content: center; align-items: center; gap: 6px; z-index: 110;
}
.kb-hamburger span { display: block; width: 24px; height: 2px; background: var(--kb-primary); transition: all var(--dur-base) var(--ease); border-radius: 1px; }
.kb-hamburger.active span:nth-child(1) { transform: translateY(8px) rotate(45deg); background: var(--kb-white); }
.kb-hamburger.active span:nth-child(2) { opacity: 0; }
.kb-hamburger.active span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); background: var(--kb-white); }

/* Mobile menu */
.kb-mobile-menu {
    position: fixed; inset: 0; z-index: 105; background: var(--kb-dark);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; visibility: hidden; transition: all var(--dur-slow) var(--ease);
}
.kb-mobile-menu.active { opacity: 1; visibility: visible; }
.kb-mobile-menu__list { text-align: center; }
.kb-mobile-menu__list li { margin-bottom: var(--space-8); }
.kb-mobile-menu__link {
    font-family: var(--font-display); font-size: clamp(2rem, 5.5vw, 3.25rem);
    font-weight: 500; color: var(--kb-white);
    opacity: 0; transform: translateY(20px); transition: all 0.5s var(--ease);
}
.kb-mobile-menu.active .kb-mobile-menu__link { opacity: 1; transform: translateY(0); }
.kb-mobile-menu__list li:nth-child(1) .kb-mobile-menu__link { transition-delay: 0.1s; }
.kb-mobile-menu__list li:nth-child(2) .kb-mobile-menu__link { transition-delay: 0.15s; }
.kb-mobile-menu__list li:nth-child(3) .kb-mobile-menu__link { transition-delay: 0.2s; }
.kb-mobile-menu__list li:nth-child(4) .kb-mobile-menu__link { transition-delay: 0.25s; }
.kb-mobile-menu__list li:nth-child(5) .kb-mobile-menu__link { transition-delay: 0.3s; }
.kb-mobile-menu__link:hover { color: var(--kb-accent); }
.kb-mobile-menu__contact { text-align: center; margin-top: var(--space-12); opacity: 0; transition: opacity 0.5s var(--ease) 0.35s; }
.kb-mobile-menu.active .kb-mobile-menu__contact { opacity: 1; }

/* ==================== HERO v5 — Dark + Panel ==================== */
.kb-hero {
    position: relative;
    background: var(--kb-dark);
    padding-top: calc(var(--header-h) + var(--topbar-h));
    overflow: hidden;
}

/* Rich layered dark background */
.kb-hero__bg {
    position: absolute; inset: 0; z-index: 0;
    background:
        radial-gradient(ellipse at 25% 50%, rgba(27,42,74,0.6) 0%, transparent 55%),
        radial-gradient(ellipse at 75% 25%, rgba(200,168,92,0.05) 0%, transparent 45%),
        radial-gradient(ellipse at 50% 100%, rgba(27,42,74,0.3) 0%, transparent 50%),
        linear-gradient(160deg, #060A12 0%, #0E1721 25%, #152238 55%, #0C1320 100%);
}
.kb-hero__bg::before {
    content: ''; position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(200,168,92,0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(200,168,92,0.02) 1px, transparent 1px);
    background-size: 60px 60px;
}

.kb-hero__inner {
    position: relative; z-index: 2;
    width: 100%; max-width: 1200px; margin: 0 auto;
    padding: clamp(2.5rem, 5vw, 4.5rem) var(--space-6) clamp(2rem, 3vw, 2.5rem);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(2rem, 3vw, 3rem);
    align-items: center;
}

/* Content block */
.kb-hero__content {
    animation: heroFadeIn 0.7s ease-out 0.2s both;
}
@keyframes heroFadeIn {
    from { opacity: 0; transform: translateY(16px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Tag with gold line */
.kb-hero__tag {
    display: inline-flex; align-items: center; gap: 0.75rem;
    font-size: 0.6875rem; font-weight: 600;
    letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--kb-accent);
    margin-bottom: var(--space-6);
}
.kb-hero__tag-line {
    display: block; width: 2rem; height: 1px;
    background: var(--kb-accent); opacity: 0.6;
}

/* Heading */
.kb-hero__heading { margin-bottom: var(--space-6); }

.kb-hero__h-bold {
    display: block;
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 2rem + 2.2vw, 4rem);
    font-weight: 700;
    color: #FFFFFF;
    line-height: 1.08;
    letter-spacing: -0.015em;
}

.kb-hero__h-rule {
    display: block;
    width: 56px; height: 2px;
    background: linear-gradient(90deg, var(--kb-accent), rgba(200,168,92,0.15));
    margin: var(--space-4) 0;
}

.kb-hero__h-light {
    display: block;
    font-family: var(--font-display);
    font-size: clamp(1.25rem, 1.1rem + 0.5vw, 1.625rem);
    font-weight: 400;
    font-style: italic;
    color: var(--kb-accent);
    line-height: 1.35;
    opacity: 0.9;
}

/* Description */
.kb-hero__desc {
    font-size: clamp(0.9375rem, 0.92rem + 0.1vw, 1rem);
    color: rgba(255,255,255,0.7);
    line-height: 1.85;
    margin-top: var(--space-2);
    margin-bottom: var(--space-8);
    max-width: 480px;
    letter-spacing: 0.015em;
}

/* Actions */
.kb-hero__actions {
    display: flex; gap: var(--space-4); align-items: center;
}

.kb-hero__phone {
    display: inline-flex; align-items: center; gap: var(--space-2);
    font-size: 0.9375rem; font-weight: 500; color: rgba(255,255,255,0.7);
    transition: color var(--dur-base) var(--ease);
}
.kb-hero__phone:hover { color: var(--kb-accent); }
.kb-hero__phone svg { opacity: 0.5; }

/* ── Right: Specializations panel ──────────────────────────────────────── */
.kb-hero__panel {
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 4px;
    padding: clamp(1.5rem, 2.2vw, 2rem);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    animation: heroFadeIn 0.7s ease-out 0.4s both;
    position: relative;
    overflow: hidden;
    align-self: center;
}
/* Subtle gold gradient top edge */
.kb-hero__panel::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, var(--kb-accent), rgba(200,168,92,0.2), transparent);
}

.kb-hero__panel-header {
    display: flex; align-items: center; gap: 0.75rem;
    margin-bottom: 1.25rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}

.kb-hero__panel-symbol {
    font-family: var(--font-display);
    font-size: 2.25rem; font-weight: 700;
    color: var(--kb-accent); opacity: 0.6;
    line-height: 1;
}

.kb-hero__panel-label {
    display: block;
    font-size: 0.8125rem; font-weight: 600;
    letter-spacing: 0.15em; text-transform: uppercase;
    color: #fff;
}

.kb-hero__panel-sublabel {
    display: block;
    font-size: 0.6875rem; font-weight: 400;
    color: rgba(255,255,255,0.4);
    letter-spacing: 0.05em;
    margin-top: 0.2rem;
}

/* Specialization items */
.kb-hero__panel-list {
    display: flex; flex-direction: column;
    gap: 0;
    margin-bottom: 1.25rem;
}

.kb-hero__panel-item {
    display: flex; align-items: center; gap: 0.75rem;
    padding: 0.65rem 0;
    border-bottom: 1px solid rgba(255,255,255,0.04);
    transition: background var(--dur-base) var(--ease);
}
.kb-hero__panel-item:last-child { border-bottom: none; }
.kb-hero__panel-item:hover { background: rgba(255,255,255,0.02); }

.kb-hero__panel-item-icon {
    display: flex; align-items: center; justify-content: center;
    width: 20px; height: 20px;
    color: var(--kb-accent); opacity: 0.75;
    flex-shrink: 0;
}

.kb-hero__panel-item-name {
    font-family: var(--font-display);
    font-size: 1.0625rem; font-weight: 500;
    color: rgba(255,255,255,0.92);
    line-height: 1.3;
}

/* Panel footer — location */
.kb-hero__panel-footer {
    display: flex; align-items: center; gap: 0.5rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255,255,255,0.06);
    font-size: 0.6875rem; font-weight: 500;
    color: rgba(255,255,255,0.35);
    text-transform: uppercase; letter-spacing: 0.1em;
}
.kb-hero__panel-footer svg { color: var(--kb-accent); opacity: 0.5; }
.kb-hero__panel-dot { opacity: 0.4; }

/* ── Stats strip — full grid width ─────────────────────────────────────── */
.kb-hero__stats {
    grid-column: 1 / -1;
    display: flex; align-items: center; gap: var(--space-8);
    padding-top: var(--space-6);
    border-top: 1px solid rgba(255,255,255,0.08);
    animation: heroFadeIn 0.7s ease-out 0.55s both;
}
.kb-hero__stat-num {
    display: block; font-family: var(--font-display);
    font-size: clamp(1.625rem, 2vw, 2.125rem);
    font-weight: 600; color: #FFFFFF; line-height: 1;
    letter-spacing: 0.02em;
}
.kb-hero__stat-label {
    display: block; font-size: 0.625rem; color: rgba(255,255,255,0.4);
    text-transform: uppercase; letter-spacing: 0.12em; margin-top: 0.3rem;
    font-weight: 500;
}
.kb-hero__stat-sep {
    width: 1px; height: 32px;
    background: linear-gradient(180deg, rgba(255,255,255,0.15), rgba(255,255,255,0.04));
}

/* Abstract scales SVG — decorative art */
.kb-hero__art {
    position: absolute;
    right: clamp(3rem, 12vw, 14rem);
    top: 50%;
    transform: translateY(-50%);
    width: clamp(10rem, 14vw, 16rem);
    color: rgba(200,168,92,0.06);
    z-index: 1;
    pointer-events: none;
    user-select: none;
}
.kb-hero__art svg {
    width: 100%; height: auto;
}

/* Floating law decorations */
.kb-hero__deco {
    position: absolute; z-index: 1; pointer-events: none; color: rgba(200,168,92,0.06);
}
.kb-hero__deco--book {
    left: 3%; bottom: 15%; opacity: 0.7;
    animation: heroFloat 12s ease-in-out infinite;
}
.kb-hero__deco--paragraph {
    right: 8%; top: 18%;
    font-family: Georgia, serif; font-size: 6rem; font-weight: 600;
    color: rgba(200,168,92,0.035); line-height: 1;
    animation: heroFloat 15s ease-in-out infinite reverse;
}
.kb-hero__deco--columns {
    left: 8%; top: 20%; opacity: 0.7;
    animation: heroFloat 18s ease-in-out infinite;
}
.kb-hero__deco--gavel {
    right: 3%; bottom: 20%; opacity: 0.8;
    animation: heroFloat 14s ease-in-out infinite reverse;
}
@keyframes heroFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-12px); }
}

/* bounceY kept for potential re-use */
@keyframes bounceY { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(5px); } }

/* ==================== SPECS PREVIEW (dark glassmorphism) ==================== */
.kb-specs-preview {
    position: relative;
    padding: var(--section-lg) 0;
    overflow: hidden;
    isolation: isolate;
}
.kb-specs-preview__bg {
    position: absolute; inset: 0; z-index: -1;
    background: linear-gradient(135deg, #0b1120 0%, #0f1829 35%, #0d1a2e 60%, #0a1018 100%);
}
.kb-specs-preview__bg::before {
    content: ''; position: absolute; inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
    opacity: 0.5;
}
.kb-specs-preview__bg::after {
    content: ''; position: absolute; top: -20%; left: 50%; transform: translateX(-50%);
    width: 70%; height: 60%;
    background: radial-gradient(ellipse at center, rgba(180, 145, 70, 0.07) 0%, transparent 70%);
    pointer-events: none;
}
.kb-specs-preview__header { text-align: center; margin-bottom: clamp(2rem, 4vw, 3.5rem); }
.kb-specs-preview__label-row { display: flex; align-items: center; justify-content: center; gap: 1rem; margin-bottom: 1.25rem; }
.kb-specs-preview__label {
    font-family: var(--font-body, 'Inter', sans-serif); font-size: 0.6875rem; font-weight: 600;
    letter-spacing: 0.22em; text-transform: uppercase; color: var(--kb-gold, #b49146);
}
.kb-specs-preview__line { display: block; width: 3rem; height: 1px; background: linear-gradient(90deg, transparent, var(--kb-gold, #b49146), transparent); opacity: 0.6; }
.kb-specs-preview__heading {
    font-family: var(--font-display, 'Cormorant Garamond', serif);
    font-size: var(--fs-h2, clamp(1.75rem, 1.5rem + 1.1vw, 2.5rem));
    font-weight: 500; color: #fff; line-height: 1.15; letter-spacing: -0.01em; margin: 0;
}
.kb-specs-preview__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }
@media (max-width: 1024px) { .kb-specs-preview__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 599px)  { .kb-specs-preview__grid { grid-template-columns: 1fr; gap: 1rem; } }

/* Spec Card */
.kb-spec-card {
    position: relative; display: flex; flex-direction: column;
    padding: 1.5rem 1.5rem 1.75rem; border-radius: 2px;
    border: 1px solid rgba(255, 255, 255, 0.07);
    background: rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(12px) saturate(1.2);
    -webkit-backdrop-filter: blur(12px) saturate(1.2);
    overflow: hidden; cursor: default;
    transition: background var(--dur-slow) var(--ease), border-color var(--dur-slow) var(--ease), transform var(--dur-slow) var(--ease);
}
.kb-spec-card::before {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(160deg, rgba(180, 145, 70, 0.06) 0%, transparent 50%);
    opacity: 0; transition: opacity var(--dur-slow) var(--ease);
}
.kb-spec-card:hover { background: rgba(255, 255, 255, 0.07); border-color: rgba(180, 145, 70, 0.25); transform: translateY(-4px); }
.kb-spec-card:hover::before { opacity: 1; }
.kb-spec-card__number { font-family: var(--font-display, 'Cormorant Garamond', serif); font-size: 0.875rem; font-weight: 600; letter-spacing: 0.15em; color: var(--kb-gold, #b49146); margin-bottom: 0.75rem; opacity: 0.9; }
.kb-spec-card__icon { display: flex; align-items: center; width: 32px; height: 32px; margin-bottom: 0.75rem; color: var(--kb-gold, #b49146); transition: transform var(--dur-slow) var(--ease); }
.kb-spec-card:hover .kb-spec-card__icon { transform: scale(1.08); }
.kb-spec-card__name { font-family: var(--font-display, 'Cormorant Garamond', serif); font-size: clamp(1.125rem, 1.05rem + 0.35vw, 1.3125rem); font-weight: 600; color: #fff; line-height: 1.25; margin: 0 0 0.625rem; letter-spacing: 0.01em; flex-grow: 1; }
.kb-spec-card__desc { font-family: var(--font-body, 'Inter', sans-serif); font-size: 0.8125rem; line-height: 1.7; color: rgba(255, 255, 255, 0.5); margin: 0 0 1rem; }
.kb-spec-card__border { position: absolute; bottom: 0; left: 0; height: 2px; width: 2rem; background: linear-gradient(90deg, var(--kb-gold, #b49146), rgba(180, 145, 70, 0.4)); transition: width 0.4s cubic-bezier(0.25, 1, 0.5, 1); }
.kb-spec-card:hover .kb-spec-card__border { width: 100%; }

/* Specs Preview Footer CTA */
.kb-specs-preview__footer { display: flex; justify-content: center; margin-top: clamp(2rem, 4vw, 3rem); }
.kb-btn--outline-gold {
    display: inline-flex; align-items: center; gap: 0.6rem;
    padding: 0.8125rem 2.25rem;
    font-family: var(--font-body, 'Inter', sans-serif); font-size: 0.8125rem; font-weight: 600;
    letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--kb-gold, #b49146); border: 1px solid rgba(180, 145, 70, 0.45);
    background: transparent; border-radius: 1px; text-decoration: none;
    position: relative; overflow: hidden;
    transition: color var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease);
}
.kb-btn--outline-gold::before { content: ''; position: absolute; inset: 0; background: var(--kb-gold, #b49146); transform: scaleX(0); transform-origin: left; transition: transform 0.35s cubic-bezier(0.25, 1, 0.5, 1); z-index: -1; }
.kb-btn--outline-gold:hover { color: #0b1120; border-color: var(--kb-gold, #b49146); }
.kb-btn--outline-gold:hover::before { transform: scaleX(1); }
.kb-btn--outline-gold svg { transition: transform var(--dur-base) var(--ease); }
.kb-btn--outline-gold:hover svg { transform: translateX(4px); }

/* ==================== INTRO ==================== */
.kb-intro {
    position: relative; overflow: hidden;
}
/* Scales of justice watermark — intro background */
.kb-intro::before {
    content: '';
    position: absolute; bottom: -5%; right: -3%;
    width: 380px; height: 420px;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 440' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cline x1='200' y1='20' x2='200' y2='400' stroke='%231B2A4A' stroke-width='1.5'/%3E%3Cline x1='80' y1='80' x2='320' y2='80' stroke='%231B2A4A' stroke-width='1.2'/%3E%3Cline x1='95' y1='80' x2='75' y2='200' stroke='%231B2A4A' stroke-width='0.8'/%3E%3Cline x1='95' y1='80' x2='115' y2='200' stroke='%231B2A4A' stroke-width='0.8'/%3E%3Cline x1='305' y1='80' x2='285' y2='170' stroke='%231B2A4A' stroke-width='0.8'/%3E%3Cline x1='305' y1='80' x2='325' y2='170' stroke='%231B2A4A' stroke-width='0.8'/%3E%3Cpath d='M55 200 Q95 235 135 200' stroke='%231B2A4A' stroke-width='1.2' fill='none'/%3E%3Cpath d='M265 170 Q305 205 345 170' stroke='%231B2A4A' stroke-width='1.2' fill='none'/%3E%3Ccircle cx='200' cy='20' r='8' stroke='%231B2A4A' stroke-width='1' fill='none'/%3E%3Cline x1='150' y1='400' x2='250' y2='400' stroke='%231B2A4A' stroke-width='1.5'/%3E%3Cpath d='M170 400 L200 420 L230 400' stroke='%231B2A4A' stroke-width='1' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-size: contain;
    opacity: 0.025; pointer-events: none; z-index: 0;
}
/* Soft radial warmth top-left */
.kb-intro::after {
    content: ''; position: absolute;
    top: -10%; left: -10%;
    width: 500px; height: 500px;
    background: radial-gradient(ellipse, rgba(200,168,92,0.04) 0%, transparent 70%);
    pointer-events: none; z-index: 0;
}

.kb-intro__grid {
    display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-12);
    align-items: center; position: relative; z-index: 1;
}
.kb-intro__content {
    border-left: 2px solid var(--kb-accent); padding-left: var(--space-6);
}
.kb-intro__content .kb-h2 { margin-bottom: var(--space-4); letter-spacing: -0.01em; }
.kb-intro__content p { font-size: var(--fs-body); line-height: 1.75; color: var(--kb-text); }
.kb-intro__content .kb-arrow-link { margin-top: var(--space-4); }

/* Integrated photo — NOT a stock rectangle */
.kb-intro__visual { position: relative; }
.kb-intro__img-wrap {
    position: relative; overflow: hidden;
    border-radius: 2px 40px 2px 40px;
    aspect-ratio: 4/5; max-height: 480px;
}
.kb-intro__img-wrap img {
    width: 100%; height: 100%; object-fit: cover;
    object-position: center 20%;
    transition: filter 0.6s var(--ease);
}
.kb-intro__visual:hover .kb-intro__img-wrap img {
    filter: brightness(1.03);
}
/* Subtle tint overlay */
.kb-intro__img-tint {
    display: none;
}
/* Fade edges into section background */
.kb-intro__img-fade {
    position: absolute; inset: 0;
    background:
        linear-gradient(to right, var(--kb-bg) 0%, transparent 15%),
        linear-gradient(to left, var(--kb-bg) 0%, transparent 8%),
        linear-gradient(to bottom, var(--kb-bg) 0%, transparent 10%),
        linear-gradient(to top, var(--kb-bg) 0%, transparent 15%);
    pointer-events: none; z-index: 1;
}
/* Gold accent line — visual anchor */
.kb-intro__accent-line {
    position: absolute; left: -16px; top: 30px; bottom: 50px;
    width: 2px;
    background: linear-gradient(to bottom, transparent, var(--kb-accent) 20%, var(--kb-accent) 80%, transparent);
    opacity: 0.4;
}
/* Corner ornament */
.kb-intro__ornament {
    position: absolute; top: 10px; right: 10px; z-index: 2;
}

/* ==================== SPECS PREVIEW (inline styles from template) ==================== */
/* Additional overrides if needed — main styles are in the template <style> block */

/* ==================== TRUST ==================== */
/* Trust */
.kb-trust { background: var(--kb-bg); }
.kb-trust__values {
    display: flex; flex-wrap: wrap; justify-content: center; align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-10);
}
.kb-trust__val {
    font-size: var(--fs-body); font-weight: 600; color: var(--kb-primary);
}
.kb-trust__sep {
    width: 4px; height: 4px; border-radius: 50%; background: var(--kb-accent); opacity: 0.5;
    flex-shrink: 0;
}
.kb-trust__quote {
    max-width: 720px; margin: 0 auto;
    padding: var(--space-8) var(--space-10);
    border-left: 3px solid var(--kb-accent);
    background: var(--kb-white); border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
    box-shadow: var(--shadow-sm);
}
.kb-trust__quote p {
    font-family: var(--font-display); font-size: clamp(1.125rem, 1.05rem + 0.35vw, 1.375rem);
    font-weight: 500; font-style: italic; color: var(--kb-primary);
    line-height: 1.6; margin: 0 0 var(--space-3) 0; max-width: none;
}
.kb-trust__quote footer {
    font-size: var(--fs-small); color: var(--kb-text-light); font-style: normal;
}

/* ==================== OPINIE ==================== */
.kb-opinie { background: var(--kb-white); position: relative; overflow: hidden; }
/* Faint § watermark in opinie */
.kb-opinie::before {
    content: '§';
    position: absolute; top: -30px; right: 5%;
    font-family: var(--font-display); font-size: clamp(14rem, 20vw, 22rem);
    font-weight: 300; color: var(--kb-primary); opacity: 0.018;
    line-height: 1; pointer-events: none; z-index: 0;
}
.kb-opinie .kb-container { position: relative; z-index: 1; }
.kb-opinie__rating {
    display: flex; align-items: center; justify-content: center; gap: var(--space-3);
    margin-top: var(--space-4);
}
.kb-opinie__stars { display: flex; gap: 2px; }
.kb-opinie__score { font-size: var(--fs-small); font-weight: 600; color: var(--kb-text-light); }

.kb-opinie__grid {
    columns: 3; column-gap: var(--space-6);
}
.kb-opinie__card {
    background: var(--kb-bg); border-radius: var(--radius-lg);
    padding: var(--space-6); border: 1px solid var(--kb-border);
    display: inline-flex; flex-direction: column; width: 100%;
    break-inside: avoid; margin-bottom: var(--space-6);
    transition: all var(--dur-base) var(--ease);
}
.kb-opinie__card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); border-color: rgba(200,168,92,0.2); }
.kb-opinie__card-stars { display: flex; gap: 2px; margin-bottom: var(--space-3); }
.kb-opinie__card-text {
    font-size: var(--fs-body); line-height: 1.75; color: var(--kb-text);
    flex: 1; margin-bottom: var(--space-4); font-style: italic;
}
.kb-opinie__card-author {
    display: flex; align-items: center; gap: var(--space-3);
    padding-top: var(--space-4); border-top: 1px solid var(--kb-border);
}
.kb-opinie__card-avatar {
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--kb-primary); color: var(--kb-white);
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-display); font-size: 1rem; font-weight: 600;
    flex-shrink: 0;
}
.kb-opinie__card-author strong { display: block; font-size: var(--fs-small); color: var(--kb-primary); }
.kb-opinie__card-author small { display: block; font-size: 0.6875rem; color: var(--kb-text-light); }
.kb-opinie__card-google { margin-left: auto; opacity: 0.4; flex-shrink: 0; }

/* ==================== CTA ==================== */
.kb-cta {
    position: relative; padding: var(--section-lg) 0; overflow: hidden;
    background: linear-gradient(160deg, var(--kb-dark) 0%, #162238 40%, var(--kb-primary) 100%);
}
/* Diagonal crosshatch pattern */
.kb-cta::before {
    content: ''; position: absolute; inset: 0;
    background-image:
        linear-gradient(45deg, rgba(200,168,92,0.025) 1px, transparent 1px),
        linear-gradient(-45deg, rgba(200,168,92,0.025) 1px, transparent 1px),
        radial-gradient(rgba(200,168,92,0.04) 1px, transparent 1px);
    background-size: 50px 50px, 50px 50px, 32px 32px;
}
/* Large radial gold glow behind text */
.kb-cta::after {
    content: '';
    position: absolute;
    top: 50%; left: 50%; transform: translate(-50%, -50%);
    width: 700px; height: 500px;
    background: radial-gradient(ellipse, rgba(200,168,92,0.08) 0%, rgba(200,168,92,0.03) 40%, transparent 70%);
    pointer-events: none;
}
.kb-cta__inner { text-align: center; position: relative; z-index: 1; }

/* Gold ornamental lines above and below heading */
.kb-cta__inner::before,
.kb-cta__inner::after {
    content: '';
    display: block;
    width: 100px; height: 1px;
    background: linear-gradient(90deg, transparent, var(--kb-accent), transparent);
    margin: 0 auto;
    opacity: 0.5;
}
.kb-cta__inner::before { margin-bottom: var(--space-8); }
.kb-cta__inner::after { display: none; }

.kb-cta__heading {
    font-size: clamp(1.75rem, 1.4rem + 1.2vw, 2.5rem);
    color: var(--kb-white); margin-bottom: var(--space-4);
    position: relative;
    letter-spacing: -0.01em;
}
.kb-cta__text { color: rgba(255,255,255,0.55); max-width: 520px; margin: 0 auto var(--space-8); font-size: var(--fs-body); line-height: 1.8; letter-spacing: 0.01em; }
.kb-cta__actions { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; }

/* CTA decorative corner elements */
.kb-cta__corner {
    position: absolute;
    width: 80px; height: 80px;
    z-index: 1; pointer-events: none;
}
.kb-cta__corner--tl {
    top: var(--space-10); left: var(--space-10);
    border-top: 1px solid rgba(200,168,92,0.15);
    border-left: 1px solid rgba(200,168,92,0.15);
}
.kb-cta__corner--tl::after {
    content: '';
    position: absolute; top: -4px; left: -4px;
    width: 8px; height: 8px;
    background: var(--kb-accent); opacity: 0.3;
    transform: rotate(45deg);
}
.kb-cta__corner--br {
    bottom: var(--space-10); right: var(--space-10);
    border-bottom: 1px solid rgba(200,168,92,0.15);
    border-right: 1px solid rgba(200,168,92,0.15);
}
.kb-cta__corner--br::after {
    content: '';
    position: absolute; bottom: -4px; right: -4px;
    width: 8px; height: 8px;
    background: var(--kb-accent); opacity: 0.3;
    transform: rotate(45deg);
}

/* CTA floating decorations */
.kb-cta__deco {
    position: absolute; z-index: 0; pointer-events: none;
    color: rgba(200,168,92,0.06);
}
.kb-cta__deco--1 {
    top: 15%; left: 5%;
    font-family: Georgia, serif; font-size: 5rem; font-weight: 600;
    color: rgba(200,168,92,0.04); line-height: 1;
    animation: heroFloat 14s ease-in-out infinite;
}
.kb-cta__deco--2 {
    bottom: 12%; right: 8%; opacity: 0.8;
    animation: heroFloat 16s ease-in-out infinite reverse;
}
.kb-cta__deco--3 {
    top: 20%; right: 15%; opacity: 0.6;
    animation: heroFloat 18s ease-in-out infinite;
}
.kb-cta__deco--4 {
    bottom: 18%; left: 12%;
    font-family: Georgia, serif; font-size: 3rem; font-weight: 600;
    color: rgba(200,168,92,0.03); line-height: 1;
    animation: heroFloat 12s ease-in-out infinite reverse;
}

/* ==================== PAGE HERO ==================== */
.kb-page-hero {
    position: relative; overflow: hidden;
    background: linear-gradient(160deg, var(--kb-dark) 0%, var(--kb-primary) 100%);
    padding: calc(var(--header-h) + var(--topbar-h) + var(--space-20)) 0 var(--space-16);
}
.kb-page-hero::before {
    content: ''; position: absolute; inset: 0;
    background-image: radial-gradient(rgba(200,168,92,0.04) 1px, transparent 1px);
    background-size: 40px 40px;
}
.kb-page-hero__inner { position: relative; }
.kb-page-hero__title { font-size: var(--fs-h1); color: var(--kb-white); line-height: 1.1; }
.kb-breadcrumb { font-size: var(--fs-small); color: rgba(255,255,255,0.4); margin-bottom: var(--space-6); }
.kb-breadcrumb a { color: rgba(255,255,255,0.6); }
.kb-breadcrumb a:hover { color: var(--kb-accent); }
.kb-breadcrumb__sep { margin: 0 var(--space-2); }

/* ==================== ABOUT ==================== */
.kb-about__layout {
    display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-12); align-items: stretch;
}
.kb-about__subtitle {
    font-size: var(--fs-body); color: var(--kb-accent); text-transform: uppercase;
    letter-spacing: 0.15em; font-weight: 600; margin: 0 0 var(--space-8) 0;
}
.kb-about__right { display: flex; }
.kb-about__photo-wrap {
    position: relative; border-radius: var(--radius-lg); overflow: hidden;
    flex: 1; min-height: 100%;
}
.kb-about__photo-wrap img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    filter: saturate(0.5) contrast(1.1);
    transition: filter var(--dur-slow) var(--ease);
}
.kb-about__photo-wrap:hover img { filter: saturate(0.8) contrast(1.05); }
.kb-about__photo-accent {
    position: absolute; bottom: 0; left: 0; right: 0; height: 4px;
    background: linear-gradient(to right, var(--kb-accent), transparent);
}
.kb-about__values {
    margin-top: var(--space-10); padding-top: var(--space-10);
    border-top: 1px solid var(--kb-border);
}
.kb-about__values .kb-h3 { margin-bottom: var(--space-6); }
.kb-about__values-list {
    display: flex; flex-wrap: wrap; gap: var(--space-4) var(--space-8);
    list-style: none; padding: 0; margin: 0;
}
.kb-about__values-list li {
    display: flex; align-items: center; gap: var(--space-2);
    font-weight: 500; color: var(--kb-primary); font-size: var(--fs-body);
}
.kb-about__values-list li svg { flex-shrink: 0; }
.kb-about__bottom { margin-top: var(--space-12); }
.kb-check-list { display: flex; flex-direction: column; gap: var(--space-3); }
.kb-check-list li { display: flex; align-items: flex-start; gap: var(--space-3); line-height: 1.6; }
.kb-check-list li svg { flex-shrink: 0; margin-top: 4px; }
.kb-check-list--two-col { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3) var(--space-8); }

.kb-blockquote {
    padding: var(--space-8) var(--space-10); border-left: 3px solid var(--kb-accent);
    background: var(--kb-white); border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
    box-shadow: var(--shadow-sm);
}
.kb-blockquote p {
    font-family: var(--font-display); font-size: clamp(1.1875rem, 1.1rem + 0.4vw, 1.5rem);
    font-style: italic; color: var(--kb-primary); max-width: none; margin: 0; line-height: 1.5;
}
.kb-blockquote--accent { background: var(--kb-bg); }

/* ==================== SPECJALIZACJE FULL ==================== */
.kb-spec-block { padding: var(--space-12) 0; border-bottom: 1px solid var(--kb-border); }
.kb-spec-block:last-child { border-bottom: none; }
.kb-spec-block__header { display: flex; gap: var(--space-8); align-items: flex-start; margin-bottom: var(--space-8); }
.kb-spec-block__icon {
    width: 80px; height: 80px; display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--kb-primary), var(--kb-primary-dark));
    color: var(--kb-accent); border-radius: var(--radius-lg); flex-shrink: 0;
}
.kb-spec-block__header .kb-h2 { margin-bottom: var(--space-3); }
.kb-spec-block__lead { color: var(--kb-text-light); }
.kb-spec-block__scope { font-weight: 600; margin-bottom: var(--space-4); }
.kb-spec-block__content { padding-left: calc(80px + var(--space-8)); }
.kb-spec-block .kb-blockquote { margin-top: var(--space-8); margin-left: calc(80px + var(--space-8)); }

/* ==================== WSPÓŁPRACA ==================== */
.kb-steps { max-width: 800px; margin: 0 auto; }
.kb-step { display: flex; gap: var(--space-8); padding: var(--space-8) 0; position: relative; }
.kb-step:not(:last-child)::after {
    content: ''; position: absolute; left: 28px;
    top: calc(var(--space-8) + 56px); bottom: 0;
    width: 2px; background: linear-gradient(180deg, var(--kb-accent), var(--kb-border));
}
.kb-step__num {
    width: 56px; height: 56px; display: flex; align-items: center; justify-content: center;
    font-family: var(--font-display); font-size: 1.75rem; font-weight: 600;
    color: var(--kb-accent); background: var(--kb-primary); border-radius: 50%;
    flex-shrink: 0; position: relative; z-index: 1;
}
.kb-step__name { font-size: var(--fs-h3); margin-bottom: var(--space-2); }
.kb-step__content .kb-check-list { margin-top: var(--space-4); }

/* ==================== KONSULTACJE ==================== */
.kb-konsultacje__inner { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-12); align-items: center; }
.kb-konsultacje__options { display: grid; gap: var(--space-6); }
.kb-konsultacje__option {
    padding: var(--space-8); background: var(--kb-bg); border-radius: var(--radius-lg);
    border: 1px solid var(--kb-border); color: var(--kb-accent);
    transition: all var(--dur-base) var(--ease);
}
.kb-konsultacje__option:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); border-color: var(--kb-accent); }
.kb-konsultacje__option h3 { margin-top: var(--space-4); margin-bottom: var(--space-2); color: var(--kb-primary); }
.kb-konsultacje__option p { font-size: var(--fs-small); color: var(--kb-text-light); margin: 0; }

/* ==================== KONTAKT ==================== */
.kb-kontakt { position: relative; overflow: hidden; }
/* Gavel watermark */
.kb-kontakt::before {
    content: '';
    position: absolute; top: 15%; left: -2%;
    width: 200px; height: 200px;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 100 100' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='55' y='10' width='25' height='25' rx='3' transform='rotate(45 67.5 22.5)' stroke='%231B2A4A' stroke-width='0.8' fill='none'/%3E%3Crect x='20' y='45' width='25' height='25' rx='3' transform='rotate(45 32.5 57.5)' stroke='%231B2A4A' stroke-width='0.8' fill='none'/%3E%3Cline x1='15' y1='85' x2='50' y2='85' stroke='%231B2A4A' stroke-width='1.2'/%3E%3Cline x1='32.5' y1='72' x2='32.5' y2='85' stroke='%231B2A4A' stroke-width='0.8'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-size: contain;
    opacity: 0.025; pointer-events: none;
}
.kb-kontakt__grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--space-12); }
.kb-kontakt__card {
    background: var(--kb-white); border-radius: var(--radius-lg);
    padding: var(--space-8); box-shadow: var(--shadow-md);
    border: 1px solid var(--kb-border); margin-top: var(--space-6);
}
.kb-kontakt__item { display: flex; gap: var(--space-4); align-items: flex-start; padding: var(--space-4) 0; border-bottom: 1px solid var(--kb-border); }
.kb-kontakt__item:last-child { border-bottom: none; }
.kb-kontakt__item svg { flex-shrink: 0; margin-top: 2px; }
.kb-kontakt__item strong { display: block; font-size: 0.75rem; color: var(--kb-text-light); margin-bottom: var(--space-1); text-transform: uppercase; letter-spacing: 0.1em; }
.kb-kontakt__item a:hover { color: var(--kb-accent); }
.kb-kontakt__map { margin-top: var(--space-6); }

/* Full-width map (kontakt page bottom) */
.kb-map-full { position: relative; background: var(--kb-dark); }
.kb-map-full__overlay {
    position: absolute; top: 0; left: 0; right: 0; z-index: 2;
    padding: var(--space-6) 0;
    pointer-events: none;
}
.kb-map-full__overlay .kb-label { color: var(--kb-accent); }
.kb-map-full iframe {
    display: block; width: 100%; height: 450px; border: 0;
    filter: saturate(0.7) contrast(1.05);
    transition: filter var(--dur-slow) var(--ease);
}
.kb-map-full:hover iframe { filter: saturate(1) contrast(1); }

/* ==================== FORM ==================== */
.kb-form { margin-top: var(--space-8); }
.kb-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.kb-form__field { margin-bottom: var(--space-4); }
.kb-form__field label { display: block; font-size: var(--fs-small); font-weight: 600; margin-bottom: var(--space-2); }
.kb-form__field label span { color: var(--kb-accent); }
.kb-form__field input, .kb-form__field textarea {
    width: 100%; padding: 0.875rem var(--space-4);
    border: 1px solid var(--kb-border); border-radius: var(--radius);
    background: var(--kb-white); transition: all var(--dur-base) var(--ease);
}
.kb-form__field input:focus, .kb-form__field textarea:focus {
    border-color: var(--kb-accent);
    box-shadow: 0 0 0 3px rgba(200,168,92,0.12);
}
.kb-form__consent { margin-bottom: var(--space-6); }
.kb-form__consent label { display: flex; gap: var(--space-3); font-size: var(--fs-small); color: var(--kb-text-light); cursor: pointer; align-items: flex-start; }
.kb-form__consent input[type="checkbox"] { width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; accent-color: var(--kb-accent); }
.kb-form__consent a { color: var(--kb-accent); text-decoration: underline; }
.kb-form__submit { width: 100%; justify-content: center; padding: var(--space-4); font-size: 0.9375rem; }
.kb-form__status { margin-top: var(--space-4); padding: var(--space-3) var(--space-4); border-radius: var(--radius); font-size: var(--fs-small); display: none; }
.kb-form__status.success { display: block; background: #ecfdf5; color: #065f46; border: 1px solid #a7f3d0; }
.kb-form__status.error { display: block; background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }

/* ==================== FOOTER ==================== */
.kb-footer {
    background: var(--kb-dark); color: rgba(255,255,255,0.6);
    padding: var(--section-md) 0 var(--space-8);
    position: relative; overflow: hidden;
}
/* Greek columns watermark in footer */
.kb-footer::before {
    content: '';
    position: absolute; bottom: 0; left: 5%;
    width: 200px; height: 300px;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 100 160' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='10' y='8' width='80' height='7' rx='2' stroke='white' stroke-width='0.6' fill='none'/%3E%3Crect x='10' y='145' width='80' height='7' rx='2' stroke='white' stroke-width='0.6' fill='none'/%3E%3Crect x='20' y='15' width='6' height='130' stroke='white' stroke-width='0.5' fill='none'/%3E%3Crect x='38' y='15' width='6' height='130' stroke='white' stroke-width='0.5' fill='none'/%3E%3Crect x='56' y='15' width='6' height='130' stroke='white' stroke-width='0.5' fill='none'/%3E%3Crect x='74' y='15' width='6' height='130' stroke='white' stroke-width='0.5' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-size: contain;
    opacity: 0.02; pointer-events: none;
}
/* Book watermark in footer right */
.kb-footer::after {
    content: '';
    position: absolute; top: 10%; right: 3%;
    width: 180px; height: 200px;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 100 120' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M15 100 Q50 80 50 80 Q50 80 85 100' stroke='white' stroke-width='0.8' fill='none'/%3E%3Cpath d='M15 10 Q50 25 50 25 Q50 25 85 10' stroke='white' stroke-width='0.8' fill='none'/%3E%3Cline x1='15' y1='10' x2='15' y2='100' stroke='white' stroke-width='0.6'/%3E%3Cline x1='85' y1='10' x2='85' y2='100' stroke='white' stroke-width='0.6'/%3E%3Cline x1='50' y1='25' x2='50' y2='80' stroke='white' stroke-width='0.4'/%3E%3Cline x1='25' y1='35' x2='45' y2='40' stroke='white' stroke-width='0.3'/%3E%3Cline x1='25' y1='45' x2='45' y2='48' stroke='white' stroke-width='0.3'/%3E%3Cline x1='25' y1='55' x2='45' y2='56' stroke='white' stroke-width='0.3'/%3E%3Cline x1='55' y1='40' x2='75' y2='35' stroke='white' stroke-width='0.3'/%3E%3Cline x1='55' y1='48' x2='75' y2='45' stroke='white' stroke-width='0.3'/%3E%3Cline x1='55' y1='56' x2='75' y2='55' stroke='white' stroke-width='0.3'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-size: contain;
    opacity: 0.025; pointer-events: none;
}
.kb-footer__grid {
    display: grid; grid-template-columns: 1.5fr 1fr 1.5fr;
    gap: var(--space-12); padding-bottom: var(--space-12);
    border-bottom: 1px solid rgba(255,255,255,0.08);
}
.kb-footer__logo { display: inline-flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-4); }
.kb-footer__logo strong { color: var(--kb-white); font-family: var(--font-display); font-size: 1.0625rem; }
.kb-footer__logo small { font-size: 0.6875rem; color: rgba(255,255,255,0.4); text-transform: uppercase; letter-spacing: 0.08em; }
.kb-footer__desc { font-size: var(--fs-small); max-width: 300px; line-height: 1.7; }
.kb-footer__heading { font-size: 0.875rem; color: var(--kb-white); margin-bottom: var(--space-4); letter-spacing: 0.1em; text-transform: uppercase; font-family: var(--font-body); font-weight: 600; }
.kb-footer__links li { margin-bottom: var(--space-2); }
.kb-footer__links a { font-size: var(--fs-small); }
.kb-footer__links a:hover { color: var(--kb-accent); }
.kb-footer__contact li { display: flex; gap: var(--space-3); align-items: flex-start; margin-bottom: var(--space-3); font-size: var(--fs-small); }
.kb-footer__contact svg { flex-shrink: 0; margin-top: 2px; color: var(--kb-accent); }
.kb-footer__contact a:hover { color: var(--kb-accent); }
.kb-footer__bottom { display: flex; justify-content: space-between; padding-top: var(--space-8); font-size: 0.8125rem; color: rgba(255,255,255,0.3); letter-spacing: 0.01em; }
.kb-footer__bottom a { color: var(--kb-accent); }
.kb-footer__bottom a:hover { color: var(--kb-accent-hover); }

/* ==================== FLOATING CTA ==================== */
.kb-floating-cta {
    position: fixed; bottom: var(--space-8); right: var(--space-6); z-index: 90;
    width: 56px; height: 56px; display: flex; align-items: center; justify-content: center;
    background: var(--kb-accent); color: var(--kb-dark); border-radius: 50%;
    box-shadow: 0 4px 20px rgba(200,168,92,0.4);
    opacity: 0; transform: translateY(20px);
    transition: all var(--dur-slow) var(--ease); pointer-events: none;
}
.kb-floating-cta.visible { opacity: 1; transform: translateY(0); pointer-events: auto; }
.kb-floating-cta:hover { transform: translateY(-3px) scale(1.08); box-shadow: 0 6px 28px rgba(200,168,92,0.5); }

/* ==================== SCROLL TOP ==================== */
.kb-scroll-top {
    position: fixed; bottom: var(--space-8); right: calc(var(--space-6) + 56px + var(--space-4));
    z-index: 90; width: 44px; height: 44px;
    display: flex; align-items: center; justify-content: center;
    background: var(--kb-white); color: var(--kb-primary); border-radius: 50%;
    box-shadow: var(--shadow-md); border: 1px solid var(--kb-border);
    opacity: 0; transform: translateY(20px);
    transition: all var(--dur-slow) var(--ease); pointer-events: none;
}
.kb-scroll-top.visible { opacity: 1; transform: translateY(0); pointer-events: auto; }
.kb-scroll-top:hover { background: var(--kb-primary); color: var(--kb-white); }

/* ==================== COOKIES ==================== */
.kb-cookies {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 95;
    background: var(--kb-dark); transform: translateY(100%); transition: transform var(--dur-slow) var(--ease);
}
.kb-cookies.visible { transform: translateY(0); }
.kb-cookies__inner {
    max-width: 1200px; margin: 0 auto; padding: var(--space-4) var(--space-6);
    display: flex; align-items: center; justify-content: space-between; gap: var(--space-6);
}
.kb-cookies p { font-size: var(--fs-small); color: rgba(255,255,255,0.6); margin: 0; }
.kb-cookies a { color: var(--kb-accent); text-decoration: underline; }

/* ==================== ANIMATIONS ==================== */
.kb-anim {
    opacity: 0; transform: translateY(28px);
    transition: opacity 0.7s var(--ease), transform 0.7s var(--ease);
    transition-delay: var(--delay, var(--anim-delay, 0s));
}
.kb-anim.visible { opacity: 1; transform: translateY(0); }

/* ==================== PAGE CONTENT ==================== */
.kb-page-title { margin-bottom: var(--space-8); }
.kb-content p { margin-bottom: var(--space-4); }
.kb-content h2 { margin-top: var(--space-8); }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {
    .kb-hero__inner { gap: var(--space-6); }
    .kb-hero__art { display: none; }
    .kb-hero__deco--columns, .kb-hero__deco--book { display: none; }
    .kb-opinie__grid { columns: 2; }
    .kb-intro__grid { grid-template-columns: 1fr; gap: var(--space-8); }
    .kb-intro__visual { max-width: 400px; }
    .kb-about__layout { grid-template-columns: 1fr; gap: var(--space-8); }
    .kb-about__photo-wrap { max-height: 400px; }
    .kb-spec-block__content { padding-left: 0; }
    .kb-spec-block .kb-blockquote { margin-left: 0; }
    .kb-konsultacje__inner { grid-template-columns: 1fr; }
    .kb-kontakt__grid { grid-template-columns: 1fr; }
    .kb-footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
}

@media (max-width: 768px) {
    :root { --header-h: 64px; --topbar-h: 0px; }
    .kb-topbar { display: none; }
    .kb-header { top: 0; }
    .kb-container { padding-left: var(--space-4); padding-right: var(--space-4); }
    .kb-nav { display: none; }
    .kb-hamburger { display: flex; }
    .kb-hero__deco { display: none; }
    .kb-opinie__grid { columns: 1; }
    .kb-about__photo-wrap { max-height: 300px; }
    .kb-about__values-list { gap: var(--space-3) var(--space-6); }
    .kb-hero__inner { grid-template-columns: 1fr; }
    .kb-hero__panel { max-width: 100%; }
    .kb-hero__stats { flex-wrap: wrap; gap: var(--space-4); }
    .kb-hero__decor { display: none; }
    .kb-intro__content { border-left: none; padding-left: 0; }
    .kb-intro__visual { max-width: 320px; margin: 0 auto; }
    .kb-intro__accent-line { display: none; }
    .kb-spec-block__header { flex-direction: column; }
    .kb-spec-block__icon { width: 56px; height: 56px; }
    .kb-spec-block__icon svg { width: 24px; height: 24px; }
    .kb-check-list--two-col { grid-template-columns: 1fr; }
    .kb-step__num { width: 40px; height: 40px; font-size: 1.125rem; }
    .kb-step:not(:last-child)::after { left: 19px; }
    .kb-form__row { grid-template-columns: 1fr; }
    .kb-kontakt__card { padding: var(--space-4); }
    .kb-konsultacje__option { padding: var(--space-4); }
    .kb-footer__grid { grid-template-columns: 1fr; gap: var(--space-6); }
    .kb-footer__bottom { flex-direction: column; gap: var(--space-2); text-align: center; }
    .kb-cookies__inner { flex-direction: column; text-align: center; }
    .kb-floating-cta { width: 48px; height: 48px; bottom: var(--space-4); right: var(--space-4); }
    .kb-scroll-top { width: 38px; height: 38px; right: calc(var(--space-4) + 48px + var(--space-3)); bottom: var(--space-4); }
}

@media (max-width: 480px) {
    .kb-container { padding-left: var(--space-3); padding-right: var(--space-3); }
    .kb-hero__actions { flex-direction: column; align-items: stretch; }
    .kb-hero__actions .kb-btn { text-align: center; justify-content: center; }
    .kb-hero__stats { gap: var(--space-3); }
    .kb-hero__stat-sep:last-of-type { display: none; }
    .kb-step { flex-direction: column; gap: var(--space-4); }
    .kb-step:not(:last-child)::after { display: none; }
    .kb-about__values { margin-top: var(--space-6); padding-top: var(--space-6); }
    .kb-intro__visual { display: none; }
    .kb-footer__contact span { font-size: 0.75rem; }
    .kb-footer__contact a { font-size: 0.75rem; }
}

/* ==========================================================================
   FOCUS VISIBLE (Accessibility — keyboard navigation)
   ========================================================================== */
.kb-btn:focus-visible,
.kb-btn--outline-gold:focus-visible {
    outline: 2px solid var(--kb-accent);
    outline-offset: 3px;
}
.kb-nav__link:focus-visible {
    outline: 2px solid var(--kb-accent);
    outline-offset: 4px;
}
.kb-hamburger:focus-visible {
    outline: 2px solid var(--kb-accent);
    outline-offset: 2px;
}
.kb-mobile-menu__link:focus-visible {
    outline: 2px solid var(--kb-accent);
    outline-offset: 4px;
}
.kb-floating-cta:focus-visible {
    outline: 2px solid var(--kb-primary);
    outline-offset: 3px;
}
.kb-scroll-top:focus-visible {
    outline: 2px solid var(--kb-accent);
    outline-offset: 2px;
}
.kb-arrow-link:focus-visible {
    outline: 2px solid var(--kb-accent);
    outline-offset: 4px;
}
.kb-footer__links a:focus-visible,
.kb-footer__contact a:focus-visible {
    outline: 2px solid var(--kb-accent);
    outline-offset: 2px;
}
.kb-form__field input:focus-visible,
.kb-form__field textarea:focus-visible {
    outline: 2px solid var(--kb-accent);
    outline-offset: 1px;
    border-color: var(--kb-accent);
    box-shadow: 0 0 0 3px rgba(200,168,92,0.12);
}
.kb-header__logo:focus-visible {
    outline: 2px solid var(--kb-accent);
    outline-offset: 4px;
}

/* ==========================================================================
   ANIMATIONS — will-change + reduced motion
   ========================================================================== */
.kb-anim {
    will-change: opacity, transform;
}
.kb-anim.visible {
    will-change: auto;
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    .kb-anim { opacity: 1; transform: none; }
    .kb-preloader { display: none !important; }
}
