/* ============================================================
   PulSEO - Main Stylesheet
   Colors: #0e3976 (primary), #585887 (secondary), #ffa000 (accent)
   ============================================================ */

/* ---- CSS Variables ---- */
:root {
    --color-primary:    #0e3976;
    --color-secondary:  #585887;
    --color-accent:     #ffa000;
    --color-white:      #ffffff;
    --color-bg:         #f7f9fc;
    --color-bg-dark:    #0a2540;
    --color-text:       #1a1a2e;
    --color-text-muted: #6b7080;
    --color-border:     #e4e8f0;
    --radius-sm:        .375rem;
    --radius-md:        .75rem;
    --radius-lg:        1.25rem;
    --shadow-sm:        0 2px 8px rgba(14,57,118,.07);
    --shadow-md:        0 4px 20px rgba(14,57,118,.12);
    --shadow-lg:        0 8px 40px rgba(14,57,118,.18);
    --transition:       .3s ease;
    --section-py:       5rem;
}

/* ---- Typography ---- */
h1,h2,h3,h4,h5,h6 { color: var(--color-primary); font-weight: 700; line-height: 1.25; }
h1 { font-size: clamp(1.9rem, 4.5vw, 3.2rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.4rem); margin-bottom: .75rem; }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.6rem); }
h4 { font-size: 1.15rem; }
p  { font-size: 1.05rem; line-height: 1.55; color: var(--color-text); }

/* ---- Utility ---- */
.text-center  { text-align: center; }
.text-primary { color: var(--color-primary); }
.text-accent  { color: var(--color-accent); }
.text-muted   { color: var(--color-text-muted); }
.text-white   { color: #fff; }
.mt-1 { margin-top: .5rem; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }
.mt-4 { margin-top: 2rem; }
.mb-1 { margin-bottom: .5rem; }
.mb-2 { margin-bottom: 1rem; }
.mb-3 { margin-bottom: 1.5rem; }
.mb-4 { margin-bottom: 2rem; }
.visually-hidden { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }

/* ---- Section Headers ---- */
.section-header { text-align: center; margin-bottom: 3.5rem; }
.section-eyebrow {
    display: inline-block;
    background: rgba(255,160,0,.12);
    color: var(--color-accent);
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .1em;
    padding: .3rem .85rem;
    padding-top: .4rem;
    border-radius: 2rem;
    margin-bottom: .85rem;
    border: 1px solid rgba(255,160,0,.25);
}
.section-title { margin-bottom: .75rem; }
.section-subtitle { font-size: 1.1rem; color: var(--color-text-muted); max-width: 100%; margin: 0 auto; }

/* ---- Navigation ---- */
.nav-list { display: flex; align-items: center; gap: .25rem; list-style: none; position: relative; }
.nav-link {
    display: flex;
    align-items: center;
    gap: .35rem;
    padding: .55rem .85rem;
    font-size: .95rem;
    font-weight: 500;
    color: var(--color-text);
    border-radius: var(--radius-sm);
    transition: color var(--transition);
    white-space: nowrap;
    position: relative;
    z-index: 1;
}
.nav-link:hover { color: var(--color-primary); }
.nav-item--active > .nav-link { color: var(--color-primary); background: rgba(14,57,118,.06); }

/* Sliding highlight na głównym nav — wstrzykiwany przez JS */
.nav-slider {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    height: 36px;
    border-radius: var(--radius-sm);
    background: rgba(14,57,118,.06);
    pointer-events: none;
    transition: left .22s cubic-bezier(.4,0,.2,1), width .22s cubic-bezier(.4,0,.2,1), opacity .18s ease;
    opacity: 0;
    z-index: 0;
}
.nav-arrow { font-size: .65rem; transition: transform var(--transition); }
.nav-item--has-dropdown:hover .nav-arrow { transform: rotate(180deg); }

/* Dropdown */
.nav-item--has-dropdown { position: relative; }
.nav-dropdown {
    position: absolute;
    top: calc(100% + .6rem);
    left: 50%;
    transform: translateX(-50%) translateY(-10px);
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: 0 12px 40px rgba(14,57,118,.14);
    list-style: none;
    min-width: 300px;
    padding: .5rem;
    opacity: 0;
    visibility: hidden;
    transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
    z-index: 200;
}
/* Most niewidoczny — wypełnia szczelinę między linkiem a dymkiem */
.nav-dropdown::before {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 0;
    right: 0;
    height: 1rem;
}
/* Gdy nav-list jest hovered — schowaj wszystkie dropdowny natychmiast.
   Specyficzność 0,2,0 — przegrywa z regułą niżej gdy konkretny item jest hovered. */
.nav-list:hover .nav-dropdown {
    opacity: 0;
    visibility: hidden;
    transform: translateX(-50%) translateY(-10px);
    transition: none;
}
/* Specyficzność 0,3,0 — wygrywa z powyższą i pokazuje tylko aktualnie hovered dropdown. */
.nav-item--has-dropdown:hover .nav-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
    transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
}

/* Sliding highlight — wstrzykiwany przez JS */
.nav-dropdown-slider {
    position: absolute;
    left: .5rem;
    right: .5rem;
    border-radius: var(--radius-sm);
    background: rgba(14,57,118,.06);
    pointer-events: none;
    transition: top .22s cubic-bezier(.4,0,.2,1), height .22s cubic-bezier(.4,0,.2,1), opacity .18s ease;
    opacity: 0;
    z-index: 0;
}
.nav-dropdown-slider.is-visible { opacity: 1; }

.nav-dropdown-link {
    display: flex;
    align-items: center;
    gap: .8rem;
    padding: .75rem 1rem;
    font-size: .93rem;
    font-weight: 500;
    color: var(--color-text);
    border-radius: var(--radius-sm);
    white-space: nowrap;
    position: relative;
    z-index: 1;
    transition: color .2s ease;
}
.nav-dropdown-link i {
    width: 32px;
    height: 32px;
    background: rgba(14,57,118,.07);
    border-radius: .4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    color: var(--color-primary);
    flex-shrink: 0;
    transition: background .2s ease, color .2s ease;
}
.nav-dropdown-link:hover  { color: var(--color-primary); }
.nav-dropdown-link.active { color: var(--color-primary); }
.nav-dropdown-link:hover i  { background: var(--color-accent); color: #fff; }
.nav-dropdown-link.active i { background: var(--color-primary); color: #fff; }

/* ---- Mobile Menu ---- */
.mobile-menu {
    position: fixed;
    top: 0;
    right: -100%;
    width: min(340px, 90vw);
    height: 100vh;
    background: #fff;
    z-index: 999;
    transition: right .35s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
    box-shadow: var(--shadow-lg);
}
.mobile-menu.is-open { right: 0; }
.mobile-menu__inner { padding: 5rem 1.5rem 2rem; display: flex; flex-direction: column; gap: 2rem; }
.mobile-overlay {
    position: fixed;
    inset: 0;
    background: rgba(10,37,64,.5);
    z-index: 998;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition);
}
.mobile-overlay.is-visible { opacity: 1; pointer-events: all; }
.mobile-nav-list { list-style: none; display: flex; flex-direction: column; gap: .25rem; }
.mobile-nav-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: .85rem 1rem;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-text);
    border-radius: var(--radius-sm);
    background: none;
    border: none;
    cursor: pointer;
    transition: background var(--transition);
    text-align: left;
}
.mobile-nav-link:hover { background: rgba(14,57,118,.06); color: var(--color-primary); }
.mobile-nav-sub { display: none; list-style: none; padding: .25rem 0 .25rem 1rem; }
.mobile-nav-sub.is-open { display: block; }
.mobile-nav-sublink { display: flex; align-items: center; gap: .6rem; padding: .6rem 1rem; font-size: .95rem; color: var(--color-text-muted); border-radius: var(--radius-sm); }
.mobile-nav-sublink i { font-size: .85rem; color: var(--color-accent); flex-shrink: 0; width: 1rem; text-align: center; }
.mobile-nav-sublink:hover { color: var(--color-primary); background: rgba(14,57,118,.04); }

/* ---- Hero ---- */
.hero { animation: gradientShift 8s ease infinite; }
@keyframes gradientShift {
    0%,100% { background-position: 0% 50%; }
    50%      { background-position: 100% 50%; }
}
.hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url('/assets/images/overlay.webp') center center / cover no-repeat;
    pointer-events: none;
    z-index: 0;
}
.hero > * { position: relative; z-index: 1; }

/* Hero layout — 3 divy: top (pełna szer.) + bottom (2 kolumny) */
.hero-top {
    padding-top: calc(72px + 2rem);
}
.hero-bottom {
    display: grid;
    grid-template-columns: 1fr;
    align-items: end;
    gap: 2rem;
}
@media(min-width:1024px) {
    .hero-bottom { grid-template-columns: 55fr 45fr; }
}
.hero-content { 
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    align-content: center;
    height: 100%;
}
.hero-visual { display: none; }
@media(min-width:1024px) {
    .hero-visual { display: flex; justify-content: flex-end; align-items: flex-end; }
}
.hero-illustration {
    width: 100%;
    max-width: 480px;
    animation: floatAnim 4s ease-in-out infinite;
}
.hero-rocket-wrap {
    width: 100%;
    max-width: 500px;
    aspect-ratio: 500 / 375;
}
.hero-rocket {
    width: 100%;
    display: block;
    object-fit: contain;
    opacity: 0;
    transition: opacity .4s ease;
}
.hero-rocket.is-loaded {
    opacity: 1;
}
@keyframes floatAnim {
    0%,100% { transform: translateY(0); }
    50%      { transform: translateY(-16px); }
}

/* ---- Stats Bar ---- */
.stats-bar {
    background: var(--color-primary);
    padding: 3rem 0;
    position: relative;
}
.stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
    text-align: center;
}
@media(min-width:768px) { .stats-grid { grid-template-columns: repeat(4, 1fr); } }
.stat-value {
    font-size: clamp(2.2rem, 5vw, 3rem);
    font-weight: 800;
    color: #fff;
    line-height: 1;
    margin-bottom: .35rem;
}
.stat-value span { color: var(--color-accent); }
.stat-label { font-size: .95rem; color: rgba(255,255,255,.7); font-weight: 500; }

/* ---- Generic Section ---- */
.section { padding: var(--section-py) 0; position: relative; }
.section--gray { background: var(--color-bg); }
.section--dark { background: var(--color-bg-dark); }
.section--primary { background: var(--color-primary); }

/* ---- Pricing Section ---- */
.pricing-section {
    position: relative;
    padding: 5rem 0 4rem;
    background: linear-gradient(135deg, #0e3976 0%, #1a4f9e 50%, #0e3976 100%);
    overflow: hidden;
}
.pricing-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url('/assets/images/overlay.webp') center center / cover no-repeat;
    opacity: 0.6;
    pointer-events: none;
}
.pricing-section .section-header,
.pricing-section .pricing-grid,
.pricing-section .pricing-footnote { position: relative; z-index: 1; }

.section-eyebrow--light {
    background: rgba(255,160,0,.18);
    color: #ffa000;
    border-color: rgba(255,160,0,.3);
}

.pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    align-items: stretch;
}
@media (max-width: 900px) { .pricing-grid { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; } }

.pricing-card {
    background: #fff;
    border-radius: 1rem;
    overflow: visible;
    display: flex;
    flex-direction: column;
    position: relative;
    box-shadow: 0 8px 32px rgba(14,57,118,.18);
    transition: opacity .6s ease, transform .6s ease, box-shadow .3s;
}
.pricing-card.is-visible:hover {
    transform: translateY(-4px);
}
.pricing-card--featured {
    border: 2px solid #ffa000;
    box-shadow: 0px 0px 20px 14px rgba(255, 107, 53, 0.35);
    padding-top: .75rem;
}
.pricing-card--featured.is-visible:hover {
    transform: translateY(-4px);
}

.pricing-badge {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #ffa000;
    color: #fff;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .06em;
    padding: .3rem .9rem;
    border-radius: 2rem;
    z-index: 2;
    text-transform: uppercase;
    white-space: nowrap;
    box-shadow: 0 2px 12px rgba(255,160,0,.4);
}

.pricing-img-wrap {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: .5rem 0 1rem;
}
.pricing-img-wrap img {
    max-height: 116px;
    min-height: 116px;
    width: auto;
    object-fit: contain;
}

.pricing-card__body {
    padding: 1.25rem 1.5rem 1.5rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.pricing-card__name {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: .5rem;
    text-align: center;
}
.pricing-card__price {
    font-size: 1rem;
    color: #555;
    margin-bottom: 0;
    padding-bottom: .75rem;
    text-align: center;
}
.pricing-card__price strong {
    font-size: 2rem;
    font-weight: 800;
    color: var(--color-primary);
}
.pricing-card__price span {
    font-size: .85rem;
    color: #888;
}

.pricing-features {
    list-style: none;
    margin: 0 0 1.5rem;
    padding: 0;
    flex: 1;
}
.pricing-features li {
    font-size: .9rem;
    text-align: left;
    color: #444;
    padding: .2rem 0;
    border-bottom: 1px solid #f5f5f5;
}
.pricing-features li:last-child { border-bottom: none; }
.pricing-features li .fa-circle-check { color: #ffa000; margin-top: .15rem; flex-shrink: 0; }

.btn--outline-white {
    background: transparent;
    color: var(--color-primary);
    border-color: var(--color-primary);
}
.btn--outline-white:hover {
    background: var(--color-primary);
    color: #fff;
}

.pricing-footnote {
    text-align: center;
    color: rgba(255,255,255,.55);
    font-size: .8rem;
    margin-top: 3rem;
}

.more-info {
    list-style: decimal;
    padding-left: 1.25rem;
    margin-top: 2.5rem;
    color: rgba(255,255,255,.55);
    font-size: .78rem;
    line-height: 1.6;
    position: relative;
    z-index: 1;
}
.more-info li + li { margin-top: .35rem; }

/* ---- SEO Section ---- */
.seo-layout {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 3rem;
    align-items: center;
}
@media (max-width: 1023px) {
    .seo-layout {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto auto;
    }
    .seo-col--center {
        grid-column: 1 / -1;
        order: -1;
    }
}
@media (max-width: 639px) {
    .seo-layout { grid-template-columns: 1fr; }
    .seo-col--center { order: 0; }
}

.seo-col { display: flex; flex-direction: column; gap: 1.25rem; }

.seo-col--center {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
}
@media (max-width: 1023px) { .seo-col--center { width: 100%; max-width: 360px; margin: 0 auto; } }

.seo-center-img img {
    height: auto;
    display: block;
}

.seo-box {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    background: #fff;
    border-radius: .75rem;
    padding: 1.25rem 1.5rem;
    box-shadow: 0 4px 20px rgba(14,57,118,.08);
    transition: transform .3s, box-shadow .3s;
}
.seo-box:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 32px rgba(14,57,118,.14);
}

.seo-box__icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: .6rem;
    background: rgba(14,57,118,.07);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    color: var(--color-primary);
    transition: background .3s, color .3s;
}
.seo-box:hover .seo-box__icon {
    background: var(--color-accent);
    color: #fff;
}

.seo-box__content h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: .3rem;
}
.seo-box__content p {
    font-size: .88rem;
    color: var(--color-text-muted);
    line-height: 1.55;
    margin: 0;
}

/* ---- Section Background Decorations ---- */
@keyframes decoFloatY    { 0%,100%{transform:translateY(0)}           50%{transform:translateY(-18px)} }
@keyframes decoFloatX    { 0%,100%{transform:translateX(0)}           50%{transform:translateX(-24px)} }
@keyframes decoFloatDiag { 0%,100%{transform:translate(0,0)}          50%{transform:translate(-18px,-24px)} }
@keyframes decoRotate    { from{transform:rotate(0deg)}                to{transform:rotate(360deg)} }
@keyframes decoPulse     { 0%,100%{transform:scale(1)}                50%{transform:scale(1.08)} }
@keyframes decoWobble    { 0%,100%{border-radius:60% 40% 30% 70%/60% 30% 70% 40%} 50%{border-radius:30% 60% 70% 40%/50% 60% 30% 60%} }

.section-decos { position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:0; }
.section-decos ~ * { position:relative; z-index:1; }
.deco { position:absolute; pointer-events:none; }

/* Kolory */
.deco--p  { background:var(--color-primary); }
.deco--a  { background:var(--color-accent); }
.deco--w  { background:#fff; }
.deco--rp { background:transparent; border:3px solid var(--color-primary); }
.deco--ra { background:transparent; border:3px solid var(--color-accent); }
.deco--rw { background:transparent; border:3px solid rgba(255,255,255,.4); }

/* Kształty */
.deco--circle  { border-radius:50%; }
.deco--blob    { border-radius:60% 40% 30% 70%/60% 30% 70% 40%; animation:decoWobble 12s ease-in-out infinite; }
.deco--diamond { clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%); }
.deco--triangle{ clip-path:polygon(50% 0%,100% 100%,0% 100%); }
.deco--cross   { clip-path:polygon(33% 0%,66% 0%,66% 33%,100% 33%,100% 66%,66% 66%,66% 100%,33% 100%,33% 66%,0% 66%,0% 33%,33% 33%); }
.deco--rring   { border-radius:50%; background:transparent; }
.deco--hexagon { clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%); }

/* Animacje — nie kolidują z kształtami bo clip-path jest osobną właściwością */
.deco--fy  { animation:decoFloatY    5s ease-in-out infinite; }
.deco--fx  { animation:decoFloatX    6s ease-in-out infinite; }
.deco--fd  { animation:decoFloatDiag 7s ease-in-out infinite; }
.deco--ro  { animation:decoRotate    18s linear infinite; }
.deco--pu  { animation:decoPulse     4s ease-in-out infinite; }

/* ---- Service Cards ---- */
.services-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}
@media(min-width:640px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media(min-width:1024px) { .services-grid { grid-template-columns: repeat(4, 1fr); } }

.service-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2rem 1.75rem;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}
.service-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
    transform: scaleX(0);
    transition: transform var(--transition);
    transform-origin: left;
}
.service-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(14,57,118,.15);
}
.service-card:hover::before { transform: scaleX(1); }

/* Obrazek z kółkiem w tle */
.service-img-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 70px;
    height: 70px;
    margin: 0 auto 1.5rem;
}
.service-img-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: #e8ecf2;
    transition: background var(--transition);
    opacity: 0.3;
}
.service-card:hover .service-img-wrap::before {
    background: var(--color-accent);
}
.service-img {
    position: relative;
    z-index: 1;
    width: auto;
    height: auto;
    min-height: 70px;
    max-height: 70px;
    object-fit: contain;
}
.service-card h3 { font-size: 1.2rem; margin-bottom: .6rem; }
.service-card p  { font-size: .95rem; color: var(--color-text-muted); margin-bottom: 0; flex: 1; }
.service-card .btn { margin-top: 1.5rem; }
.service-link:hover { gap: .7rem; color: var(--color-accent); }

/* ---- Why Us section ---- */
.why-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
    align-items: center;
}
@media(min-width:1024px) { .why-grid { grid-template-columns: 1fr 1fr; } }
.why-list { list-style: none; display: flex; flex-direction: column; gap: 1.25rem; margin-top: 2rem; }
.why-item {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
}
.why-icon {
    width: 48px;
    height: 48px;
    background: rgba(14,57,118,.08);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    font-size: 1.1rem;
    flex-shrink: 0;
    transition: background var(--transition), color var(--transition);
}
.why-item:hover .why-icon { background: var(--color-accent); color: #fff; }
.why-item-text h4 { font-size: 1.05rem; margin-bottom: .25rem; }
.why-item-text p  { font-size: .93rem; color: var(--color-text-muted); }
.why-image { display: flex; justify-content: center; }
.why-image img { max-width: 420px; width: 100%; border-radius: var(--radius-lg); }

/* ---- Process Steps ---- */
.process-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}
@media(min-width:768px) { .process-grid { grid-template-columns: repeat(2, 1fr); } }
@media(min-width:1200px) { .process-grid { grid-template-columns: repeat(4, 1fr); } }

.process-step {
    position: relative;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2rem 1.5rem;
    text-align: center;
    transition: transform var(--transition), box-shadow var(--transition);
}
.process-step:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.process-step__num {
    width: 52px;
    height: 52px;
    background: var(--color-primary);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    font-weight: 800;
    margin: 0 auto 1.25rem;
}
.process-step:hover .process-step__num { background: var(--color-accent); }
.process-step h3 { font-size: 1.05rem; margin-bottom: .5rem; }
.process-step p  { font-size: .9rem; color: var(--color-text-muted); }

/* ---- Case Study Cards ---- */
.cs-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.75rem;
}
@media(min-width:640px) { .cs-grid { grid-template-columns: repeat(2, 1fr); } }
@media(min-width:1024px) { .cs-grid { grid-template-columns: repeat(3, 1fr); } }

.cs-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    display: block;
    transition: opacity .85s cubic-bezier(.2,0,0,1), transform .85s cubic-bezier(.2,0,0,1), box-shadow var(--transition);
}
.cs-card.is-visible:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.cs-card__image { position: relative; aspect-ratio: 16/9; background: var(--color-bg); overflow: hidden; }
.cs-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.cs-card:hover .cs-card__image img { transform: scale(1.04); }
.cs-card__badge {
    position: absolute;
    top: .75rem;
    left: .75rem;
    background: var(--color-accent);
    color: #fff;
    font-size: .78rem;
    font-weight: 700;
    padding: .25rem .7rem;
    border-radius: 2rem;
}
.cs-card__body { padding: 1.5rem; }
.cs-card__meta { font-size: .82rem; color: var(--color-text-muted); margin-bottom: .6rem; }
.cs-card__title { font-size: 1.1rem; margin-bottom: .6rem; }
.cs-card__result {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    color: #22c55e;
    font-size: .88rem;
    font-weight: 700;
    margin-top: .5rem;
}
.cs-card__result i { font-size: .75rem; }
.cs-card__link {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    color: var(--color-primary);
    font-weight: 600;
    font-size: .9rem;
    margin-top: 1rem;
    transition: gap var(--transition);
}
.cs-card:hover .cs-card__link { gap: .7rem; }

/* ---- Portfolio ---- */
.portfolio-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}
.portfolio-card {
    background: #fff;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border);
    display: flex;
    flex-direction: column;
    transition: opacity .85s cubic-bezier(.2,0,0,1), transform .85s cubic-bezier(.2,0,0,1), box-shadow var(--transition);
}
.portfolio-card.is-visible:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.portfolio-card__image-link { display: block; }
.portfolio-card__image {
    position: relative;
    overflow: hidden;
    aspect-ratio: 930/455;
}
.portfolio-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; display: block; }
.portfolio-card:hover .portfolio-card__image img { transform: scale(1.04); }
.portfolio-card__overlay {
    position: absolute;
    inset: 0;
    background: rgba(14,57,118,.65);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .3s ease;
}
.portfolio-card:hover .portfolio-card__overlay { opacity: 1; }
.portfolio-card__overlay span { color: #fff; font-weight: 600; font-size: .95rem; display: flex; align-items: center; gap: .5rem; }
.portfolio-card__body { padding: 1.5rem; display: flex; flex-direction: column; flex: 1; }
.portfolio-card__meta { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: .75rem; }
.portfolio-card__type {
    font-size: .75rem; font-weight: 700;
    background: rgba(14,57,118,.08); color: var(--color-primary);
    padding: .2rem .65rem; border-radius: 2rem;
}
.portfolio-card__industry {
    font-size: .75rem; font-weight: 600;
    background: rgba(255,160,0,.1); color: var(--color-accent);
    padding: .2rem .65rem; border-radius: 2rem;
}
.portfolio-card__title { font-size: 1.05rem; margin-bottom: .5rem; line-height: 1.3; }
.portfolio-card__desc  { font-size: .88rem; color: var(--color-text-muted); line-height: 1.55; margin-bottom: 1rem; flex: 1; }
.portfolio-card__tags  { display: flex; flex-wrap: wrap; gap: .35rem; margin-bottom: 1rem; }
.portfolio-tag { font-size: .72rem; font-weight: 600; background: var(--color-bg); color: var(--color-text-muted); border: 1px solid var(--color-border); padding: .15rem .6rem; border-radius: .25rem; }
.portfolio-card__link { display: inline-flex; align-items: center; gap: .4rem; font-size: .88rem; font-weight: 600; color: var(--color-primary); margin-top: auto; transition: gap var(--transition); }
.portfolio-card:hover .portfolio-card__link { gap: .65rem; color: var(--color-accent); }

/* Portfolio single */
.portfolio-layout { display: block; }

.portfolio-live { margin-top: 5rem; text-align: center; }
.portfolio-live__btn {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    padding: 1.1rem 2rem;
    background: #fff;
    border: 2px solid var(--color-primary);
    cursor: pointer;
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: background var(--transition), border-color var(--transition), box-shadow var(--transition), transform var(--transition);
    position: relative;
    overflow: hidden;
}
.portfolio-live__btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--color-primary);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .35s ease;
    z-index: 0;
}
.portfolio-live__btn:hover { border-color: var(--color-primary); box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.portfolio-live__btn:hover::before { transform: scaleX(1); }
.portfolio-live__btn > * { position: relative; z-index: 1; transition: color .35s ease; }
.portfolio-live__btn:hover .portfolio-live__label,
.portfolio-live__btn:hover .portfolio-live__url,
.portfolio-live__btn:hover .portfolio-live__icon { color: #fff; }
.portfolio-live__label { font-weight: 700; font-size: 1rem; color: var(--color-primary); }
.portfolio-live__url { font-size: .88rem; color: var(--color-text-muted); font-weight: 400; }
.portfolio-live__icon { font-size: .95rem; color: var(--color-accent); margin-left: .25rem; transition: transform .3s ease, color .35s ease; }
.portfolio-live__btn:hover .portfolio-live__icon { transform: translate(3px, -3px); }
.portfolio-featured-img { border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 2rem; box-shadow: var(--shadow-md); }
.portfolio-featured-img img { width: 100%; height: auto; display: block; }
.portfolio-infobar {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    margin-bottom: 2.5rem;
    overflow: hidden;
}
.portfolio-infobar__item {
    padding: 1.5rem 1.75rem;
    border-right: 1px solid var(--color-border);
    position: relative;
    transition: background var(--transition);
}
.portfolio-infobar__item:last-child { border-right: none; }
.portfolio-infobar__item::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--color-accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .3s ease;
}
.portfolio-infobar__item:hover { background: var(--color-bg); }
.portfolio-infobar__item:hover::before { transform: scaleX(1); }
.portfolio-infobar__item strong {
    display: block;
    font-size: .76rem;
    font-weight: 700;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: .07em;
    margin-bottom: .45rem;
}
.portfolio-infobar__item span {
    font-size: .97rem;
    color: var(--color-primary);
    line-height: 1.55;
    font-weight: 500;
}
.portfolio-info-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 1.75rem; position: sticky; top: 90px; }
.portfolio-info-card__title { font-size: 1rem; margin-bottom: 1.25rem; padding-bottom: .75rem; border-bottom: 1px solid var(--color-border); }
.portfolio-info-list { list-style: none; display: flex; flex-direction: column; gap: .85rem; }
.portfolio-info-list li { display: flex; flex-direction: column; gap: .2rem; }
.portfolio-info-list__label { font-size: .75rem; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .06em; display: flex; align-items: center; gap: .4rem; }
.portfolio-info-list__label i { color: var(--color-accent); font-size: .8rem; }
.portfolio-info-list li > span:last-child { font-size: .95rem; color: var(--color-text); font-weight: 500; }
.portfolio-info-techs { margin-top: 1.25rem; padding-top: 1.25rem; border-top: 1px solid var(--color-border); }
.portfolio-info-techs__label { font-size: .75rem; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: .6rem; }
.portfolio-related { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--color-border); }
.portfolio-related__title { font-size: .85rem; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: .85rem; }
.portfolio-related-item { display: flex; align-items: center; gap: .75rem; padding: .6rem 0; border-bottom: 1px solid var(--color-border); transition: color var(--transition); }
.portfolio-related-item:last-child { border-bottom: none; }
.portfolio-related-item:hover { color: var(--color-accent); }
.portfolio-related-item img { width: 56px; height: 40px; object-fit: cover; border-radius: .375rem; flex-shrink: 0; }
.portfolio-related-item strong { display: block; font-size: .85rem; color: var(--color-primary); line-height: 1.3; }
.portfolio-related-item span  { font-size: .75rem; color: var(--color-text-muted); }

@media (max-width: 1023px) {
    .portfolio-grid    { grid-template-columns: repeat(2, 1fr); }
    .portfolio-layout  { grid-template-columns: 1fr; }
    .portfolio-infobar { grid-template-columns: 1fr; }
    .portfolio-infobar__item { border-right: none; border-bottom: 1px solid var(--color-border); }
    .portfolio-infobar__item:last-child { border-bottom: none; }
    .portfolio-infobar__item::before { top: auto; bottom: 0; height: 2px; }
    .portfolio-info-card { position: static; }
}
@media (max-width: 599px) {
    .portfolio-grid    { grid-template-columns: 1fr; }
}

/* ---- About / O nas home ---- */
.about-split-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    align-items: stretch;
    margin-bottom: 2.5rem;
}
.about-intro { display: flex; flex-direction: column; justify-content: center; align-items: flex-start; }
.about-intro__subheading { font-size: 1.15rem; font-weight: 600; margin: 1.5rem 0 .6rem; color: var(--color-primary); }
.about-intro p { color: var(--color-text-muted); line-height: 1.7; font-size: 1rem; }

.about-tags { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.25rem; }
.about-tag {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: rgba(255,160,0,.1);
    color: var(--color-primary);
    border-radius: 2rem;
    padding: .3rem .85rem;
    font-size: .82rem;
    font-weight: 600;
}
.about-tag i { color: var(--color-accent); font-size: .72rem; }

/* Dark philosophy card */
.about-philosophy-card {
    background: var(--color-primary);
    border-radius: var(--radius-lg);
    padding: 2.5rem;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.about-philosophy-card__deco {
    position: absolute;
    top: -60px;
    right: -60px;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: rgba(255,160,0,.1);
    pointer-events: none;
}
.about-philosophy-card__deco::after {
    content: '';
    position: absolute;
    bottom: -80px;
    left: -80px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: rgba(255,255,255,.04);
}
.about-philosophy-card__text {
    font-size: clamp(1.3rem, 2.2vw, 1.65rem);
    font-weight: 700;
    font-style: italic;
    color: #fff;
    line-height: 1.3;
    margin-bottom: 0;
}
.about-philosophy-card__quote {
    font-size: 4.5em;
    line-height: 0;
    vertical-align: .15em;
    color: var(--color-accent);
    margin-right: .15em;
    user-select: none;
    opacity: 1;
}
.about-philosophy-card__divider {
    height: 1px;
    background: rgba(255,255,255,.15);
    margin: 1.75rem 0;
}
.about-philosophy-card h3 {
    color: var(--color-accent);
    font-size: 1.05rem;
    margin-bottom: .6rem;
}
.about-philosophy-card p {
    color: rgba(255,255,255,.75);
    font-size: .95rem;
    line-height: 1.65;
    margin: 0;
}
.about-philosophy-card__promises {
    list-style: none;
    margin: auto 0 0;
    padding-top: 1.75rem;
    border-top: 1px solid rgba(255,255,255,.1);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .55rem .75rem;
}
.about-philosophy-card__promises li {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .88rem;
    color: rgba(255,255,255,.8);
    line-height: 1.3;
}
.about-philosophy-card__promises i {
    color: var(--color-accent);
    font-size: .85rem;
    flex-shrink: 0;
}

/* Numbered services strip */
.about-services-strip {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.about-svc {
    padding: 1.75rem 1.4rem;
    border-right: 1px solid var(--color-border);
    transition: background var(--transition), box-shadow var(--transition);
    position: relative;
}
.about-svc:last-child { border-right: none; }
.about-svc:hover { background: var(--color-bg); }
.about-svc::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--color-accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .3s ease;
}
.about-svc:hover::before { transform: scaleX(1); }
.about-svc__num {
    font-size: 2.2rem;
    font-weight: 800;
    color: rgba(255,160,0,.18);
    line-height: 1;
    margin-bottom: .75rem;
    font-variant-numeric: tabular-nums;
}
.about-svc h4 { font-size: .95rem; margin-bottom: .4rem; color: var(--color-primary); }
.about-svc p  { font-size: .82rem; color: var(--color-text-muted); line-height: 1.6; margin: 0; }

@media (max-width: 1023px) {
    .about-split-grid       { grid-template-columns: 1fr; }
    .about-services-strip   { grid-template-columns: repeat(3, 1fr); }
    .about-svc:nth-child(3) { border-right: none; }
    .about-svc              { border-bottom: 1px solid var(--color-border); }
    .about-svc:last-child   { border-bottom: none; }
}
@media (max-width: 767px) {
    .about-services-strip { grid-template-columns: 1fr 1fr; }
    .about-svc:nth-child(3) { border-right: 1px solid var(--color-border); }
    .about-svc:nth-child(2n) { border-right: none; }
    .about-svc { border-bottom: 1px solid var(--color-border); }
    .about-philosophy-card__promises { grid-template-columns: 1fr; }
}
@media (max-width: 479px) {
    .about-services-strip   { grid-template-columns: 1fr; }
    .about-svc              { border-right: none !important; }
}

/* ---- Testimonials ---- */
.testimonials-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    align-items: stretch;
}
@media(min-width:768px) { .testimonials-grid { grid-template-columns: repeat(3, 1fr); } }

.testimonial-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2rem;
    position: relative;
    display: flex;
    flex-direction: column;
    transition: transform var(--transition), box-shadow var(--transition);
}
.testimonial-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.testimonial-card::before {
    content: '\201C';
    position: absolute;
    top: 1.25rem;
    right: 1.5rem;
    font-size: 5rem;
    line-height: 1;
    color: rgba(14,57,118,.07);
    font-family: Georgia, serif;
}
.testimonial-stars { color: var(--color-accent); margin-bottom: 1rem; letter-spacing: .1rem; flex-shrink: 0; }

.testimonial-body { flex: 1; margin-bottom: 1.5rem; }

.testimonial-text {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--color-text);
    font-style: italic;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: all .35s ease;
}
.testimonial-text.is-expanded {
    display: block;
    -webkit-line-clamp: unset;
    line-clamp: unset;
    overflow: visible;
}
.testimonial-read-more {
    background: none;
    border: none;
    color: var(--color-primary);
    font-size: .88rem;
    font-weight: 600;
    cursor: pointer;
    padding: .35rem 0 0;
    display: block;
    transition: color .2s;
}
.testimonial-read-more:hover { color: var(--color-accent); }

.testimonial-author { display: flex; align-items: center; gap: 1rem; margin-top: auto; flex-shrink: 0; }
.testimonial-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    background: var(--color-bg);
    flex-shrink: 0;
}
.testimonial-name { font-weight: 700; font-size: .95rem; }
.testimonial-company { font-size: .83rem; color: var(--color-text-muted); }

/* ---- Blog Cards ---- */
.blog-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.75rem;
}
@media(min-width:640px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media(min-width:1024px) { .blog-grid { grid-template-columns: repeat(3, 1fr); } }

.blog-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: opacity .85s cubic-bezier(.2,0,0,1), transform .85s cubic-bezier(.2,0,0,1), box-shadow var(--transition);
}
.blog-card.is-visible:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.blog-card__image { aspect-ratio: 16/9; background: var(--color-bg); overflow: hidden; }
.blog-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.blog-card:hover .blog-card__image img { transform: scale(1.04); }
.blog-card__body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.blog-card__category {
    display: inline-block;
    background: rgba(14,57,118,.08);
    color: var(--color-primary);
    font-size: .78rem;
    font-weight: 700;
    padding: .2rem .65rem;
    border-radius: 2rem;
    margin-bottom: .75rem;
}
.blog-card__title { font-size: 1.05rem; margin-bottom: .6rem; flex: 1; }
.blog-card__meta { font-size: .82rem; color: var(--color-text-muted); display: flex; gap: 1rem; align-items: center; }
.blog-card__meta i { font-size: .75rem; }
.blog-card__link {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    color: var(--color-primary);
    font-weight: 600;
    font-size: .9rem;
    margin-top: 1rem;
    transition: gap var(--transition);
}
.blog-card:hover .blog-card__link { gap: .7rem; }

/* ---- FAQ ---- */
.faq-list { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 1rem; }
.faq-item {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: box-shadow var(--transition);
}
.faq-item.is-open { box-shadow: var(--shadow-sm); border-color: rgba(14,57,118,.2); }
.faq-question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    cursor: pointer;
    background: none;
    border: none;
    width: 100%;
    text-align: left;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-primary);
    transition: background var(--transition);
}
.faq-question:hover { background: rgba(14,57,118,.03); }
.faq-icon {
    width: 28px;
    height: 28px;
    background: rgba(14,57,118,.08);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    font-size: .7rem;
    flex-shrink: 0;
    transition: background var(--transition), transform var(--transition);
}
.faq-item.is-open .faq-icon { background: var(--color-primary); color: #fff; transform: rotate(180deg); }
.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height .4s ease, padding .3s ease;
}
.faq-item.is-open .faq-answer { max-height: 600px; }
.faq-answer-inner { padding: 0 1.5rem 1.5rem; font-size: 1rem; color: var(--color-text-muted); line-height: 1.75; }

/* ---- CTA Section ---- */
.cta-section {
    background: linear-gradient(135deg, var(--color-primary) 0%, #1a4f9e 100%);
    padding: 5rem 0;
    text-align: center;
    position: relative;
    position: relative;
    overflow: hidden;
}
.cta-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='40' cy='40' r='30'/%3E%3C/g%3E%3C/svg%3E") repeat;
}
.cta-section * { position: relative; z-index: 1; }
.cta-section h2 { color: #fff; margin-bottom: 1rem; }
.cta-section p  { color: rgba(255,255,255,.8); font-size: 1.1rem; margin-bottom: 2.5rem; max-width: 560px; margin-left: auto; margin-right: auto; }
.cta-btns { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ---- Logo Bar ---- */
.logos-bar {
    padding: 2.5rem 0;
    background: var(--color-bg);
}
.logos-bar__label {
    text-align: center;
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-primary);
    margin-bottom: 1.75rem;
}
.logos-grid {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 2rem 3rem;
}
.logos-grid__item {
    display: flex;
    align-items: center;
    justify-content: center;
}
.logos-grid__item img {
    height: 38px;
    min-height: 38px;
    max-height: 38px;
    width: auto;
    object-fit: contain;
    opacity: .5;
    transition: opacity .3s;
}
.logos-grid__item img:hover {
    opacity: 1;
}

/* ---- Breadcrumbs ---- */
.breadcrumbs { padding: .75rem 0; margin-bottom: 1rem; }
.breadcrumbs ol { display: flex; align-items: center; flex-wrap: wrap; gap: .25rem; list-style: none; }
.breadcrumbs li { display: flex; align-items: center; gap: .25rem; font-size: .88rem; color: var(--color-text-muted); }
.breadcrumbs a { color: var(--color-text-muted); }
.breadcrumbs a:hover { color: var(--color-primary); }
.breadcrumbs li:last-child { color: var(--color-primary); font-weight: 500; }
.breadcrumbs__sep { color: var(--color-border); font-size: .65rem; }

/* ---- Page Hero (subpages) ---- */
.page-hero {
    background: linear-gradient(135deg, var(--color-primary) 0%, #1a4f9e 100%);
    padding: calc(72px + 2.5rem) 0 3rem;
    position: relative;
    overflow: hidden;
    margin-top: -72px;
}
.page-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url('/assets/images/overlay.webp') center center / cover no-repeat;
    pointer-events: none;
    z-index: 0;
}
.page-hero * { position: relative; z-index: 1; }
.page-hero .breadcrumbs { margin-bottom: 1.5rem; }
.page-hero .breadcrumbs li { color: rgba(255,255,255,.65); }
.page-hero .breadcrumbs a { color: rgba(255,255,255,.65); }
.page-hero .breadcrumbs a:hover { color: #fff; }
.page-hero .breadcrumbs li:last-child { color: rgba(255,255,255,.95); }
.page-hero .breadcrumbs__sep { color: rgba(255,255,255,.3); }
.page-hero-icon {
    width: 64px;
    height: 64px;
    background: rgba(255,255,255,.12);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: var(--color-accent);
    flex-shrink: 0;
}
.page-hero .page-hero-title {
    display: flex;
    align-items: flex-start;
    gap: 1.25rem;
    margin-bottom: .75rem;
}
.page-hero h1 { color: #fff; margin-bottom: 0; }
.page-hero p  { color: rgba(255,255,255,.8); font-size: 1.1rem; margin-bottom: 1.5rem; }

/* ---- Offer Feature List ---- */
.feature-list { list-style: none; display: flex; flex-direction: column; gap: .85rem; }
.feature-list li { display: flex; align-items: flex-start; gap: .8rem; font-size: 1rem; line-height: 1.55; }
.feature-list li i { color: var(--color-accent); font-size: .9rem; margin-top: .25rem; flex-shrink: 0; }

/* ---- Content Rich Layout Classes (for post content) ---- */
.post-content > * {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .65s cubic-bezier(.2,0,0,1), transform .65s cubic-bezier(.2,0,0,1);
}
.post-content > *.in-view {
    opacity: 1;
    transform: translateY(0);
}
.post-content h2 { margin-top: 2.5rem; margin-bottom: 1rem; }
.post-content h3 { margin-top: 2rem; margin-bottom: .75rem; }
.post-content p  { margin-bottom: 1.25rem; }
.post-content ul, .post-content ol { margin: 1rem 0 1.5rem 1.5rem; line-height: 1.75; }
.legal-doc ol { list-style: decimal; }
.legal-doc ol li { margin-bottom: .65rem; }
.legal-doc ol ul { margin-top: .5rem; }
.legal-doc h2 { margin-top: 2.5rem; }
.legal-doc h3 { margin-top: 1.5rem; }
.post-content li { margin-bottom: .4rem; }
.post-content a  { color: var(--color-primary); text-decoration: underline; text-underline-offset: 3px; }
.post-content a.btn { text-decoration: none; }
.post-content img { border-radius: var(--radius-md); margin: 0 0 2rem 0; }
.post-content table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; font-size: .95rem; }
.post-content th { background: var(--color-primary); color: #fff; padding: .75rem 1rem; text-align: left; }
.post-content td { padding: .65rem 1rem; border-bottom: 1px solid var(--color-border); }
.post-content tr:nth-child(even) td { background: var(--color-bg); }

/* Content layout helpers */
.content-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    background: linear-gradient(135deg, var(--color-primary), #1a4f9e);
    color: #fff;
    border-radius: var(--radius-lg);
    padding: 1.75rem 2rem;
    margin: 2rem 0;
}
.content-banner strong { font-size: 1.15rem; color: #fff; }
.content-grid-2 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    margin: 2rem 0;
}
@media(min-width:640px) { .content-grid-2 { grid-template-columns: repeat(2, 1fr); } }
.content-grid-3 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    margin: 2rem 0;
}
@media(min-width:640px) { .content-grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media(min-width:1024px) { .content-grid-3 { grid-template-columns: repeat(3, 1fr); } }
.content-box {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 1.5rem;
    transition: box-shadow var(--transition), transform var(--transition);
}
.content-box:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.content-box h3 { font-size: 1.05rem; margin-bottom: .5rem; }
.content-box p  { font-size: .93rem; color: var(--color-text-muted); }
.content-image-text {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    align-items: center;
    margin: 2rem 0;
}
@media(min-width:768px) { .content-image-text { grid-template-columns: 1fr 1fr; } }
.content-image-text img { border-radius: var(--radius-lg); width: 100%; }
.content-highlight {
    background: rgba(255,160,0,.08);
    border-left: 4px solid var(--color-accent);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    padding: 1.25rem 1.5rem;
    margin: 2rem 0;
}
.content-highlight p { color: var(--color-text); font-weight: 500; }
.content-highlight pre { margin-top: .75rem; }

/* Code blocks in content */
pre {
    background: #f4f6fa;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 1.1rem 1.25rem;
    overflow-x: auto;
    max-width: 100%;
    margin: 1.5rem 0;
    font-size: .85rem;
    line-height: 1.65;
}
pre code {
    background: none;
    border: none;
    padding: 0;
    font-size: inherit;
    color: #0e3976;
    font-family: 'Consolas', 'Monaco', 'Courier New', monospace;
}
code {
    background: rgba(14,57,118,.07);
    color: #0e3976;
    font-family: 'Consolas', 'Monaco', 'Courier New', monospace;
    font-size: .875em;
    padding: .15em .4em;
    border-radius: .25rem;
}


/* ---- Contact Form ---- */
.contact-trust-bar {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 3rem;
}
.contact-trust-item {
    display: flex;
    align-items: center;
    gap: .6rem;
    background: #fff;
    border: 1.5px solid var(--color-border);
    border-radius: 2rem;
    padding: .6rem 1.35rem;
    font-size: .88rem;
    font-weight: 600;
    color: var(--color-primary);
    box-shadow: var(--shadow-sm);
}
.contact-trust-item i { color: var(--color-accent); }

.contact-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    align-items: start;
}
@media(min-width:1024px) { .contact-grid { grid-template-columns: 3fr 2fr; } }

.contact-form {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2.5rem;
    box-shadow: var(--shadow-sm);
}
.form-group { margin-bottom: 1.25rem; }
.form-label { display: block; font-size: .9rem; font-weight: 600; color: var(--color-text); margin-bottom: .4rem; }
.form-label span { color: var(--color-accent); }
.form-control {
    width: 100%;
    padding: .85rem 1rem;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 1rem;
    font-family: inherit;
    color: var(--color-text);
    background: #fff;
    transition: border-color var(--transition), box-shadow var(--transition);
    outline: none;
}
.form-control:focus { border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(14,57,118,.1); }
textarea.form-control { resize: vertical; min-height: 150px; }
.form-row { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media(min-width:640px) { .form-row { grid-template-columns: repeat(2, 1fr); } }
.form-checkbox { cursor: pointer; font-size: .83rem; color: var(--color-text-muted); line-height: 1.55; }
.form-checkbox input { width: 16px; height: 16px; margin-top: .15rem; flex-shrink: 0; accent-color: var(--color-primary); cursor: pointer; }
.form-checkbox a { color: var(--color-primary); }

/* Honeypot — bots fill it, humans never see it */
.hp-trap { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; opacity: 0; pointer-events: none; }

/* Contact dark info card */
.contact-info-card {
    background: var(--color-primary);
    border-radius: var(--radius-lg);
    padding: 2.25rem 2rem;
    color: #fff;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.contact-info-card__header { margin-bottom: 1.75rem; }
.contact-info-card__title { font-size: 1.2rem; color: #fff; margin-bottom: .3rem; }
.contact-info-card__subtitle { font-size: .83rem; color: rgba(255,255,255,.6); line-height: 1.5; }
.contact-info-card__items { display: flex; flex-direction: column; gap: 1.25rem; margin-bottom: 1.75rem; }
.contact-info-card__item { display: flex; gap: .85rem; align-items: flex-start; }
.contact-info-card__icon {
    width: 40px; height: 40px; flex-shrink: 0;
    background: rgba(255,255,255,.12);
    border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    font-size: .95rem; color: var(--color-accent);
}
.contact-info-card__text { flex: 1; }
.contact-info-card__text h4 { font-size: .7rem; color: rgba(255,255,255,.5); margin-bottom: .2rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }
.contact-info-card__text a,
.contact-info-card__text p { font-size: .93rem; color: rgba(255,255,255,.9); line-height: 1.5; }
.contact-info-card__text a:hover { color: var(--color-accent); }
.contact-info-card__divider { border: none; border-top: 1px solid rgba(255,255,255,.12); margin: 0 0 1.5rem; }
.contact-info-card__social { display: flex; gap: .65rem; }
.contact-info-card__social a {
    width: 42px; height: 42px;
    background: rgba(255,255,255,.1);
    border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,.75); font-size: 1rem;
    text-decoration: none;
    transition: background var(--transition), color var(--transition);
}
.contact-info-card__social a:hover { background: var(--color-accent); color: #fff; }

/* Contact mini value props */
.contact-values-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}
@media(max-width:767px) { .contact-values-grid { grid-template-columns: 1fr; gap: 1rem; } }
.contact-value-card {
    text-align: center;
    padding: 1.75rem 1.25rem;
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    transition: transform var(--transition), box-shadow var(--transition);
}
.contact-value-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.contact-value-card__icon {
    width: 56px; height: 56px;
    border-radius: 50%;
    background: rgba(14,57,118,.07);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; color: var(--color-primary);
    margin: 0 auto .85rem;
}
.contact-value-card h3 { font-size: .95rem; margin-bottom: .35rem; }
.contact-value-card p  { font-size: .83rem; color: var(--color-text-muted); line-height: 1.55; }

.map-embed { border-radius: var(--radius-lg); overflow: hidden; margin-top: 1.5rem; box-shadow: var(--shadow-sm); }
.map-embed iframe { display: block; width: 100%; }

/* ---- Dictionary / Slownik ---- */
.slownik-search { max-width: 480px; margin: 0 auto 3rem; position: relative; }
.slownik-search input {
    width: 100%;
    padding: .9rem 1.25rem .9rem 3rem;
    border: 2px solid var(--color-border);
    border-radius: 3rem;
    font-size: 1rem;
    outline: none;
    transition: border-color var(--transition);
}
.slownik-search input:focus { border-color: var(--color-primary); }
.slownik-search i { position: absolute; left: 1.1rem; top: 50%; transform: translateY(-50%); color: var(--color-text-muted); }

.slownik-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}
@media(min-width:640px) { .slownik-grid { grid-template-columns: repeat(2, 1fr); } }
@media(min-width:1024px) { .slownik-grid { grid-template-columns: repeat(3, 1fr); } }

/* Alphabet grid */
.slownik-alpha-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: .85rem;
}
@media(max-width:1023px) { .slownik-alpha-grid { grid-template-columns: repeat(4, 1fr); } }
@media(max-width:599px)  { .slownik-alpha-grid { grid-template-columns: repeat(3, 1fr); } }

.slownik-alpha-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 1rem 1.1rem 1.2rem;
    transition: border-color var(--transition), box-shadow var(--transition);
}
.slownik-alpha-card:not(.slownik-alpha-card--empty):hover {
    border-color: rgba(14,57,118,.25);
    box-shadow: var(--shadow-sm);
}
.slownik-alpha-card--empty { opacity: .6; }

.slownik-alpha-card__letter {
    font-size: 1.55rem;
    font-weight: 800;
    color: var(--color-primary);
    line-height: 1;
    margin-bottom: .55rem;
}
.slownik-alpha-card--empty .slownik-alpha-card__letter { color: rgba(14,57,118,.18); }

.slownik-alpha-card__line {
    height: 1px;
    background: var(--color-border);
    margin-bottom: .7rem;
}
.slownik-alpha-card:not(.slownik-alpha-card--empty) .slownik-alpha-card__line { background: var(--color-primary); opacity: .18; }

.slownik-alpha-card__entry {
    display: block;
    font-size: .85rem;
    font-weight: 700;
    color: var(--color-primary);
    text-decoration: none;
    line-height: 1.35;
    padding: .25rem 0;
    transition: color var(--transition);
}
.slownik-alpha-card__entry:hover { color: var(--color-accent); }
.slownik-alpha-card__entry + .slownik-alpha-card__entry {
    border-top: 1px solid var(--color-border);
    margin-top: .2rem;
}
.slownik-alpha-card__none {
    font-size: .8rem;
    color: var(--color-text-muted);
    font-style: italic;
}

.slownik-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.slownik-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--color-primary); }
.slownik-card__letter { font-size: 2rem; font-weight: 800; color: rgba(14,57,118,.12); line-height: 1; }
.slownik-card__title { font-size: 1.05rem; font-weight: 700; color: var(--color-primary); }
.slownik-card__excerpt { font-size: .88rem; color: var(--color-text-muted); line-height: 1.6; flex: 1; }
.slownik-card__link {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .88rem;
    font-weight: 600;
    color: var(--color-accent);
    margin-top: .5rem;
}
.slownik-card:hover .slownik-card__link { gap: .6rem; }

/* ---- Blog Article Layout ---- */
.article-layout { display: grid; grid-template-columns: 1fr; gap: 3rem; }
.article-layout > * { min-width: 0; }
@media(min-width:1200px) { .article-layout { grid-template-columns: 1fr 320px; } }
.article-header { margin-bottom: 2rem; }
.article-category {
    display: inline-block;
    background: rgba(14,57,118,.08);
    color: var(--color-primary);
    font-size: .82rem;
    font-weight: 700;
    padding: .25rem .8rem;
    border-radius: 2rem;
    margin-bottom: 1rem;
}
.article-meta { display: flex; gap: 1.25rem; align-items: center; flex-wrap: wrap; margin-top: 1rem; font-size: .88rem; color: var(--color-text-muted); }
.article-meta i { font-size: .75rem; color: var(--color-accent); }
.article-featured-image { border-radius: var(--radius-lg); width: 100%; margin-bottom: 2.5rem; }

/* Sidebar */
.article-sidebar { display: flex; flex-direction: column; gap: 1.5rem; align-self: start; position: sticky; top: calc(var(--header-h, 72px) + 1.5rem); }
.sidebar-widget { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 1.5rem; }
.sidebar-widget__title { font-size: 1rem; font-weight: 700; color: var(--color-primary); margin-bottom: 1rem; padding-bottom: .75rem; border-bottom: 1px solid var(--color-border); }
.related-list { list-style: none; display: flex; flex-direction: column; gap: .85rem; }
.related-list a { font-size: .93rem; color: var(--color-text); display: flex; gap: .5rem; align-items: flex-start; }
.related-list a:hover { color: var(--color-primary); }
.related-list i { color: var(--color-accent); font-size: .75rem; margin-top: .3rem; flex-shrink: 0; }

/* Sidebar audit widget */
.sidebar-widget--audit { position: relative; overflow: hidden; }
.sidebar-widget--audit::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--color-accent), var(--color-secondary)); }
.sidebar-widget__audit-icon { font-size: 1.5rem; color: var(--color-accent); line-height: 1; }

/* Sidebar share buttons */
.sidebar-share-btn { display: inline-flex; align-items: center; justify-content: center; width: 2.4rem; height: 2.4rem; border-radius: 50%; font-size: .95rem; color: #fff; transition: transform .2s, opacity .2s; }
.sidebar-share-btn:hover { transform: translateY(-2px); opacity: .88; }
.sidebar-share-btn--fb { background: #1877f2; }
.sidebar-share-btn--li { background: #0a66c2; }
.sidebar-share-btn--tw { background: #000; }

/* ---- Team Cards ---- */
.team-grid { display: grid; grid-template-columns: 1fr; gap: 1.75rem; }
@media(min-width:640px) { .team-grid { grid-template-columns: repeat(2, 1fr); } }
@media(min-width:1024px) { .team-grid { grid-template-columns: repeat(4, 1fr); } }
.team-card {
    text-align: center;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2rem 1.5rem;
    transition: transform var(--transition), box-shadow var(--transition);
}
.team-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.team-avatar {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    object-fit: cover;
    margin: 0 auto 1.25rem;
    border: 3px solid rgba(14,57,118,.1);
}
.team-name { font-size: 1.05rem; font-weight: 700; margin-bottom: .25rem; }
.team-role { font-size: 1rem; font-weight: 900; color: var(--color-text-muted); }

/* ---- Values Cards ---- */
.values-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media(min-width:640px) { .values-grid { grid-template-columns: repeat(2, 1fr); } }
@media(min-width:1024px) { .values-grid { grid-template-columns: repeat(4, 1fr); } }
.value-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2rem 1.5rem;
    text-align: center;
    transition: transform var(--transition), box-shadow var(--transition);
}
.value-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.value-icon { font-size: 2.5rem; color: var(--color-primary); margin-bottom: 1rem; display: block; }
.value-card:hover .value-icon { color: var(--color-accent); }
.value-card h3 { font-size: 1.05rem; margin-bottom: .5rem; }
.value-card p  { font-size: .9rem; color: var(--color-text-muted); }

/* ---- 404 ---- */
.page-404 { text-align: center; padding: 6rem 1rem; }
.page-404__code { font-size: clamp(6rem, 18vw, 12rem); font-weight: 800; color: rgba(14,57,118,.08); line-height: 1; }
.page-404 h1 { margin-top: -2rem; margin-bottom: 1rem; }
.page-404 p  { font-size: 1.1rem; color: var(--color-text-muted); margin-bottom: 2rem; }

/* ---- Footer ---- */
.site-footer { background: var(--color-bg-dark); color: rgba(255,255,255,.8); }
.footer-top { padding: 4.5rem 0 3rem; }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
@media(min-width:640px) { .footer-grid { grid-template-columns: repeat(2, 1fr); } }
@media(min-width:1024px) { .footer-grid { grid-template-columns: 1.8fr 1.6fr 1fr 1.1fr; } }

.footer-logo { display: inline-flex; margin-bottom: 1rem; }
.footer-desc { font-size: .93rem; line-height: 1.7; color: rgba(255,255,255,.6); margin-bottom: 1.5rem; }
.footer-social { display: flex; gap: .75rem; }
.social-link {
    width: 38px;
    height: 38px;
    background: rgba(255,255,255,.1);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,.8);
    font-size: .95rem;
    transition: background var(--transition), color var(--transition);
}
.social-link:hover { background: var(--color-accent); color: #fff; }

.footer-heading { display: block; font-size: 1rem; font-weight: 700; color: #fff; margin-bottom: 1.25rem; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: .65rem; }
.footer-links a { font-size: .9rem; color: rgba(255,255,255,.6); display: flex; align-items: center; gap: .5rem; transition: color var(--transition); }
.footer-links a i { font-size: .65rem; color: var(--color-accent); }
.footer-links a:hover { color: #fff; }

.footer-contact { list-style: none; display: flex; flex-direction: column; gap: .9rem; }
.footer-contact li { display: flex; align-items: flex-start; gap: .75rem; font-size: .9rem; }
.footer-contact i { color: var(--color-accent); margin-top: .2rem; flex-shrink: 0; }
.footer-contact a { color: rgba(255,255,255,.65); }
.footer-contact a:hover { color: #fff; }
.footer-contact span { color: rgba(255,255,255,.65); }

.footer-bottom { border-top: 1px solid rgba(255,255,255,.08); padding: 1.5rem 0; }
.footer-bottom-inner { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 1rem; }
.footer-legal { justify-self: end; }
.footer-copy { font-size: .85rem; color: rgba(255,255,255,.45); }
.footer-legal { list-style: none; display: flex; gap: 1.5rem; flex-wrap: wrap; }
.footer-legal a { font-size: .85rem; color: rgba(255,255,255,.45); transition: color var(--transition); }
.footer-legal a:hover { color: rgba(255,255,255,.8); }
.footer-legal-btn { background: none; border: none; padding: 0; margin: 0; font: inherit; font-size: .85rem; font-weight: 600; color: rgba(255,255,255,.45); cursor: pointer; transition: color var(--transition); line-height: inherit; letter-spacing: inherit; }
.footer-legal-btn:hover { color: rgba(255,255,255,.8); }

/* ---- Mobile fixes ---- */
@media(max-width:767px) {
    .home-services-btns { justify-content: center; }
    .hero-btns { justify-content: center; }
    .content-banner { flex-direction: column; align-items: center; text-align: center; }
    .content-banner .btn { align-self: center; }
    .sidebar-widget .btn:not(.btn--full) { display: flex; justify-content: center; width: 100%; }
    .pricing-card__price span { display: block; margin-top: .1rem; }
}
@media(max-width:767px), (pointer: coarse) {
    .cursor-rocket, canvas[style*="position:fixed"] { display: none !important; }
}

/* ---- Scroll to top ---- */
#scroll-top {
    position: fixed;
    z-index: 9800;
    bottom: 1.5rem;
    right: 1.25rem;
    width: 64px;
    height: 64px;
    padding: 0;
    background: none;
    border: none;
    cursor: pointer;
    opacity: 0;
    transform: translateY(70px);
    transition: opacity .35s ease, transform .4s cubic-bezier(.2,0,0,1);
    pointer-events: none;
}
#scroll-top.is-visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: all;
}
#scroll-top.is-launching {
    opacity: 0;
    transform: translateY(-220px);
    pointer-events: none;
    transition: opacity .4s ease .7s, transform 1s cubic-bezier(.4,0,.8,1);
}
#scroll-top svg { display: block; transform: rotate(-90deg); }
#scroll-top .scroll-top__bg       { fill: transparent; stroke: rgba(14,57,118,.15); transition: opacity .15s ease; }
#scroll-top .scroll-top__progress { fill: none; stroke: #ffa000; transition: opacity .15s ease; }
#scroll-top.is-launching .scroll-top__bg,
#scroll-top.is-launching .scroll-top__progress { opacity: 0; }
#scroll-top .scroll-top__icon {
    position: absolute;
    top: calc(50% + 5px); left: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
}

/* ---- Phone button ---- */
@keyframes phone-pulse {
    0%   { transform: scale(1);    opacity: .5; }
    70%  { transform: scale(1.6);  opacity: 0;  }
    100% { transform: scale(1.6);  opacity: 0;  }
}
#phone-btn {
    position: fixed;
    z-index: 9800;
    bottom: 1.5rem;
    left: 1.25rem;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: transparent;
    border: 3px solid rgba(255,160,0,.3);
    color: var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    text-decoration: none;
    cursor: pointer;
    transition: border-color .2s, transform .2s;
}
#phone-btn:hover { border-color: #ffa000; transform: scale(1.08); }
#phone-btn i { filter: drop-shadow(0 0 2px #fff) drop-shadow(0 0 1px #fff); }
#phone-btn::before {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: 50%;
    border: 3px solid #ffa000;
    animation: phone-pulse 2s ease-out infinite;
}

/* ---- Callback bubble ---- */
#callback-bubble {
    position: fixed;
    z-index: 9802;
    bottom: 1.5rem;
    left: calc(1.25rem + 64px + 12px);
    width: min(250px, calc(100vw - 1.25rem - 64px - 24px));
    background: #fff;
    border-radius: 14px;
    border: 1px solid var(--color-border, #e2e8f0);
    box-shadow: 0 8px 32px rgb(14 57 118 / .13);
    padding: .6rem;
    opacity: 0;
    transform: translateX(-8px);
    transition: opacity .3s ease, transform .3s ease;
    pointer-events: none;
    overflow: visible;
    display: flex;
    align-items: flex-end;
    gap: .5rem;
    cursor: pointer;
}
#callback-bubble.is-visible {
    opacity: 1;
    transform: translateX(0);
    pointer-events: all;
}
#callback-bubble::after {
    content: '';
    position: absolute;
    left: -9px;
    bottom: 22px;
    width: 9px;
    height: 16px;
    background: #fff;
    clip-path: polygon(100% 0, 100% 100%, 0 50%);
}
.callback-bubble__avatar {
    flex-shrink: 0;
    width: auto;
    height: 120px;
    margin-top: -60px;
    margin-bottom: 0;
    object-fit: contain;
    object-position: bottom;
    transform: scaleX(-1);
    pointer-events: none;
    border-radius: 0 0 0 14px;
    display: block;
    align-self: flex-end;
}
.callback-bubble__content {
    flex: 1;
    position: relative;
}
#callback-bubble p {
    margin: 0;
    font-size: .82rem;
    line-height: 1.5;
    color: var(--color-text, #1e293b);
}
#callback-bubble-close {
    position: absolute;
    top: -6px;
    right: -4px;
    width: 22px;
    height: 22px;
    border: none;
    background: none;
    cursor: pointer;
    font-size: 1.1rem;
    line-height: 1;
    color: var(--color-text-muted, #94a3b8);
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: background .15s, color .15s;
}
#callback-bubble-close:hover { background: #f1f5f9; color: #0e3976; }

/* ---- Callback modal overrides ---- */
.callback-phone-row {
    display: flex;
    gap: .6rem;
    align-items: stretch;
}
.callback-phone-row select {
    flex-shrink: 0;
    padding: .7rem .65rem;
    border: 1.5px solid #c3d0e8;
    border-radius: .6rem;
    font-size: .9rem;
    background: #f8fafc;
    color: #0e3976;
    cursor: pointer;
    outline: none;
    transition: border-color .2s;
}
.callback-phone-row select:focus { border-color: #1a73e8; }
.callback-phone-row input {
    flex: 1;
    padding: .7rem .9rem;
    border: 1.5px solid #c3d0e8;
    border-radius: .6rem;
    font-size: .9rem;
    outline: none;
    transition: border-color .2s;
}
.callback-phone-row input:focus { border-color: #1a73e8; }
.callback-error {
    margin: .6rem 0 0;
    font-size: .82rem;
    color: #d93025;
}

/* ---- Alerts / Notices ---- */
.alert { padding: 1rem 1.25rem; border-radius: var(--radius-sm); margin-bottom: 1rem; font-size: .95rem; }
.alert--success { background: #d1fae5; border: 1px solid #6ee7b7; color: #065f46; }
.alert--error   { background: #fee2e2; border: 1px solid #fca5a5; color: #991b1b; }

/* ================================================================
   SEO Offer Page — Pozycjonowanie Stron
   ================================================================ */

/* Scope strip */
.seo-scope-strip {
    background: rgba(14,57,118,.04);
    border-bottom: 1px solid var(--color-border);
    padding: .8rem 0;
}
.seo-scope-strip-inner {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem .85rem;
    align-items: center;
    justify-content: center;
}
.seo-scope-tag {
    display: inline-flex;
    align-items: center;
    gap: .38rem;
    font-size: .78rem;
    font-weight: 600;
    color: var(--color-primary);
    padding: .26rem .7rem;
    background: rgba(14,57,118,.06);
    border-radius: 2rem;
    border: 1px solid rgba(14,57,118,.12);
    transition: background var(--transition), border-color var(--transition);
}
.seo-scope-tag i { color: var(--color-accent); font-size: .68rem; }

/* Intro 2-col layout */
.seo-intro-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}
@media(max-width:1023px) { .seo-intro-grid { grid-template-columns: 1fr; gap: 2.5rem; } }

/* Visual box — dark navy card with chart */
.seo-visual-box {
    background: linear-gradient(150deg, #091f4a 0%, #0e3976 55%, #163f83 100%);
    border-radius: var(--radius-lg);
    padding: 1.75rem;
    position: relative;
    overflow: hidden;
    box-shadow: 0 24px 64px rgba(14,57,118,.4), 0 4px 16px rgba(14,57,118,.2);
}
.seo-visual-box::before {
    content: '';
    position: absolute;
    top: -60px; right: -60px;
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(255,160,0,.12) 0%, transparent 70%);
    pointer-events: none;
}
.seo-chart-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}
.seo-chart-label {
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: rgba(255,255,255,.6);
}
.seo-chart-trend {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-size: .8rem;
    font-weight: 700;
    color: #4ade80;
    background: rgba(74,222,128,.12);
    border: 1px solid rgba(74,222,128,.22);
    padding: .18rem .55rem;
    border-radius: 2rem;
}
.seo-chart-bars {
    display: flex;
    align-items: flex-end;
    gap: 5px;
    height: 88px;
    margin-bottom: .55rem;
}
.seo-chart-bar {
    flex: 1;
    background: rgba(255,255,255,.18);
    border-radius: 3px 3px 0 0;
    height: 0;
    transition: height 1.4s cubic-bezier(.22,.61,.36,1);
    transition-delay: calc(var(--bar-i, 0) * 55ms);
}
.seo-chart-bar:last-child         { background: var(--color-accent); }
.seo-chart-bar:nth-last-child(2)  { background: rgba(255,160,0,.75); }
.seo-chart-bar:nth-last-child(3)  { background: rgba(255,160,0,.5);  }
.seo-chart-bar:nth-last-child(4)  { background: rgba(255,255,255,.38); }
.seo-chart-bar:nth-last-child(5)  { background: rgba(255,255,255,.3);  }
.seo-chart-bar:nth-last-child(6)  { background: rgba(255,255,255,.24); }
.animate-on-scroll.is-visible .seo-chart-bar { height: var(--bar-h); }

.seo-chart-months {
    display: flex;
    justify-content: space-between;
    margin-bottom: 1.25rem;
}
.seo-chart-months span { font-size: .58rem; color: rgba(255,255,255,.3); flex: 1; text-align: center; }

/* SERP mini mockup */
.seo-serp-mock { background: #fff; border-radius: var(--radius-md); overflow: hidden; }
.seo-serp-chrome {
    background: #f1f3f4;
    padding: .42rem .7rem;
    display: flex;
    align-items: center;
    gap: .3rem;
    border-bottom: 1px solid #e0e0e0;
}
.seo-serp-dot { width: 7px; height: 7px; border-radius: 50%; }
.seo-serp-dot:nth-child(1) { background: #ff5f56; }
.seo-serp-dot:nth-child(2) { background: #ffbd2e; }
.seo-serp-dot:nth-child(3) { background: #27c93f; }
.seo-serp-urlbar {
    flex: 1;
    background: #fff;
    border-radius: 2rem;
    padding: .17rem .55rem;
    font-size: .64rem;
    color: #555;
    border: 1px solid #ddd;
    display: flex;
    align-items: center;
    gap: .3rem;
    margin-left: .25rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.seo-serp-urlbar i { color: #4caf50; font-size: .58rem; flex-shrink: 0; }
.seo-serp-body { padding: .55rem .65rem; display: flex; flex-direction: column; gap: .35rem; }
.seo-serp-result { padding: .42rem .48rem; border-radius: 4px; position: relative; }
.seo-serp-result--top {
    background: rgba(14,57,118,.05);
    border: 1.5px solid rgba(14,57,118,.18);
}
.seo-serp-result--top::after {
    content: '#1';
    position: absolute;
    right: .45rem; top: .38rem;
    font-size: .62rem;
    font-weight: 800;
    color: var(--color-accent);
    background: rgba(255,160,0,.12);
    padding: .08rem .32rem;
    border-radius: 2rem;
}
.seo-serp-url   { font-size: .62rem; color: #1a8036; font-weight: 500; }
.seo-serp-title { font-size: .7rem; font-weight: 700; color: #1558d6; line-height: 1.3; margin: .1rem 0; }
.seo-serp-desc  { font-size: .61rem; color: #666; line-height: 1.4; }
.seo-serp-result--dim .seo-serp-title,
.seo-serp-result--dim .seo-serp-desc { filter: blur(2px); opacity: .35; user-select: none; }

/* Process cards 3×2 grid */
.seo-process-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}
@media(max-width:1023px) { .seo-process-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:599px)  { .seo-process-grid { grid-template-columns: 1fr; } }

/* ---- Collab steps stepper ---- */
.collab-steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    position: relative;
}
.collab-steps::before {
    content: '';
    position: absolute;
    top: 2.1rem;
    left: calc(12.5% + .5rem);
    right: calc(12.5% + .5rem);
    height: 2px;
    background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
    z-index: 0;
}
.collab-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 0 1rem;
    position: relative;
    z-index: 1;
}
.collab-step__circle {
    width: 4.2rem; height: 4.2rem;
    border-radius: 50%;
    background: var(--color-primary);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem;
    margin-bottom: 1.25rem;
    box-shadow: 0 4px 18px rgba(14,57,118,.25);
    flex-shrink: 0;
    border: 3px solid #fff;
    outline: 2px solid var(--color-primary);
    transition: transform .25s;
}
.collab-step__circle--accent { background: var(--color-accent); outline-color: var(--color-accent); box-shadow: 0 4px 18px rgba(255,160,0,.3); }
.collab-step:hover .collab-step__circle { transform: scale(1.08); }
.collab-step__body h3 { font-size: 1rem; font-weight: 700; color: var(--color-primary); margin-bottom: .5rem; }
.collab-step__body p  { font-size: .87rem; line-height: 1.6; color: var(--color-text-muted); margin: 0; }
@media(max-width:767px) {
    .collab-steps { grid-template-columns: 1fr 1fr; gap: 2rem; }
    .collab-steps::before { display: none; }
}
@media(max-width:480px) {
    .collab-steps { grid-template-columns: 1fr; gap: 1.5rem; }
    .collab-step { align-items: flex-start; text-align: left; flex-direction: row; gap: 1rem; }
    .collab-step__circle { margin-bottom: 0; flex-shrink: 0; width: 3rem; height: 3rem; font-size: 1.1rem; }
}

.seo-process-card {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 2rem 1.75rem;
    border: 1px solid var(--color-border);
    position: relative;
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.seo-process-card::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .4s ease;
}
.seo-process-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); border-color: rgba(14,57,118,.2); }
.seo-process-card:hover::after { transform: scaleX(1); }
.seo-process-card__num {
    font-size: 3.5rem;
    font-weight: 900;
    color: var(--color-primary);
    opacity: .055;
    position: absolute;
    top: .5rem; right: 1.2rem;
    line-height: 1;
    pointer-events: none;
}
.seo-process-card__icon {
    width: 48px; height: 48px;
    border-radius: var(--radius-md);
    background: rgba(14,57,118,.08);
    display: flex; align-items: center; justify-content: center;
    color: var(--color-primary);
    font-size: 1.2rem;
    margin-bottom: 1.25rem;
    transition: background var(--transition), color var(--transition);
}
.seo-process-card:hover .seo-process-card__icon { background: var(--color-primary); color: #fff; }
.seo-process-card:hover .service-img-wrap::before { background: var(--color-accent); }
.seo-process-card h3 { font-size: 1rem; margin-bottom: .6rem; }
.seo-process-card p  { font-size: .9rem; color: var(--color-text-muted); line-height: 1.6; }

/* Search channels 4-col grid */
.seo-channels-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
}
@media(max-width:1023px) { .seo-channels-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:599px)  { .seo-channels-grid { grid-template-columns: 1fr; } }

.seo-channel-card {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 2rem 1.5rem;
    border: 1px solid var(--color-border);
    text-align: center;
    position: relative;
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition);
}
.seo-channel-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: var(--ch-color, var(--color-primary));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .35s ease;
}
.seo-channel-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.seo-channel-card:hover::before { transform: scaleX(1); }
.seo-channel-icon {
    width: 58px; height: 58px;
    border-radius: 50%;
    background: var(--ch-bg, rgba(14,57,118,.08));
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 1.1rem;
    font-size: 1.45rem;
    color: var(--ch-color, var(--color-primary));
    transition: background var(--transition), color var(--transition);
}
.seo-channel-card:hover .seo-channel-icon { background: var(--ch-color, var(--color-primary)); color: #fff; }
.seo-channel-card h3 { font-size: .98rem; margin-bottom: .5rem; }
.seo-channel-card p  { font-size: .87rem; color: var(--color-text-muted); line-height: 1.55; }

/* Ranking pillars — dark bg section */
.seo-pillars-section {
    background: var(--color-primary);
    position: relative;
    overflow: hidden;
}
.seo-pillars-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.seo-pillars-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.75rem;
    position: relative;
    z-index: 1;
}
@media(max-width:1023px) { .seo-pillars-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:599px)  { .seo-pillars-grid { grid-template-columns: 1fr; gap: 1rem; } }

.seo-pillar {
    padding: 2rem 1.5rem;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255,255,255,.09);
    background: rgba(255,255,255,.05);
    text-align: center;
    transition: background var(--transition), transform var(--transition), border-color var(--transition);
}
.seo-pillar:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.18); transform: translateY(-4px); }
.seo-pillar__icon {
    width: 64px; height: 64px;
    border-radius: var(--radius-md);
    background: rgba(255,160,0,.15);
    border: 1px solid rgba(255,160,0,.3);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 1.25rem;
    font-size: 1.6rem;
    color: var(--color-accent);
    transition: background var(--transition), border-color var(--transition);
}
.seo-pillar:hover .seo-pillar__icon { background: rgba(255,160,0,.25); border-color: rgba(255,160,0,.5); }
.seo-pillar h3 { color: #fff; font-size: 1.05rem; margin-bottom: .6rem; }
.seo-pillar p  { color: rgba(255,255,255,.62); font-size: .89rem; line-height: 1.6; }

/* SEO knowledge expandable items */
.seo-knowledge-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
@media(max-width:767px) { .seo-knowledge-grid { grid-template-columns: 1fr; } }

.seo-knowledge-item {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    background: #fff;
    transition: border-color var(--transition);
}
.seo-knowledge-item.is-open { border-color: rgba(14,57,118,.28); }
.seo-knowledge-btn {
    width: 100%;
    display: flex;
    align-items: center;
    gap: .9rem;
    padding: 1.1rem 1.3rem;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    transition: background var(--transition);
}
.seo-knowledge-btn:hover { background: var(--color-bg); }
.seo-knowledge-btn__icon {
    width: 38px; height: 38px;
    border-radius: var(--radius-sm);
    background: rgba(14,57,118,.07);
    display: flex; align-items: center; justify-content: center;
    color: var(--color-primary);
    font-size: .92rem;
    flex-shrink: 0;
    transition: background var(--transition), color var(--transition);
}
.seo-knowledge-item.is-open .seo-knowledge-btn__icon { background: var(--color-primary); color: #fff; }
.seo-knowledge-btn__title { flex: 1; font-size: .96rem; font-weight: 700; color: var(--color-primary); }
.seo-knowledge-btn__arrow {
    color: var(--color-text-muted);
    font-size: .76rem;
    transition: transform .3s ease;
    flex-shrink: 0;
}
.seo-knowledge-item.is-open .seo-knowledge-btn__arrow { transform: rotate(180deg); }
.seo-knowledge-body { max-height: 0; overflow: hidden; transition: max-height .45s cubic-bezier(.4,0,.2,1); }
.seo-knowledge-body-inner {
    padding: 0 1.3rem 1.3rem;
    border-top: 1px solid var(--color-border);
}
.seo-knowledge-body-inner p { font-size: .91rem; color: var(--color-text-muted); line-height: 1.65; margin-top: .8rem; }
.seo-knowledge-item.is-open .seo-knowledge-body { max-height: 500px; }

/* ===== Web Visual Box — browser mockup (tworzenie stron) ===== */
.web-visual-box {
    background: linear-gradient(150deg, #091f4a 0%, #0e3976 55%, #163f83 100%);
    border-radius: var(--radius-lg);
    padding: 1.75rem;
    position: relative;
    overflow: hidden;
    box-shadow: 0 24px 64px rgba(14,57,118,.4), 0 4px 16px rgba(14,57,118,.2);
}
.web-visual-box::before {
    content: '';
    position: absolute;
    top: -60px; right: -60px;
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(255,160,0,.12) 0%, transparent 70%);
    pointer-events: none;
}
.web-browser-mock {
    background: #fff;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(0,0,0,.2);
}
.web-browser-bar {
    background: #f1f3f4;
    padding: .55rem .85rem;
    display: flex;
    align-items: center;
    gap: .4rem;
    border-bottom: 1px solid #e0e0e0;
}
.web-browser-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.web-browser-url {
    flex: 1;
    background: #fff;
    border-radius: 20px;
    height: 22px;
    margin-left: .4rem;
    display: flex; align-items: center;
    padding: 0 .65rem;
    font-size: .72rem;
    color: #555;
    gap: .3rem;
}
/* Mock nav */
.web-mock-nav {
    display: flex; align-items: center; justify-content: space-between;
    padding: .6rem .85rem;
    background: #0e3976;
}
.web-mock-logo { width: 60px; height: 10px; background: rgba(255,255,255,.7); border-radius: 3px; }
.web-mock-nav-links { display: flex; gap: .5rem; align-items: center; }
.web-mock-nav-item { width: 28px; height: 7px; background: rgba(255,255,255,.35); border-radius: 3px; }
.web-mock-nav-btn { width: 42px; height: 18px; background: #ffa000; border-radius: 4px; margin-left: .25rem; }
/* Mock hero */
.web-mock-hero {
    background: linear-gradient(120deg, #1a4f9e 0%, #0e3976 100%);
    padding: 1.1rem .85rem;
    display: flex; justify-content: space-between; align-items: center; gap: .75rem;
}
.web-mock-hero-text { flex: 1; }
.web-mock-h1 { height: 10px; background: rgba(255,255,255,.8); border-radius: 3px; width: 85%; }
.web-mock-btn { margin-top: .65rem; width: 60px; height: 18px; background: #ffa000; border-radius: 4px; }
.web-mock-hero-img { width: 55px; height: 55px; background: rgba(255,255,255,.12); border-radius: 8px; flex-shrink: 0; }
/* Mock cards */
.web-mock-cards {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: .5rem; padding: .75rem .85rem .85rem;
    background: #f8f9fb;
}
.web-mock-card {
    background: #fff; border-radius: 6px; padding: .6rem;
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
    display: flex; flex-direction: column; gap: .35rem;
}
.web-mock-card-icon { width: 20px; height: 20px; background: rgba(14,57,118,.1); border-radius: 4px; margin-bottom: .2rem; }
.web-mock-card-lines { display: flex; flex-direction: column; }
.web-mock-line { height: 6px; background: #e0e4ec; border-radius: 3px; }
/* Performance badges */
.web-perf-badges {
    display: flex; gap: .65rem; justify-content: center; flex-wrap: wrap; margin-top: 1.25rem;
}
.web-perf-badge {
    display: inline-flex; align-items: center; gap: .4rem;
    background: rgba(255,255,255,.12); color: #fff;
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 2rem; padding: .35rem .9rem;
    font-size: .82rem; font-weight: 600;
}

/* Shop visual mockup — e-commerce specific content */
.shop-mock-topbar {
    background: #0e3976;
    padding: .55rem .85rem;
    display: flex; align-items: center; gap: .5rem;
}
.shop-mock-topbar-logo { width: 50px; height: 9px; background: rgba(255,255,255,.7); border-radius: 3px; }
.shop-mock-search { flex: 1; height: 20px; background: rgba(255,255,255,.15); border-radius: 10px; margin: 0 .5rem; }
.shop-mock-cart-icon { width: 28px; height: 20px; background: #ffa000; border-radius: 4px; flex-shrink: 0; }
.shop-mock-cats {
    padding: .4rem .85rem;
    display: flex; gap: .4rem;
    background: #fff; border-bottom: 1px solid #e8eaf0;
}
.shop-mock-cat { width: 38px; height: 8px; background: #d5daea; border-radius: 3px; }
.shop-mock-products {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: .5rem; padding: .65rem .85rem .75rem;
    background: #f8f9fb;
}
.shop-mock-product {
    background: #fff; border-radius: 6px;
    overflow: hidden; box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.shop-mock-product-img {
    height: 44px;
    background: linear-gradient(135deg, #e8ecf5, #d0d8ea);
    position: relative;
}
.shop-mock-product-badge {
    position: absolute; bottom: 4px; right: 4px;
    width: 24px; height: 11px;
    background: #ffa000; border-radius: 2px;
}
.shop-mock-product-info { padding: .4rem .5rem .5rem; }
.shop-mock-product-name { height: 7px; width: 75%; background: #cdd2de; border-radius: 3px; }
.shop-mock-product-price { height: 9px; width: 40%; background: rgba(14,57,118,.45); border-radius: 3px; margin-top: .35rem; }
.shop-mock-product-btn { height: 13px; background: rgba(255,160,0,.25); border-radius: 3px; margin-top: .4rem; }

/* Shop build animation */
.animate-on-scroll .shop-mock-topbar,
.animate-on-scroll .shop-mock-cats,
.animate-on-scroll .shop-mock-product { opacity: 0; }
.animate-on-scroll.is-visible .shop-mock-topbar { animation: webBuild .35s ease forwards .35s; }
.animate-on-scroll.is-visible .shop-mock-cats   { animation: webBuild .35s ease forwards .6s; }
.animate-on-scroll.is-visible .shop-mock-product:nth-child(1) { animation: webBuild .3s ease forwards .85s; }
.animate-on-scroll.is-visible .shop-mock-product:nth-child(2) { animation: webBuild .3s ease forwards 1.05s; }
.animate-on-scroll.is-visible .shop-mock-product:nth-child(3) { animation: webBuild .3s ease forwards 1.25s; }
.animate-on-scroll.is-visible .shop-mock-product:nth-child(4) { animation: webBuild .3s ease forwards 1.45s; }

/* Pricing footnotes */
.pricing-footnotes {
    margin-top: 2rem;
    padding: 1.25rem 1.5rem;
    background: rgba(255,255,255,.06);
    border-radius: var(--radius-md);
    border: 1px solid rgba(255,255,255,.1);
}
.pricing-footnotes ol { list-style: decimal; padding-left: 1.25rem; display: flex; flex-direction: column; gap: .5rem; }
.pricing-footnotes li { font-size: .8rem; color: rgba(255,255,255,.6); line-height: 1.55; }

/* Build animation — strona "składa się" element po elemencie */
@keyframes webBuild {
    from { opacity: 0; transform: translateY(7px); }
    to   { opacity: 1; transform: translateY(0); }
}
.animate-on-scroll .web-mock-nav,
.animate-on-scroll .web-mock-hero,
.animate-on-scroll .web-mock-card,
.animate-on-scroll .web-perf-badge { opacity: 0; }

.animate-on-scroll.is-visible .web-mock-nav {
    animation: webBuild .35s ease forwards .35s;
}
.animate-on-scroll.is-visible .web-mock-hero {
    animation: webBuild .35s ease forwards .65s;
}
.animate-on-scroll.is-visible .web-mock-card:nth-child(1) {
    animation: webBuild .3s ease forwards .95s;
}
.animate-on-scroll.is-visible .web-mock-card:nth-child(2) {
    animation: webBuild .3s ease forwards 1.15s;
}
.animate-on-scroll.is-visible .web-mock-card:nth-child(3) {
    animation: webBuild .3s ease forwards 1.35s;
}
.animate-on-scroll.is-visible .web-perf-badge:nth-child(1) {
    animation: webBuild .3s ease forwards 1.55s;
}
.animate-on-scroll.is-visible .web-perf-badge:nth-child(2) {
    animation: webBuild .3s ease forwards 1.7s;
}
.animate-on-scroll.is-visible .web-perf-badge:nth-child(3) {
    animation: webBuild .3s ease forwards 1.85s;
}

/* SEO Components — always-visible card grid */
.seo-comp-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}
@media(max-width:1023px) { .seo-comp-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:599px)  { .seo-comp-grid { grid-template-columns: 1fr; } }
.seo-comp-grid--2col { grid-template-columns: repeat(2, 1fr); }
@media(max-width:599px) { .seo-comp-grid--2col { grid-template-columns: 1fr; } }

/* ---- Risk cards (oferta-support) ---- */
.risk-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
@media(max-width:767px) { .risk-grid { grid-template-columns: 1fr; } }

.risk-card {
    display: flex;
    gap: 1.25rem;
    background: #fff;
    border: 1px solid var(--color-border);
    border-left: 4px solid var(--ri, #e53e3e);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    padding: 1.5rem;
    transition: box-shadow .25s, transform .25s;
}
.risk-card:hover { box-shadow: 0 8px 32px rgba(14,57,118,.09); transform: translateY(-2px); }
.risk-card--wide { grid-column: 1 / -1; }

.risk-card__icon {
    flex-shrink: 0;
    width: 46px; height: 46px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--ri, #e53e3e) 12%, #fff);
    color: var(--ri, #e53e3e);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem;
}
.risk-card__body { flex: 1; }
.risk-card__body h3 { font-size: 1.05rem; font-weight: 700; color: var(--color-primary); margin: 0 0 .65rem; }
.risk-card__body p  { font-size: .92rem; line-height: 1.65; color: var(--color-text); margin-bottom: .5rem; }
.risk-card__body p:last-child { margin-bottom: 0; }

/* ---- Platform cards (WooCommerce / Shoper) ---- */
.platform-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.75rem; }
@media(max-width:767px) { .platform-grid { grid-template-columns: 1fr; } }

.platform-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2rem;
    position: relative;
    overflow: hidden;
    transition: transform .28s cubic-bezier(.2,0,0,1), box-shadow .28s;
}
.platform-card::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(90deg, #0e3976, #1b5599);
    opacity: 0;
    transition: opacity .28s;
}
.platform-card--alt::after { background: linear-gradient(90deg, #585887, #7b7bb5); }
.platform-card:hover { transform: translateY(-4px); box-shadow: 0 16px 48px rgba(14,57,118,.11); }
.platform-card:hover::after { opacity: 1; }

.platform-card__head {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.25rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--color-border);
}
.platform-card__logo {
    width: 52px; height: 52px;
    border-radius: .875rem;
    background: rgba(14,57,118,.08);
    color: #0e3976;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.35rem;
    flex-shrink: 0;
}
.platform-card__logo--alt { background: rgba(88,88,135,.09); color: #585887; }
.platform-card__name h3 { font-size: 1.2rem; font-weight: 800; color: var(--color-primary); }
.platform-card__tag { font-size: .8rem; font-weight: 600; color: var(--color-text-light); margin-top: .15rem; }
.platform-card p { font-size: .93rem; line-height: 1.65; color: var(--color-text); margin-bottom: .65rem; }
.platform-card__list { list-style: none; margin: 1.1rem 0 0; display: flex; flex-direction: column; gap: .55rem; }
.platform-card__list li { display: flex; align-items: center; gap: .6rem; font-size: .9rem; color: var(--color-text); }
.platform-card__list i { color: #2f855a; font-size: .85rem; flex-shrink: 0; }


.seo-comp-card {
    position: relative;
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 2rem 1.75rem;
    border: 1px solid var(--color-border);
    border-top: 4px solid var(--cc, var(--color-primary));
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition);
}
.seo-comp-card::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .4s ease;
}
.seo-comp-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); border-color: rgba(14,57,118,.2); }
.seo-comp-card:hover::after { transform: scaleX(1); }
.seo-comp-card__head {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.1rem;
}
.seo-comp-card__icon {
    width: 52px; height: 52px;
    flex-shrink: 0;
    border-radius: var(--radius-md);
    background: rgba(14,57,118,.07);
    display: flex; align-items: center; justify-content: center;
    color: var(--cc, var(--color-primary));
    font-size: 1.25rem;
    transition: background var(--transition), color var(--transition);
}
.seo-comp-card:hover .seo-comp-card__icon { background: var(--cc, var(--color-primary)); color: #fff; }
.seo-comp-card h3 { font-size: 1.05rem; margin-bottom: 0; color: var(--color-primary); line-height: 1.3; }
.seo-comp-card p  { font-size: .91rem; color: var(--color-text-muted); line-height: 1.65; }
.seo-comp-card p + p { margin-top: .6rem; }

/* Ranking pillars — wariant na jasnym tle (section--gray) */
.seo-pillars-grid--light {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}
@media(max-width:1023px) { .seo-pillars-grid--light { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:599px)  { .seo-pillars-grid--light { grid-template-columns: 1fr; gap: 1rem; } }

.seo-pillar-light {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 2rem 1.75rem;
    border: 1px solid var(--color-border);
    text-align: center;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
    position: relative;
    overflow: hidden;
}
.seo-pillar-light::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .4s ease;
}
.seo-pillar-light:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); border-color: rgba(14,57,118,.2); }
.seo-pillar-light:hover::after { transform: scaleX(1); }
.seo-pillar-light__icon {
    width: 64px; height: 64px;
    border-radius: var(--radius-md);
    background: rgba(14,57,118,.08);
    border: 1px solid rgba(14,57,118,.12);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 1.25rem;
    font-size: 1.6rem;
    color: var(--color-primary);
    transition: background var(--transition), color var(--transition), border-color var(--transition);
}
.seo-pillar-light:hover .seo-pillar-light__icon {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}
.seo-pillar-light h3 { font-size: 1.05rem; margin-bottom: .6rem; }
.seo-pillar-light p  { font-size: .9rem; color: var(--color-text-muted); line-height: 1.6; }

/* Local vs National comparison */
.seo-ln-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
}
@media(max-width:767px) { .seo-ln-grid { grid-template-columns: 1fr; } }

.seo-ln-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2.5rem 2rem;
    position: relative;
    overflow: hidden;
    transition: box-shadow var(--transition), border-color var(--transition);
}
.seo-ln-card:hover { box-shadow: var(--shadow-md); border-color: var(--ln-border, rgba(14,57,118,.18)); }
.seo-ln-card:hover .seo-ln-deco { background: rgba(255,160,0,.18); transition: background .3s ease; }
.seo-ln-deco { transition: background .3s ease; }
.seo-ln-deco {
    position: absolute;
    top: -25px; right: -25px;
    width: 110px; height: 110px;
    border-radius: 50%;
    background: var(--ln-deco, rgba(14,57,118,.05));
    pointer-events: none;
}
.seo-ln-badge {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-size: .78rem;
    font-weight: 700;
    color: var(--ln-color, var(--color-primary));
    background: var(--ln-bg, rgba(14,57,118,.07));
    border: 1px solid var(--ln-border, rgba(14,57,118,.15));
    padding: .28rem .75rem;
    border-radius: 2rem;
    margin-bottom: 1.25rem;
}
.seo-ln-card h3 { font-size: 1.3rem; margin-bottom: .7rem; }
.seo-ln-card p  { font-size: .94rem; color: var(--color-text-muted); line-height: 1.65; margin-bottom: 1.25rem; }
.seo-ln-list { list-style: none; display: flex; flex-direction: column; gap: .6rem; }
.seo-ln-list li { display: flex; align-items: flex-start; gap: .55rem; font-size: .91rem; color: var(--color-text); }
.seo-ln-list li i { color: var(--ln-color, var(--color-primary)); font-size: .78rem; margin-top: .28rem; flex-shrink: 0; }

/* Support monitoring dashboard mockup */
.support-dash-mock {
    background: linear-gradient(145deg, #091b3d 0%, #0e3976 60%, #1a4a8a 100%);
    border-radius: var(--radius-md);
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: .85rem;
}
.support-dash-header {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding-bottom: .85rem;
    border-bottom: 1px solid rgba(255,255,255,.1);
}
.support-dash-logo {
    width: 1.75rem; height: 1.75rem;
    background: var(--color-accent);
    border-radius: 6px;
    flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    font-size: .75rem; color: #fff;
}
.support-dash-title {
    flex: 1;
    font-size: .72rem;
    color: rgba(255,255,255,.9);
    font-weight: 600;
}
.support-dash-live {
    display: flex;
    align-items: center;
    gap: .35rem;
    font-size: .58rem;
    color: #4ade80;
    font-weight: 700;
    letter-spacing: .06em;
}
.support-live-dot {
    width: 6px; height: 6px;
    background: #4ade80;
    border-radius: 50%;
    animation: livePulse 1.5s ease-in-out infinite;
}
@keyframes livePulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: .4; transform: scale(.75); }
}
.support-dash-uptime {
    background: rgba(255,255,255,.06);
    border-radius: 8px;
    padding: .85rem 1rem;
}
.support-dash-uptime-label {
    font-size: .62rem;
    color: rgba(255,255,255,.5);
    margin-bottom: .3rem;
}
.support-dash-uptime-value {
    font-size: 1.6rem;
    font-weight: 700;
    color: #4ade80;
    line-height: 1;
    margin-bottom: .5rem;
}
.support-dash-uptime-bar {
    height: 5px;
    background: rgba(255,255,255,.12);
    border-radius: 3px;
    overflow: hidden;
}
.support-dash-uptime-fill {
    height: 100%;
    width: 99.9%;
    background: linear-gradient(90deg, #16a34a, #4ade80);
    border-radius: 3px;
}
.support-status-list { display: flex; flex-direction: column; gap: .4rem; }
.support-status-row {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .45rem .75rem;
    background: rgba(255,255,255,.04);
    border-radius: 6px;
}
.support-status-icon { font-size: .72rem; flex-shrink: 0; color: #4ade80; }
.support-status-label { flex: 1; font-size: .66rem; color: rgba(255,255,255,.8); }
.support-status-badge {
    font-size: .56rem;
    font-weight: 700;
    padding: .18rem .5rem;
    border-radius: 4px;
    letter-spacing: .03em;
    background: rgba(74,222,128,.15);
    color: #4ade80;
}

/* Support dashboard build animation */
.animate-on-scroll .support-dash-header,
.animate-on-scroll .support-dash-uptime,
.animate-on-scroll .support-status-row { opacity: 0; }
.animate-on-scroll.is-visible .support-dash-header { animation: webBuild .35s ease forwards .35s; }
.animate-on-scroll.is-visible .support-dash-uptime  { animation: webBuild .35s ease forwards .55s; }
.animate-on-scroll.is-visible .support-status-row:nth-child(1) { animation: webBuild .3s ease forwards .75s; }
.animate-on-scroll.is-visible .support-status-row:nth-child(2) { animation: webBuild .3s ease forwards .9s; }
.animate-on-scroll.is-visible .support-status-row:nth-child(3) { animation: webBuild .3s ease forwards 1.05s; }
.animate-on-scroll.is-visible .support-status-row:nth-child(4) { animation: webBuild .3s ease forwards 1.2s; }
.animate-on-scroll.is-visible .support-status-row:nth-child(5) { animation: webBuild .3s ease forwards 1.35s; }

/* ===== Oferta deal banner ===== */
.oferta-deal-banner {
    display: flex;
    align-items: center;
    gap: 1.75rem;
    background: linear-gradient(135deg, #0e3976 0%, #1a5299 60%, #0e3976 100%);
    border-radius: var(--radius-lg);
    padding: 1.75rem 2rem;
    margin-bottom: 3rem;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    transition: transform .25s, box-shadow .25s;
}
.oferta-deal-banner::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4z'/%3E%3C/g%3E%3C/svg%3E");
    pointer-events: none;
}
.oferta-deal-banner:hover { box-shadow: 0 16px 48px rgba(14,57,118,.35); }
.oferta-deal-banner:hover .oferta-deal-banner__cta i.fa-rocket { transform: rotate(45deg) translate(2px,-2px); }

.oferta-deal-banner__tag {
    flex-shrink: 0;
    background: #e53e3e;
    color: #fff;
    font-size: 2.2rem;
    font-weight: 900;
    line-height: 1;
    width: 5.5rem;
    height: 5.5rem;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .05rem;
    box-shadow: 0 4px 20px rgba(229,62,62,.45);
    position: relative;
    z-index: 1;
    letter-spacing: -.02em;
    text-align: center;
    overflow: hidden;
}
.oferta-deal-banner__tag::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -75%;
    width: 55%;
    height: 200%;
    background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 40%, rgba(255,255,255,.45) 50%, rgba(255,255,255,.3) 60%, rgba(255,255,255,0) 100%);
    transform: skewX(-28deg);
    animation: tag-shine 2.8s ease-in-out infinite;
}
@keyframes tag-shine {
    0%   { left: -75%; }
    55%  { left: 130%; }
    100% { left: 130%; }
}

.oferta-deal-banner__body {
    flex: 1;
    position: relative;
    z-index: 1;
}
.oferta-deal-banner__eyebrow {
    font-size: .78rem;
    font-weight: 700;
    color: #ffa000;
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-bottom: .4rem;
    display: flex;
    align-items: center;
    gap: .35rem;
}
.oferta-deal-banner__title {
    font-size: 1.25rem;
    font-weight: 800;
    color: #fff;
    margin-bottom: .4rem;
    line-height: 1.25;
}
.oferta-deal-banner__desc {
    font-size: .88rem;
    color: rgba(255,255,255,.72);
    line-height: 1.55;
}

.oferta-deal-banner__cta {
    flex-shrink: 0;
    background: #ffa000;
    color: #fff;
    font-size: .9rem;
    font-weight: 700;
    padding: .75rem 1.4rem;
    border-radius: .5rem;
    display: flex;
    align-items: center;
    gap: .5rem;
    position: relative;
    z-index: 1;
    transition: background .22s;
    white-space: nowrap;
}
.oferta-deal-banner__cta i.fa-rocket { transition: transform .25s; }

@media(max-width:767px) {
    .oferta-deal-banner { flex-direction: column; align-items: center; gap: 1rem; padding: 1.5rem; }
    .oferta-deal-banner__tag { font-size: 1.5rem; }
    .oferta-deal-banner__cta { width: 100%; justify-content: center; }
    .oferta-card__footer { justify-content: center; flex-direction: column; align-items: center; gap: .75rem; }
}

/* ===== Oferta hub — duże karty usług ===== */
.oferta-card-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
}
@media(max-width:767px) { .oferta-card-grid { grid-template-columns: 1fr; } }

.oferta-card {
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: opacity .85s cubic-bezier(.2,0,0,1), transform .85s cubic-bezier(.2,0,0,1), box-shadow var(--transition), border-color var(--transition);
}
.oferta-card.is-visible:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: rgba(14,57,118,.18); }

.oferta-card__header {
    background: var(--oc, var(--color-primary));
    padding: 2rem 2.25rem 1.75rem;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    gap: 1.25rem;
}
.oferta-card__header::before {
    content: '';
    position: absolute;
    right: -35px; top: -35px;
    width: 130px; height: 130px;
    border-radius: 50%;
    background: rgba(255,255,255,.07);
    pointer-events: none;
}
.oferta-card__header::after {
    content: '';
    position: absolute;
    right: 30px; bottom: -50px;
    width: 90px; height: 90px;
    border-radius: 50%;
    background: rgba(255,255,255,.05);
    pointer-events: none;
}
.oferta-card__icon {
    width: 58px; height: 58px;
    background: rgba(255,255,255,.15);
    border-radius: var(--radius-md);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.55rem; color: #fff;
    flex-shrink: 0;
    transition: background var(--transition);
}
.oferta-card:hover .oferta-card__icon { background: rgba(255,255,255,.25); }
.oferta-card__header-text { flex: 1; min-width: 0; }
.oferta-card__title { font-size: 1.3rem; color: #fff; margin-bottom: .35rem; line-height: 1.25; }
.oferta-card__subtitle { font-size: .83rem; color: rgba(255,255,255,.72); }

.oferta-card__body {
    padding: 1.75rem 2.25rem 2rem;
    display: flex; flex-direction: column; flex: 1;
}
.oferta-card__desc {
    font-size: .93rem;
    color: var(--color-text-muted);
    line-height: 1.7;
    margin-bottom: 1.25rem;
}
.oferta-card__features {
    list-style: none;
    display: flex; flex-direction: column;
    gap: .55rem;
    margin-bottom: 1.75rem;
    flex: 1;
}
.oferta-card__features li {
    font-size: .88rem;
    color: var(--color-text);
    display: flex; align-items: flex-start; gap: .6rem;
    line-height: 1.45;
}
.oferta-card__features li i {
    color: var(--oc, var(--color-accent));
    font-size: .8rem;
    margin-top: .18rem;
    flex-shrink: 0;
}
.oferta-card__footer {
    display: flex; align-items: center;
    justify-content: space-between;
    gap: 1rem; flex-wrap: wrap;
    padding-top: 1.25rem;
    border-top: 1px solid var(--color-border);
}
.oferta-card__price-label { font-size: .72rem; color: var(--color-text-muted); margin-bottom: .15rem; }
.oferta-card__price-value { font-size: 1.05rem; font-weight: 800; color: var(--color-primary); }
.oferta-card__price-value span { font-size: .75rem; font-weight: 500; color: var(--color-text-muted); }

/* Approach section — 3 steps */
.approach-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    position: relative;
}
.approach-grid::before {
    content: '';
    position: absolute;
    top: 2.5rem; left: calc(16.66% + 1rem); right: calc(16.66% + 1rem);
    height: 2px;
    background: linear-gradient(90deg, var(--color-primary), var(--color-accent), var(--color-primary));
    opacity: .15;
    pointer-events: none;
}
@media(max-width:767px) {
    .approach-grid { grid-template-columns: 1fr; }
    .approach-grid::before { display: none; }
}
.approach-step {
    text-align: center;
    padding: 2rem 1.5rem;
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    transition: transform var(--transition), box-shadow var(--transition);
}
.approach-step:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.approach-step__num {
    width: 56px; height: 56px;
    border-radius: 50%;
    background: var(--color-primary);
    color: #fff;
    font-size: 1.3rem; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 1.25rem;
    position: relative;
    z-index: 1;
}
.approach-step h3 { font-size: 1.05rem; margin-bottom: .6rem; }
.approach-step p { font-size: .88rem; color: var(--color-text-muted); line-height: 1.65; }

/* Trust pillars — 4-col on offer hub */
.trust-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}
@media(max-width:1023px) { .trust-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:599px)  { .trust-grid { grid-template-columns: 1fr; gap: 1rem; } }

.trust-card {
    padding: 1.75rem 1.5rem;
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    border-top: 3px solid var(--color-primary);
    transition: transform var(--transition), box-shadow var(--transition);
}
.trust-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.trust-card__icon {
    width: 48px; height: 48px;
    border-radius: var(--radius-sm);
    background: rgba(14,57,118,.07);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem; color: var(--color-primary);
    margin-bottom: 1rem;
}
.trust-card h3 { font-size: .95rem; margin-bottom: .45rem; }
.trust-card p  { font-size: .85rem; color: var(--color-text-muted); line-height: 1.6; }

/* ---- Responsive tweaks ---- */
@media(max-width:767px) {
    :root { --section-py: 3.5rem; }
    .hero-top { padding-top: calc(72px + 1.25rem); padding-bottom: 1rem; }
    .hero-content { padding-bottom: 2.5rem; }
    .stats-grid { gap: 1.5rem; }
    .cta-btns { flex-direction: column; align-items: center; }
    .footer-bottom-inner { grid-template-columns: 1fr; text-align: center; }
    .footer-legal { justify-self: center; justify-content: center; }
}

/* ================================================================
   DEVICE MOCKUP (portfolio-wpis)
   Naturalne wymiary: desktop-overlay 620×425, mobile-overlay 200×372
   ================================================================ */
.device-mockup {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    max-width: 930px;
    margin: 0 auto 2.5rem;
}

/* Telefon — w HTML pierwszy, na desktop po lewej (order:1), na mobile po prawej (order:2) */
.device-mockup__mobile {
    position: relative;
    flex: 1 1 200px;
    min-width: 0;
    aspect-ratio: 200 / 372;
    margin-right: -38px;
    z-index: 3;
    order: 1;
    overflow: hidden;
    max-width: 200px;
}

/* Monitor — w HTML drugi, na desktop po prawej (order:2), na mobile po lewej (order:1) */
.device-mockup__desktop {
    position: relative;
    flex: 1 1 620px;
    min-width: 0;
    aspect-ratio: 620 / 425;
    order: 2;
    overflow: hidden;
    max-width: 620px;
}

/* Wewnętrzny wrapper — stała naturalna wielkość, skalowany przez JS */
.device-mockup__desktop-inner {
    position: absolute;
    top: 0;
    left: 0;
    width: 620px;
    height: 425px;
    transform-origin: top left;
}
.device-mockup__mobile-inner {
    position: absolute;
    top: 0;
    left: 0;
    width: 200px;
    height: 372px;
    transform-origin: top left;
}

/* Ramka — stała naturalna wielkość wewnątrz skalowanego wrappera */
.device-mockup__frame{
    pointer-events: none;
}
.device-mockup__desktop-inner .device-mockup__frame {
    position: absolute;
    top: 0;
    left: 0;
    width: 620px;
    height: 425px;
    display: block;
    z-index: 2;
}
.device-mockup__mobile-inner .device-mockup__frame {
    position: absolute;
    top: 0;
    left: 0;
    width: 200px;
    height: 372px;
    display: block;
    z-index: 2;
}

/* Ekran monitora w ramce */
.device-mockup__desktop-screen {
    position: absolute;
    top: 12px;
    left: 12px;
    width: 596px;
    height: 306px;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: none;
    z-index: 1;
    border-radius: 2px;
}
.device-mockup__desktop-screen::-webkit-scrollbar { display: none; }
.device-mockup__desktop-screen img {
    width: 100%;
    height: auto;
    display: block;
    user-select: none;
}

/* Ekran telefonu w ramce */
.device-mockup__mobile-screen {
    position: absolute;
    top: 7px;
    left: 10px;
    width: 180px;
    height: 354px;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: none;
    z-index: 1;
    border-radius: 4px;
}
.device-mockup__mobile-screen::-webkit-scrollbar { display: none; }
.device-mockup__mobile-screen img {
    width: 100%;
    height: auto;
    display: block;
    user-select: none;
}

/* Mobile: kolumna, monitor pierwszy (order:1), telefon niżej (order:2) */
@media (max-width: 767px) {
    .device-mockup {
        flex-direction: column;
        align-items: center;
        gap: 2rem;
        max-width: 100%;
        margin-bottom: 2rem;
    }
    .device-mockup__desktop {
        order: 1;
        flex: 0 0 auto;
        width: 100%;
        max-width: 620px;
        aspect-ratio: 620 / 425;
    }
    .device-mockup__mobile {
        order: 2;
        flex: 0 0 auto;
        width: 52%;
        max-width: 200px;
        aspect-ratio: 200 / 372;
        margin-right: 0;
    }
}

/* ================================================================
   O NAS PAGE
   ================================================================ */

/* Hero split */
.onas-hero-inner {
    display: flex;
    align-items: center;
    gap: 4rem;
}
.onas-hero-text { flex: 1; min-width: 0; }
.onas-hero-text p { max-width: 560px; }
.onas-hero-btns { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 1.75rem; }

@media(max-width:1023px) { .onas-hero-inner { gap: 2rem; } }
@media(max-width:767px)  { .onas-hero-inner { flex-direction: column; } }

/* Pulse visual */
.onas-pulse-visual {
    flex-shrink: 0;
    width: 240px; height: 240px;
    position: relative;
    display: flex; align-items: center; justify-content: center;
}
@media(max-width:1023px) { .onas-pulse-visual { display: none; } }

.onas-pulse__core {
    width: 88px; height: 88px;
    border-radius: 50%;
    background: rgba(255,160,0,.12);
    border: 2px solid rgba(255,160,0,.45);
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem; color: #ffa000;
    position: relative; z-index: 1;
}
.onas-pulse__ring {
    position: absolute;
    border-radius: 50%;
    border: 1.5px solid rgba(255,160,0,.22);
    animation: onasPulse 3s ease-out infinite;
    pointer-events: none;
}
.onas-pulse__ring--1 { width: 130px; height: 130px; animation-delay: 0s; }
.onas-pulse__ring--2 { width: 185px; height: 185px; animation-delay: .85s; }
.onas-pulse__ring--3 { width: 240px; height: 240px; animation-delay: 1.7s; }
@keyframes onasPulse {
    0%   { opacity: .85; transform: scale(.4); }
    100% { opacity: 0;   transform: scale(1); }
}

/* Stats mini grid */
.onas-stats-mini {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .85rem;
    margin-top: 2rem;
    width: 100%;
}
.stat-mini {
    background: #fff;
    border: 1px solid var(--color-border);
    border-left: 4px solid var(--color-primary);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    padding: 1.1rem 1.25rem;
    text-align: left;
    transition: box-shadow .22s, transform .22s;
}
.stat-mini:hover { box-shadow: 0 6px 24px rgba(14,57,118,.1); transform: translateY(-2px); }
.stat-mini__value {
    font-size: 2rem; font-weight: 800;
    color: var(--color-primary);
    line-height: 1; margin-bottom: .35rem;
}
.stat-mini__label {
    font-size: .82rem; font-weight: 600;
    color: var(--color-text);
    line-height: 1.35;
}

/* Services strip — 4-col variant */
.about-services-strip--4 { grid-template-columns: repeat(4, 1fr); }
@media(max-width:1023px) {
    .about-services-strip--4 { grid-template-columns: repeat(2, 1fr); }
    .about-services-strip--4 .about-svc:nth-child(2) { border-right: none; }
    .about-services-strip--4 .about-svc { border-bottom: 1px solid var(--color-border); }
    .about-services-strip--4 .about-svc:last-child { border-bottom: none; }
}
@media(max-width:479px) {
    .about-services-strip--4 { grid-template-columns: 1fr; }
    .about-services-strip--4 .about-svc { border-right: none !important; }
}

/* Approach grid — 4 columns */
.approach-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media(min-width:768px) and (max-width:1023px) {
    .approach-grid--4 { grid-template-columns: repeat(2, 1fr); }
    .approach-grid--4::before { display: none; }
}
@media(max-width:767px) { .approach-grid--4 { grid-template-columns: 1fr; } }

/* Team grid — 3 col */
.team-grid--pro { grid-template-columns: repeat(3, 1fr); }
@media(min-width:768px) and (max-width:1023px) { .team-grid--pro { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:767px) { .team-grid--pro { grid-template-columns: 1fr; gap: 3.5rem; } }

/* Pro team card */
.team-card--pro {
    text-align: left;
    padding: 0;
    position: relative;
}
.team-card__header {
    height: 120px;
    display: flex; align-items: center; justify-content: flex-start;
    padding: 0 1.5rem;
    position: relative;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.team-card__header::after {
    content: '';
    position: absolute; inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='20' cy='20' r='16' fill='none' stroke='white' stroke-opacity='0.07'/%3E%3C/svg%3E") repeat;
    border-radius: inherit;
}
.team-card__initials {
    font-size: 3.2rem; font-weight: 900;
    color: rgba(255,255,255,.4);
    line-height: 1;
    position: relative; z-index: 1;
    user-select: none;
}
.team-card__photo {
    position: absolute;
    right: 1.25rem;
    bottom: 0;
    height: 200px;
    width: auto;
    z-index: 2;
    pointer-events: none;
}
.team-grid--pro { padding-top: 38px; }
.team-card__body { padding: 1.4rem; display: flex; flex-direction: column; flex: 1; }
.team-card--pro { display: flex; flex-direction: column; }
.team-card__tags { margin-top: auto; }
.team-card__bio {
    font-size: .875rem;
    color: var(--color-text-muted);
    line-height: 1.65;
    margin: .55rem 0 1rem;
}
.team-card__tags { display: flex; flex-wrap: wrap; gap: .35rem; }
.team-card__tag {
    font-size: .7rem;
    background: rgba(14,57,118,.07);
    color: var(--color-primary);
    padding: .22rem .65rem;
    border-radius: 100px;
    font-weight: 500;
}
.team-card__social { display: flex; gap: .5rem; margin-top: 1rem; }
.team-card__social a {
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--color-bg);
    display: flex; align-items: center; justify-content: center;
    color: var(--color-primary);
    font-size: .8rem; text-decoration: none;
    transition: background .2s, color .2s;
}
.team-card__social a:hover { background: var(--color-accent); color: #fff; }

/* Join card */
.team-card--join {
    border: 2px dashed var(--color-border);
    background: transparent;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    text-align: center;
    padding: 2.5rem 2rem;
    min-height: 340px;
    box-shadow: none;
}
.team-card--join:hover { border-color: var(--color-accent); transform: translateY(-5px); }
.team-card__join-icon {
    width: 60px; height: 60px;
    border-radius: 50%;
    background: rgba(14,57,118,.07);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; color: var(--color-text-muted);
    transition: background .3s, color .3s;
}
.team-card--join:hover .team-card__join-icon {
    background: rgba(255,160,0,.12);
    color: var(--color-accent);
}

/* Values on dark section--primary */
.onas-title-light { color: #fff; }
.onas-values-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2.5rem;
}
@media(max-width:1023px) { .onas-values-grid { grid-template-columns: repeat(2, 1fr); gap: 2rem; } }
@media(max-width:599px)  { .onas-values-grid { grid-template-columns: 1fr; gap: 1.75rem; } }

.onas-value-item {
    padding-top: 1.75rem;
    border-top: 2px solid rgba(14,57,118,.12);
    transition: border-color .3s;
}
.onas-value-item:hover { border-top-color: var(--color-accent); }
.onas-value-item__num { display: none; }
.onas-value-item__num-hidden {
    font-size: .7rem; font-weight: 700;
    color: var(--color-accent);
    letter-spacing: .14em; text-transform: uppercase;
    margin-bottom: .85rem;
    font-variant-numeric: tabular-nums;
}
.onas-value-item__icon {
    font-size: 1.1rem; color: var(--color-primary);
    display: inline; vertical-align: middle; margin-right: .4rem;
}
.onas-value-item h3 { color: var(--color-primary); font-size: 1.1rem; margin-bottom: .5rem; display: flex; align-items: center; gap: .45rem; }

/* ── Case Study: Lista problemów audytu ───────────────────────────────────── */
.cs-audit-list {
    list-style: none;
    margin: 1.25rem 0 2rem;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: .6rem;
}
.cs-audit-item {
    display: flex;
    align-items: flex-start;
    gap: .9rem;
    padding: .85rem 1.1rem;
    background: #fff;
    border-radius: var(--radius-md);
    border-left: 3px solid var(--color-accent);
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
    font-size: .93rem;
    line-height: 1.5;
    color: var(--color-text);
}
.cs-audit-item__icon {
    color: #e53935;
    font-size: 1rem;
    line-height: 1;
    margin-top: .1rem;
    flex-shrink: 0;
}

/* ── Case Study: Timeline ─────────────────────────────────────────────────── */
.cs-timeline {
    padding-left: 2rem;
    margin: 1.75rem 0 2rem;
    list-style: none;
}
.cs-timeline__item {
    position: relative;
    padding: 0 0 1.75rem 1.25rem;
}
.cs-timeline__item:last-child { padding-bottom: 0; }

/* Linia: każdy item rysuje segment do następnego – ostatni nic nie rysuje */
.cs-timeline__item:not(:last-child)::before {
    content: '';
    position: absolute;
    left: calc(-1.075rem - 1px); /* środek kropki: -1.45rem + 0.375rem, minus pół szerokości linii */
    top: calc(.3rem + .75rem);   /* dół kropki */
    bottom: 0;
    width: 2px;
}
/* 6 itemów, 5 segmentów linii */
.cs-timeline__item:nth-child(1)::before { background: linear-gradient(to bottom, #0e3976, #2260a4); }
.cs-timeline__item:nth-child(2)::before { background: linear-gradient(to bottom, #2260a4, #3d80c0); }
.cs-timeline__item:nth-child(3)::before { background: linear-gradient(to bottom, #3d80c0, #b07800); }
.cs-timeline__item:nth-child(4)::before { background: linear-gradient(to bottom, #b07800, #d49000); }
.cs-timeline__item:nth-child(5)::before { background: linear-gradient(to bottom, #d49000, #ffa000); }

/* Kropki – dopasowane do gradientu */
.cs-timeline__dot {
    position: absolute;
    left: -1.45rem;
    top: .3rem;
    width: .75rem;
    height: .75rem;
    border-radius: 50%;
    border: 2px solid #fff;
}
.cs-timeline__item:nth-child(1) .cs-timeline__dot { background: #0e3976; box-shadow: 0 0 0 2px #0e3976; }
.cs-timeline__item:nth-child(2) .cs-timeline__dot { background: #2260a4; box-shadow: 0 0 0 2px #2260a4; }
.cs-timeline__item:nth-child(3) .cs-timeline__dot { background: #3d80c0; box-shadow: 0 0 0 2px #3d80c0; }
.cs-timeline__item:nth-child(4) .cs-timeline__dot { background: #b07800; box-shadow: 0 0 0 2px #b07800; }
.cs-timeline__item:nth-child(5) .cs-timeline__dot { background: #d49000; box-shadow: 0 0 0 2px #d49000; }
.cs-timeline__item:nth-child(6) .cs-timeline__dot { background: #ffa000; box-shadow: 0 0 0 2px #ffa000; }

/* Etykieta – kolor dopasowany do kropki */
.cs-timeline__label {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .5rem;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: .4rem;
}
.cs-timeline__item:nth-child(4) .cs-timeline__label { color: #b07800; }
.cs-timeline__item:nth-child(5) .cs-timeline__label { color: #d49000; }
.cs-timeline__item:last-child .cs-timeline__label  { color: #ffa000; }
.cs-timeline__growth {
    position: relative;
    top: -2px;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: .02em;
    color: #2e7d32;
    background: #43a04729;
    border: 2px solid #43a047;
    border-radius: 3rem;
    padding: .15rem .65rem;
    white-space: nowrap;
    text-transform: none;
}

/* Mini-metryki wewnątrz itemów osi czasu */
.cs-timeline__metrics {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem 1.25rem;
    margin-top: .45rem;
}
.cs-timeline__metric { display: flex; flex-direction: column; }
.cs-timeline__metric-value {
    font-size: .95rem;
    font-weight: 800;
    color: var(--color-primary);
    line-height: 1.1;
}
.cs-timeline__metric-label {
    font-size: .68rem;
    color: var(--color-text-muted);
    margin-top: .05rem;
}

.cs-timeline__text {
    font-size: .93rem;
    color: var(--color-text);
    line-height: 1.55;
}

.onas-value-item p  { color: var(--color-text-muted); font-size: .9rem; line-height: 1.65; margin: 0; }

/* ── Case Study: Galeria zdjęć ────────────────────────────────────────────── */
.cs-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
    margin: 1.75rem 0 2rem;
}
.cs-gallery__item {
    display: block;
    position: relative;
    border-radius: var(--radius-md);
    overflow: hidden;
    cursor: zoom-in;
    background: var(--color-bg);
}
.cs-gallery__item img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform .35s ease;
}
.cs-gallery__item:hover img { transform: scale(1.03); }
.cs-gallery__caption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: .45rem .75rem;
    background: rgba(14,57,118,.7);
    color: #fff;
    font-size: .78rem;
    font-weight: 600;
    text-align: center;
}

/* ── Pozycjonowanie lokalne ───────────────────────────────────────────────── */

/* SERP mockup */
.lokalne-serp-mockup { background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow-md); overflow:hidden; width:100%; max-width:380px; font-size:.85rem; }
.lokalne-serp-mockup__bar { display:flex; align-items:center; gap:.5rem; background:#f1f3f4; padding:.6rem .85rem; border-bottom:1px solid var(--color-border); }
.lokalne-serp-mockup__dot { width:10px; height:10px; border-radius:50%; background:#dde1e7; }
.lokalne-serp-mockup__search { flex:1; background:#fff; border:1px solid var(--color-border); border-radius:2rem; padding:.25rem .75rem; display:flex; align-items:center; gap:.4rem; font-size:.75rem; color:var(--color-text-muted); }
.lokalne-serp-mockup__ads { padding:.65rem .85rem; border-bottom:1px solid var(--color-border); }
.lokalne-serp-mockup__badge { font-size:.65rem; font-weight:700; padding:.1rem .45rem; border-radius:.25rem; margin-bottom:.35rem; display:inline-block; }
.lokalne-serp-mockup__badge--ad { background:#e8f0fe; color:#1a73e8; }
.lokalne-serp-mockup__line { height:8px; background:#e4e8f0; border-radius:4px; margin:.3rem 0; }
.lokalne-serp-mockup__pack { padding:.65rem .85rem; border-bottom:1px solid var(--color-border); background:#fafbff; }
.lokalne-serp-mockup__pack-label { font-size:.7rem; font-weight:700; color:var(--color-text-muted); margin-bottom:.45rem; display:flex; align-items:center; gap:.35rem; }
.lokalne-serp-mockup__entry { display:flex; align-items:center; gap:.5rem; padding:.35rem .5rem; border-radius:var(--radius-sm); font-size:.8rem; color:var(--color-text); margin-bottom:.2rem; }
.lokalne-serp-mockup__entry--you { background:rgba(14,57,118,.07); font-weight:700; color:var(--color-primary); }
.lokalne-serp-mockup__pin { font-size:.75rem; color:#e53935; }
.lokalne-serp-mockup__entry--you .lokalne-serp-mockup__pin { color:var(--color-accent); }
.lokalne-serp-mockup__organic { height:7px; background:#e4e8f0; border-radius:4px; }

/* Factors grid */
.lokalne-factors-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.5rem; margin-top:2.5rem; }
.lokalne-factor-card { background:#fff; border-radius:var(--radius-md); padding:1.75rem 1.5rem; border:1px solid var(--color-border); box-shadow:var(--shadow-sm); text-align:center; }
.lokalne-factor-card__icon { width:56px; height:56px; background:var(--color-primary); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 1rem; font-size:1.4rem; color:#fff; }
.lokalne-factor-card h3 { font-size:1.1rem; margin-bottom:.5rem; }
.lokalne-factor-card p  { font-size:.88rem; color:var(--color-text-muted); line-height:1.6; margin:0; }
.lokalne-pack-note { display:flex; align-items:flex-start; gap:.75rem; background:rgba(14,57,118,.05); border-left:3px solid var(--color-primary); border-radius:var(--radius-md); padding:1rem 1.25rem; margin-top:2rem; font-size:.9rem; color:var(--color-text); line-height:1.6; }
.lokalne-pack-note .fa-circle-info { color:var(--color-primary); font-size:1.1rem; flex-shrink:0; margin-top:.1rem; }

/* GBP mockup card – Google Maps style */
.lokalne-gbp-card { background:#fff; border-radius:12px; box-shadow:0 2px 12px rgba(0,0,0,.15); width:100%; max-width:380px; border:1px solid #e0e0e0; overflow:hidden; font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif; }
.lokalne-gbp-card__cover { height:90px; background:linear-gradient(135deg,#c5d8fb 0%,#b2dfdb 60%,#fff9c4 100%); }
.lokalne-gbp-card__top { display:flex; align-items:flex-start; gap:.85rem; padding:.75rem 1rem .75rem; }
.lokalne-gbp-card__logo { width:52px; height:52px; background:#fff; border-radius:8px; box-shadow:0 1px 6px rgba(0,0,0,.2); display:flex; align-items:center; justify-content:center; font-size:1.3rem; color:#4285f4; flex-shrink:0; border:2px solid #fff; }
.lokalne-gbp-card__title { padding-top:0; }
.lokalne-gbp-card__name { font-size:1rem; font-weight:700; color:#202124; line-height:1.3; }
.lokalne-gbp-card__rating { display:flex; align-items:center; gap:.2rem; margin:.2rem 0 .15rem; }
.lokalne-gbp-card__score { font-size:.82rem; font-weight:700; color:#202124; }
.lokalne-gbp-card__rating .fa-star { color:#f4b400; font-size:.72rem; }
.lokalne-gbp-card__count { font-size:.78rem; color:#70757a; }
.lokalne-gbp-card__cat { font-size:.78rem; color:#70757a; }
.lokalne-gbp-card__tabs { display:flex; border-bottom:1px solid #e0e0e0; padding:0 .75rem; gap:0; }
.lokalne-gbp-card__tab { font-size:.78rem; font-weight:500; color:#70757a; padding:.55rem .7rem; cursor:default; border-bottom:2px solid transparent; white-space:nowrap; }
.lokalne-gbp-card__tab.is-active { color:#1a73e8; border-bottom-color:#1a73e8; font-weight:600; }
.lokalne-gbp-card__actions { display:flex; padding:.8rem .5rem .6rem; gap:.25rem; border-bottom:1px solid #f1f3f4; }
.lokalne-gbp-card__action { flex:1; display:flex; flex-direction:column; align-items:center; gap:.3rem; cursor:default; }
.lokalne-gbp-card__action-ico { width:38px; height:38px; background:#e8f0fe; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.85rem; color:#1a73e8; }
.lokalne-gbp-card__action span { font-size:.63rem; color:#3c4043; text-align:center; line-height:1.3; }
.lokalne-gbp-card__open-row { display:flex; align-items:center; gap:.6rem; padding:.6rem 1rem; font-size:.82rem; color:#3c4043; border-bottom:1px solid #f1f3f4; }
.lokalne-gbp-card__rows { display:flex; flex-direction:column; }
.lokalne-gbp-card__row { display:flex; align-items:flex-start; gap:.75rem; padding:.55rem 1rem; font-size:.82rem; color:#3c4043; border-bottom:1px solid #f1f3f4; }
.lokalne-gbp-card__row:last-child { border-bottom:none; }
.lokalne-gbp-card__row .fa { color:#70757a; width:16px; text-align:center; flex-shrink:0; margin-top:.1rem; }

/* Content cards */
.lokalne-content-card { display:flex; align-items:flex-start; gap:.85rem; background:var(--color-bg); border-radius:var(--radius-md); padding:1rem 1.1rem; border:1px solid var(--color-border); }
.lokalne-content-card__icon { flex-shrink:0; width:36px; height:36px; background:var(--color-primary); border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; color:#fff; font-size:.9rem; }
.lokalne-content-card__title { display:block; margin:0 0 .25rem; font-size:.95rem; font-weight:700; }
.lokalne-content-card p  { margin:0; font-size:.83rem; color:var(--color-text-muted); line-height:1.5; }

/* Pillars grid */
.lokalne-pillars-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:2rem; }
.lokalne-pillar { background:#fff; border-radius:var(--radius-lg); padding:2rem; border:1px solid var(--color-border); box-shadow:var(--shadow-sm); }
.lokalne-pillar__icon { width:52px; height:52px; background:rgba(14,57,118,.08); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.3rem; color:var(--color-primary); margin-bottom:1.1rem; }
.lokalne-pillar h3 { font-size:1.2rem; margin-bottom:.65rem; }
.lokalne-pillar p  { font-size:.9rem; color:var(--color-text-muted); line-height:1.65; margin:0; }

/* Mapa */
.lokalne-map-wrap { background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow-md); overflow:hidden; margin-bottom:2.5rem; }
.lokalne-map-inner { position:relative; padding:1rem 1.5rem .5rem; }
.woj { fill:#c8d4e8; stroke:#fff; stroke-width:4; vector-effect:non-scaling-stroke; cursor:pointer; transition:fill .16s ease, filter .16s ease; }
.woj:hover { fill:var(--color-primary); filter:drop-shadow(0 3px 6px rgba(14,57,118,.25)); }
.woj.is-active { fill:var(--color-accent); }
.lokalne-map-tooltip { position:absolute; pointer-events:none; background:rgba(17,17,17,.9); color:#fff; padding:.4rem .75rem; border-radius:.5rem; font-size:.8rem; font-weight:600; transform:translate(-50%,-115%); white-space:nowrap; opacity:0; transition:opacity .12s ease; z-index:10; }
.lokalne-map-tooltip.is-on { opacity:1; }
.lokalne-map-state { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.85rem 1.5rem; border-top:1px solid var(--color-border); font-size:.9rem; color:var(--color-text-muted); flex-wrap:wrap; }
.lokalne-map-reset { background:none; border:1px solid var(--color-border); border-radius:2rem; padding:.3rem .85rem; font-size:.8rem; cursor:pointer; color:var(--color-text-muted); transition:border-color .2s, color .2s; }
.lokalne-map-reset:hover { border-color:var(--color-primary); color:var(--color-primary); }

/* Lista miast */
.lokalne-cities-section { display:flex; flex-direction:column; gap:2rem; }
.lokalne-voivodeship__name { font-size:1rem; font-weight:700; color:var(--color-primary); margin:0 0 .75rem; padding-bottom:.5rem; border-bottom:2px solid var(--color-accent); display:inline-block; }
.lokalne-cities-grid { display:flex; flex-wrap:wrap; gap:.45rem .65rem; }
.lokalne-city { display:inline-block; padding:.3rem .85rem; background:#fff; border:1px solid var(--color-border); border-radius:2rem; font-size:.85rem; color:var(--color-text); transition:background .2s, border-color .2s, color .2s; cursor:default; }
.lokalne-city:hover { background:rgba(14,57,118,.06); border-color:var(--color-primary); color:var(--color-primary); }
.lokalne-city--link { cursor:pointer; border-color:var(--color-primary); color:var(--color-primary); font-weight:600; text-decoration:none; }
.lokalne-city--link:hover { background:var(--color-primary); color:#fff; }

.lokalne-actions-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1rem;
    margin: 2rem 0;
}
@media (max-width: 899px) {
    .lokalne-actions-grid { grid-template-columns: repeat(5, 1fr); }
}
@media (max-width: 599px) {
    .lokalne-actions-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width:767px) {
    .lokalne-factors-grid { grid-template-columns:1fr; }
    .lokalne-pillars-grid { grid-template-columns:1fr; }
    .lokalne-gbp-card, .lokalne-serp-mockup { max-width:100%; }
}

/* ── Lightbox ─────────────────────────────────────────────────────────────── */
.cs-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0,0,0,.88);
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    cursor: zoom-out;
}
.cs-lightbox.is-open { display: flex; }
.cs-lightbox__img {
    max-width: 100%;
    max-height: 90vh;
    border-radius: var(--radius-md);
    box-shadow: 0 8px 48px rgba(0,0,0,.6);
    cursor: default;
    object-fit: contain;
}
.cs-lightbox__close {
    position: absolute;
    top: 1rem;
    right: 1.25rem;
    background: none;
    border: none;
    color: #fff;
    font-size: 2rem;
    line-height: 1;
    cursor: pointer;
    opacity: .8;
    padding: .25rem .5rem;
}
.cs-lightbox__close:hover { opacity: 1; }

/* ── Pozycjonowanie lokalne: Mapa 2-kolumny ───────────────────────────────── */
.lokalne-map-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    align-items: start;
    margin-bottom: 2.5rem;
}
.lokalne-map-col-map { min-width: 0; }
.lokalne-map-col-panel {
    background: var(--color-bg);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    height: 100%;
    display: flex;
    flex-direction: column;
}
.lokalne-panel-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    min-height: 320px;
    color: var(--color-text-muted);
    text-align: center;
    gap: 1rem;
    padding: 2rem;
}
.lokalne-panel-empty[hidden],
.lokalne-panel-result[hidden] { display: none !important; }
.lokalne-panel-empty i { font-size: 2.5rem; opacity: .25; }
.lokalne-panel-empty p { font-size: .95rem; margin: 0; }
.lokalne-panel-result { padding: 1.5rem; width: 100%; }
.lokalne-panel-result__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.25rem;
    gap: 1rem;
}
.lokalne-panel-result__head h3 {
    margin: 0;
    font-size: 1.1rem;
    color: var(--color-primary);
    text-transform: none;
}
@media (max-width: 767px) {
    .lokalne-map-cols { grid-template-columns: 1fr; }
    .lokalne-map-col-panel { min-height: 200px; }
    .lokalne-panel-empty { min-height: 200px; }
}

/* ── Pozycjonowanie lokalne: Tabs działań ─────────────────────────────────── */
.lokalne-tab-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .55rem;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: .85rem .75rem;
    cursor: pointer;
    transition: border-color .2s, box-shadow .2s, background .2s;
    text-align: center;
    font-size: .82rem;
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.3;
}
.lokalne-tab-btn__ico {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    background: var(--color-primary);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .2s;
}
.lokalne-tab-btn__ico i { color: #fff; font-size: .95rem; }
.lokalne-tab-btn:hover {
    border-color: var(--color-primary);
    box-shadow: 0 2px 12px rgba(0,0,0,.08);
}
.lokalne-tab-btn.is-active {
    border-color: var(--color-primary);
    background: var(--color-primary);
    color: #fff;
    box-shadow: 0 4px 16px rgba(0,0,0,.12);
}
.lokalne-tab-btn.is-active .lokalne-tab-btn__ico {
    background: rgba(255,255,255,.22);
}

.lokalne-tab-content {
    margin-top: 1.75rem;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 2rem 2.25rem;
    min-height: 220px;
}
.lokalne-tab-panel { display: none; }
.lokalne-tab-panel.is-active { display: block; }
.lokalne-tab-panel__title {
    display: flex;
    align-items: center;
    gap: .65rem;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--color-primary);
    margin: 0 0 1.1rem;
}
.lokalne-tab-panel__title i { font-size: 1rem; }
.lokalne-tab-panel p {
    color: var(--color-text-muted);
    font-size: .95rem;
    line-height: 1.75;
    margin-bottom: .85rem;
}
.lokalne-tab-panel p:last-child { margin-bottom: 0; }

/* ── Pozycjonowanie lokalne: Branże – photo cards ─────────────────────────── */
.lokalne-branza-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-top: 2rem;
}
.lokalne-branza-card {
    position: relative;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    border-radius: var(--radius-md);
    overflow: hidden;
    height: 200px;
    background: var(--branza-bg, linear-gradient(135deg, #374151, #1f2937));
    background-size: cover;
    background-position: center;
    text-decoration: none;
    transition: transform .28s ease, box-shadow .28s ease;
}
.lokalne-branza-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgb(0 0 0 / 80%) 0%, rgb(0 0 0 / 60%) 25%, rgb(0 0 0 / 15%) 40%, transparent 100%);
    pointer-events: none;
    transition: opacity .28s ease;
}
.lokalne-branza-card:hover {
    transform: translateY(-5px) scale(1.01);
    box-shadow: 0 18px 48px rgba(0,0,0,.22);
}
.lokalne-branza-card:hover::before {
    opacity: .85;
}
.lokalne-branza-card__label {
    position: relative;
    z-index: 1;
    color: #fff;
    font-weight: 400;
    font-size: 1.4rem;
    padding: 0.4rem 1rem;
    line-height: 1.3;
    text-align: center;
    text-shadow: 0 0px 8px rgb(0 0 0);
}
@media (max-width: 767px) {
    .lokalne-branza-grid { grid-template-columns: repeat(2, 1fr); }
    .lokalne-branza-card { height: 150px; }
}

/* ── City landing: Banner ── */
.chelm-banner {
    width: 100%;
    line-height: 0;
}
.chelm-banner__img {
    width: 100%;
    height: auto;
    display: block;
    max-height: 320px;
    object-fit: cover;
    object-position: center;
}

/* ── Case Study: Audit list ── */
.cs-audit-list {
    list-style: none;
    padding: 0;
    margin: 1rem 0 1.5rem;
    display: flex;
    flex-direction: column;
    gap: .55rem;
}
.cs-audit-item {
    display: flex;
    align-items: baseline;
    gap: .65rem;
    font-size: .95rem;
    color: var(--color-text);
    line-height: 1.5;
}
.cs-audit-item__icon {
    flex-shrink: 0;
    font-style: normal;
    font-weight: 700;
    font-size: 1rem;
    color: #d93025;
    width: 1rem;
    text-align: center;
}

/* ── Case Study: Gallery ── */
.cs-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
    margin: 2rem 0;
}
.cs-gallery__item {
    position: relative;
    display: block;
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid var(--color-border, #e2e8f0);
    text-decoration: none;
    transition: transform .2s, box-shadow .2s;
}
.cs-gallery__item:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(14,57,118,.15);
}
.cs-gallery__item img {
    display: block;
    width: 100%;
    height: auto;
}
.cs-gallery__caption {
    display: block;
    background: rgba(14,57,118,.06);
    color: var(--color-text-muted);
    font-size: .8rem;
    padding: .45rem .75rem;
    text-align: center;
}

/* ── Case Study: Lightbox ── */
.cs-lightbox {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: rgba(0,0,0,.88);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s ease;
}
.cs-lightbox.is-open {
    opacity: 1;
    pointer-events: all;
}
.cs-lightbox__img {
    max-width: min(90vw, 1200px);
    max-height: 90vh;
    border-radius: var(--radius-md);
    box-shadow: 0 24px 80px rgba(0,0,0,.6);
    display: block;
}
.cs-lightbox__close {
    position: absolute;
    top: 1.25rem;
    right: 1.5rem;
    background: transparent;
    border: none;
    color: #fff;
    font-size: 2.25rem;
    line-height: 1;
    cursor: pointer;
    padding: .25rem .5rem;
    opacity: .75;
    transition: opacity .15s;
}
.cs-lightbox__close:hover { opacity: 1; }
