/* =========================================================
   Kokybiška Svetainė
   Turinys – šviesus; header ir footer – tamsiai mėlyni
   ========================================================= */

:root {
    --bg:        #f5f8fd;
    --bg-2:      #e7eefa;
    --surface:   #ffffff;
    --surface-2: #f1f5fc;
    --border:    #d8e0ee;
    --border-2:  #c2cee2;
    --text:      #1d2533;
    --ink:       #081230;
    --muted:     #7a8799;
    --faint:     #828ea1;

    --brand:      #003a93;
    --brand-2:    #0b5fd0;
    --grad:       linear-gradient(125deg, #001a5c 0%, #003a93 48%, #0b5fd0 100%);
    --brand-soft: #e2ebfb;
    --brand-rgb:  0, 58, 147;

    --grad-white:   linear-gradient(180deg, #ffffff 0%, #f1f6fd 100%);
    --grad-soft:    linear-gradient(180deg, #edf3fc 0%, #e0e9f7 100%);
    --grad-surface: linear-gradient(180deg, #ffffff 0%, #f5f9ff 100%);

    --dk-bg:      #07112c;
    --dk-bg-2:    #0c1c44;
    --dk-surface: rgba(255,255,255,.05);
    --dk-border:  rgba(255,255,255,.1);
    --dk-text:    #eef1f6;
    --dk-muted:   rgba(238,241,246,.64);
    --dk-faint:   rgba(238,241,246,.42);

    --radius: 14px;
    --radius-lg: 20px;
    --ease: cubic-bezier(.2,.6,.2,1);
    --font: "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --font-logo: "Space Grotesk", "Hanken Grotesk", system-ui, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; max-width: 100%; overflow-x: hidden; }

body {
    margin: 0;
    font-family: var(--font);
    font-size: 1.0625rem;
    line-height: 1.7;
    color: var(--text);
    background: var(--bg);
    max-width: 100%;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--brand); text-decoration: none; transition: color .18s var(--ease); }
a:hover { color: #073c86; }

h1, h2, h3, h4 { font-family: var(--font); color: var(--ink); font-weight: 800; line-height: 1.12; letter-spacing: -.02em; margin: 0 0 .5em; }
h1 { font-size: clamp(2.2rem, 5vw, 3.6rem); }
h2 { font-size: clamp(1.7rem, 3.4vw, 2.6rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.5rem); }
p { margin: 0 0 1.1em; }

.container { width: 100%; max-width: 100vw; margin: 0; padding: 0 15px; }
.section { padding: clamp(3.5rem, 7vw, 6rem) 0; position: relative; }
.section--tight { padding: clamp(2.5rem, 5vw, 4rem) 0; position: relative; }
.bg-soft { background: var(--grad-soft); }
.muted { color: var(--muted); }
.center { text-align: center; }

.site-bg { position: fixed; inset: 0; z-index: -1; pointer-events: none;
    background:
        radial-gradient(1100px 600px at 50% -10%, rgba(var(--brand-rgb),.06), transparent 60%),
        radial-gradient(900px 500px at 100% 0%, rgba(var(--brand-rgb),.04), transparent 55%),
        linear-gradient(180deg, #ffffff 0%, #eef4fc 100%);
}

.scroll-progress { position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 60; background: var(--grad); box-shadow: 0 0 12px rgba(11,95,208,.5); transition: width .1s linear; }

.kicker { display: inline-block; font-size: .8rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--brand); margin-bottom: .9rem; }
.lead { font-size: clamp(1.08rem, 1.7vw, 1.3rem); color: var(--muted); max-width: 60ch; }
.sec-head { max-width: 64ch; margin-bottom: clamp(2rem, 4vw, 3rem); }
.sec-head--center { margin-left: auto; margin-right: auto; text-align: center; }
.sec-head--row { display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; max-width: none; flex-wrap: wrap; }
.sec-head h2 { margin-bottom: .35em; }
.sec-head p { margin: 0; }

.pill { display: inline-flex; align-items: center; gap: .5rem; font-size: .85rem; font-weight: 600; color: var(--text);
    padding: .4rem .9rem; border: 1px solid var(--border-2); border-radius: 100px; background: var(--surface); margin-bottom: 1.5rem; }
.pill__dot { width: 8px; height: 8px; border-radius: 50%; background: #1faf6a; box-shadow: 0 0 0 0 rgba(31,175,106,.5); animation: pulse 2s infinite; }
.pill--kicker { text-transform: uppercase; letter-spacing: .12em; font-size: .7rem; font-weight: 700; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(31,175,106,.5)} 70%{box-shadow:0 0 0 8px rgba(31,175,106,0)} 100%{box-shadow:0 0 0 0 rgba(31,175,106,0)} }

/* ---------- Mygtukai ---------- */
.btn { display: inline-flex; align-items: center; gap: .55rem; cursor: pointer; font-family: var(--font);
    font-weight: 700; font-size: 1rem; line-height: 1; padding: .85rem 1.5rem; border-radius: 12px; border: 1.5px solid transparent;
    transition: transform .18s var(--ease), box-shadow .22s var(--ease), background .18s var(--ease), border-color .18s var(--ease), color .18s var(--ease); }
.btn svg { width: 18px; height: 18px; }
.btn--lg { padding: 1rem 1.8rem; font-size: 1.05rem; }
.btn--primary { background: var(--grad); color: #fff; box-shadow: 0 8px 22px rgba(0,58,147,.22); }
.btn--primary:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 12px 30px rgba(0,58,147,.32); filter: brightness(1.05); }
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--border-2); }
.btn--ghost:hover { color: var(--brand); border-color: var(--brand); }
.btn--white { background: #fff; color: #0a3a82; }
.btn--white:hover { background: #fff; color: #00254f; transform: translateY(-2px); box-shadow: 0 12px 30px rgba(0,0,0,.18); }

.link-arrow { font-weight: 700; color: var(--brand); display: inline-flex; align-items: center; gap: .4rem; }
.link-arrow span { transition: transform .2s var(--ease); }
.link-arrow:hover span { transform: translateX(4px); }

/* =========================================================
   HEADER
   ========================================================= */
.site-header { position: sticky; top: 0; z-index: 50; overflow: visible;
    background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(238,243,251,.9));
    backdrop-filter: saturate(140%) blur(14px);
    border-bottom: 1px solid transparent;
    will-change: transform;
    animation: kokybiskaHeaderIn .55s var(--ease) .05s backwards;
    transition: box-shadow .25s var(--ease), background .25s var(--ease); }
.site-header.is-scrolled { background: linear-gradient(180deg, #ffffff, #f3f7fd); border-bottom: 1px solid var(--border); box-shadow: 0 1px 0 var(--border), 0 10px 30px rgba(8,18,48,.08); }
@keyframes kokybiskaHeaderIn { from { opacity: 0; transform: translateY(-16px); } to { opacity: 1; transform: none; } }

.topbar { border-bottom: 1px solid var(--border); background: var(--grad-soft); font-size: .82rem; overflow: hidden; max-height: 60px; transition: max-height .35s var(--ease), opacity .3s var(--ease); }
.site-header.is-scrolled .topbar { max-height: 0; opacity: 0; pointer-events: none; }
.topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: .6rem 1.2rem; min-height: 42px; color: var(--muted); flex-wrap: wrap; }
.topbar__tags { display: flex; align-items: center; gap: .45rem; flex-wrap: wrap; }
.topbar__kicker { text-transform: uppercase; letter-spacing: .12em; font-weight: 800; font-size: .68rem; color: var(--brand); margin-right: .15rem; }
.topbar__tag { font-size: .73rem; font-weight: 700; color: var(--brand); background: var(--brand-soft);
    border: 1px solid rgba(var(--brand-rgb), .16); padding: .16rem .58rem; border-radius: 100px; }
.topbar__contacts { display: flex; align-items: center; gap: .55rem; flex-wrap: wrap; }
.topbar__label { text-transform: uppercase; letter-spacing: .08em; font-weight: 700; font-size: .7rem; color: var(--faint); }
.topbar a { color: var(--ink); font-weight: 800; }
.topbar a:hover { color: var(--brand); }
.topbar__sep { width: 1px; height: 14px; background: var(--border-2); margin: 0 .4rem; }
@media (max-width: 1024px) { .topbar__tags { display: none; } .topbar__inner { justify-content: flex-end; } .logo__tagline { display: block; } }

.headmain__inner { display: flex; align-items: stretch; justify-content: space-between; gap: 1rem; min-height: 80px; position: relative; }
.logo { display: inline-flex; align-items: center; gap: .75rem; align-self: center; }
@keyframes logoBreath {
    0%, 100% { filter: drop-shadow(0 5px 10px rgba(var(--brand-rgb), .45)) drop-shadow(0 2px 2px rgba(8,18,48,.3)); transform: translateY(0) scale(1); }
    50%       { filter: drop-shadow(0 10px 22px rgba(var(--brand-rgb), .75)) drop-shadow(0 3px 4px rgba(8,18,48,.35)); transform: translateY(-2px) scale(1.04); }
}
.logo__mark { width: 46px; height: 46px; position: relative; flex: none; transform-style: preserve-3d;
    transition: transform .5s cubic-bezier(.2,.8,.2,1), filter .5s var(--ease);
    animation: logoBreath 3s ease-in-out infinite; }
.logo__mark svg { width: 100%; height: 100%; display: block;
    filter: drop-shadow(0 5px 10px rgba(var(--brand-rgb), .45)) drop-shadow(0 2px 2px rgba(8,18,48,.3)); }
.logo__mark::after { content: ""; position: absolute; inset: 0; border-radius: 2px; pointer-events: none;
    background: linear-gradient(115deg, transparent 38%, rgba(255,255,255,.55) 49%, transparent 60%);
    background-size: 230% 100%; background-position: 130% 0; mix-blend-mode: screen;
    transition: background-position .7s var(--ease); }
.logo:hover .logo__mark { transform: perspective(440px) translateY(-2px) rotateX(14deg) rotateY(-18deg) scale(1.07);
    filter: drop-shadow(0 16px 26px rgba(var(--brand-rgb), .5)) drop-shadow(0 4px 5px rgba(8,18,48,.35));
    animation-play-state: paused; }
.logo:hover .logo__mark::after { background-position: -40% 0; }
.logo__wrap { display: flex; flex-direction: column; justify-content: center; gap: .2rem; min-width: 0; }
.logo__text { font-family: var(--font-logo); font-weight: 700; font-size: 1.4rem; letter-spacing: -.01em; color: var(--ink); line-height: 1; display: flex; gap: .3em; }
.logo__text span { color: var(--brand-2); }
.logo__tagline { display: none; font-size: .72rem; color: var(--muted); font-weight: 600; line-height: 1.3; max-width: 32ch; }
.logo--footer .logo__text { font-size: 1.18rem; }

.header-panel { align-self: stretch; display: flex; align-items: center;
    background: var(--grad); margin-right: -2.5rem; padding: 0 2.5rem 0 72px;
    clip-path: polygon(31px 0, 100% 0, 100% 100%, 0 100%);
    box-shadow: -14px 0 36px rgba(var(--brand-rgb), .3); }

.nav-contacts { display: none; }
.nav-phone-btn { display: none; }
.nav { display: flex; align-items: center; gap: 1.8rem; }
.nav ul { display: flex; align-items: center; gap: 1.7rem; list-style: none; margin: 0; padding: 0; }
.nav ul a { font-weight: 700; font-size: .97rem; letter-spacing: .02em; color: rgba(255,255,255,.92); }
.nav ul a:hover, .nav .current-menu-item > a { color: #fff; }
.nav-cta {
    position: relative;
    background: #d42b2b;
    color: #fff;
    border: none;
    border-radius: 0;
    padding: .78rem 2.2rem;
    font-weight: 800;
    font-size: .97rem;
    letter-spacing: .04em;
    text-transform: uppercase;
    transform: skewX(-21deg);
    transition: color .35s ease;
    z-index: 0;
}
.nav-cta > span {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    transform: skewX(21deg);
}
.nav-cta svg { width: 16px; height: 16px; transition: transform .25s ease; }
.nav-cta::before {
    content: '';
    position: absolute;
    top: 0; bottom: 0;
    right: 100%; left: 0;
    background: #fff;
    opacity: 0;
    z-index: -1;
    transition: right .45s ease, opacity .35s ease;
}
.nav .nav-cta { background: #d42b2b; color: #fff; }
.nav .nav-cta:hover { color: var(--ink); background: #d42b2b; }
.nav .nav-cta:hover::before { right: 0; opacity: 1; }
.nav .nav-cta:hover svg { transform: skewX(21deg) translateX(4px); }

.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: 8px; align-self: center; color: var(--ink); }
.nav-toggle__close { display: none; }
.nav-toggle[aria-expanded="true"] .nav-toggle__open { display: none; }
.nav-toggle[aria-expanded="true"] .nav-toggle__close { display: block; }

/* plaukiojantis CTA */
.floating-cta { position: fixed; bottom: 22px; right: 22px; z-index: 55; display: inline-flex; align-items: center; gap: .55rem;
    padding: .9rem 1.3rem; border-radius: 100px; background: var(--grad); color: #fff; font-weight: 700;
    box-shadow: 0 10px 30px rgba(0,58,147,.4); opacity: 0; transform: translateY(20px) scale(.9); pointer-events: none;
    transition: opacity .3s var(--ease), transform .3s var(--ease), box-shadow .22s var(--ease); }
.floating-cta svg { width: 20px; height: 20px; }
.floating-cta.show { opacity: 1; transform: none; pointer-events: auto; }
.floating-cta:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 14px 38px rgba(0,58,147,.55); }

/* =========================================================
   HERO su video fonu
   ========================================================= */
.hero { padding: clamp(4rem, 8vw, 7rem) 0 clamp(3rem, 5vw, 4.5rem); }
.hero--video { position: relative; overflow: hidden; display: flex; align-items: center;
    min-height: min(55vh, 560px); padding: clamp(2.5rem, 5vw, 4rem) 0; }
.hero--video .container { position: relative; z-index: 1; width: 100%; }
.hero__media { position: absolute; inset: 0; z-index: 0; background: var(--dk-bg); }
.hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero__overlay { position: absolute; inset: 0;
    background:
        linear-gradient(90deg, rgba(11,21,48,.94) 0%, rgba(11,21,48,.8) 40%, rgba(11,21,48,.5) 72%, rgba(11,21,48,.35) 100%),
        linear-gradient(to bottom, rgba(11,21,48,.3), rgba(11,21,48,0) 28%, rgba(11,21,48,.55) 100%); }

.hero--video .pill { color: #fff; border-color: rgba(255,255,255,.25); background: rgba(255,255,255,.08); }
.hero--video h1 { color: #fff; font-family: var(--font-logo); font-size: clamp(2rem, 4.5vw, 4rem); letter-spacing: -.01em; line-height: 1.05; font-weight: 500; text-transform: uppercase; white-space: nowrap; }
.hero--video .hero__inner { max-width: 52ch; }
.hero h1 .accent { background: linear-gradient(120deg,#5b93ff,#9a8bff); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.hero--video .lead { color: rgba(255,255,255,.82); margin-bottom: 2rem; max-width: 54ch; }
.hero--video .btn--ghost { color: #fff; border-color: rgba(255,255,255,.5); }
.hero--video .btn--ghost:hover { background: #fff; color: var(--ink); border-color: #fff; }
.hero__inner { max-width: 52ch; }
.hero__cta { display: flex; flex-wrap: wrap; gap: .8rem; }

/* Hero buttons — same skew style as nav-cta */
.hero-btn-red, .hero-btn-blue {
    position: relative; overflow: hidden;
    border: none; border-radius: 0;
    padding: .85rem 2.2rem;
    font-weight: 800; font-size: .97rem;
    letter-spacing: .04em; text-transform: uppercase;
    transform: skewX(-21deg);
    transition: color .35s ease;
    z-index: 0; cursor: pointer;
}
.hero-btn-red > span, .hero-btn-blue > span {
    display: inline-flex; align-items: center; gap: .5rem;
    transform: skewX(21deg);
}
.hero-btn-red > span svg, .hero-btn-blue > span svg { width: 16px; height: 16px; transition: transform .25s ease; }
.hero-btn-red { background: #d42b2b; color: #fff; }
.hero-btn-red::before {
    content: ''; position: absolute; top: 0; bottom: 0; right: 100%; left: 0;
    background: #fff; opacity: 0; z-index: -1;
    transition: right .45s ease, opacity .35s ease;
}
.hero-btn-red:hover { color: var(--ink); }
.hero-btn-red:hover::before { right: 0; opacity: 1; }
.hero-btn-red:hover > span svg { transform: skewX(21deg) translateX(4px); }
.hero-btn-blue { background: var(--brand-2); color: #fff; }
.hero-btn-blue::before {
    content: ''; position: absolute; top: 0; bottom: 0; right: 100%; left: 0;
    background: #fff; opacity: 0; z-index: -1;
    transition: right .45s ease, opacity .35s ease;
}
.hero-btn-blue:hover { color: var(--brand); }
.hero-btn-blue:hover::before { right: 0; opacity: 1; }

/* Hero two-column layout */
.hero__layout { display: grid; grid-template-columns: 1fr 220px; align-items: center; gap: 1.2rem; padding-right: 2rem; }

/* Cycling text */
.hero__cycle-wrap { display: inline-block; position: relative; }
.hero__cycle { display: inline-block; font-family: var(--font-logo); color: #7fb3ff; transition: opacity .35s ease, transform .35s ease; }
.hero__cycle.is-leaving { opacity: 0; transform: translateY(-14px); }
.hero__cycle.is-entering { opacity: 0; transform: translateY(14px); }

/* Floating stat bubbles — skewed like buttons */
.hero__bubbles { display: flex; flex-direction: column; gap: 1rem; padding-right: 0; margin-left: -1rem; }
.hero__bubble { background: rgba(255,255,255,.1); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(255,255,255,.22); border-radius: 4px;
    padding: 1.1rem 1.4rem; text-align: left;
    display: flex; align-items: center; gap: .9rem;
    box-shadow: 0 4px 20px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.2);
    transform: skewX(-21deg);
    transition: transform .3s ease, box-shadow .3s ease, background .3s ease; }
.hero__bubble:hover { background: rgba(255,255,255,.16); box-shadow: 0 8px 30px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.25); }
.hero__bubble--offset { transform: skewX(-21deg) translateX(14px); }
.hero__bubble--offset:hover { transform: skewX(-21deg) translateX(14px); }
.hero__bubble svg { width: 26px; height: 26px; flex-shrink: 0; color: rgba(255,255,255,.65); transform: skewX(21deg); }
.hero__bubble__text { transform: skewX(21deg); }
.hero__bubble b { display: block; font-size: 1.6rem; font-weight: 800; color: #fff; line-height: 1; font-family: var(--font-logo); }
.hero__bubble span { display: block; font-size: .78rem; color: rgba(255,255,255,.7); margin-top: .25rem; font-weight: 500; }

/* =========================================================
   ŠVIESIOS SEKCIJOS
   ========================================================= */
.svc, .steps, .quotes { display: grid; gap: 1.2rem; }
.svc { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.svc-card { background: var(--grad-surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 2rem 1.85rem; display: flex; flex-direction: column;
    box-shadow: 0 4px 16px rgba(8,18,48,.06), 0 1px 2px rgba(8,18,48,.05);
    transition: border-color .2s var(--ease), box-shadow .25s var(--ease), transform .25s var(--ease); }
.svc-card:hover { transform: translateY(-4px); border-color: transparent; box-shadow: 0 18px 40px rgba(14,26,54,.1), 0 0 0 1px rgba(0,58,147,.12); }
.svc-card__icon { width: 50px; height: 50px; border-radius: 13px; display: grid; place-items: center; background: var(--brand-soft); color: var(--brand); margin-bottom: 1.25rem; }
.svc-card__icon svg { width: 26px; height: 26px; }
.svc-card h3 { margin-bottom: .4em; }
.svc-card p { color: var(--muted); font-size: .98rem; margin: 0 0 1.4rem; }
.svc-card__foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.svc-card__price { font-weight: 800; color: var(--ink); font-size: 1.15rem; }
.svc-card__price small { display: block; font-size: .7rem; font-weight: 600; color: var(--faint); letter-spacing: .05em; text-transform: uppercase; }

.steps { grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); }
.step { padding-top: 1rem; }
.step::before { content: ""; display: block; width: 40px; height: 3px; background: var(--grad); border-radius: 3px; margin-bottom: 1rem; }
.step__num { font-size: .85rem; font-weight: 800; color: var(--brand); letter-spacing: .12em; }
.step h3 { margin: .6rem 0 .4em; }
.step p { color: var(--muted); font-size: .97rem; margin: 0; }

.projektai-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.2rem; }
.projektas { background: var(--grad-surface); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column;
    box-shadow: 0 4px 16px rgba(8,18,48,.06), 0 1px 2px rgba(8,18,48,.05);
    transition: border-color .2s var(--ease), box-shadow .25s var(--ease), transform .25s var(--ease); }
.projektas:hover { transform: translateY(-4px); border-color: transparent; box-shadow: 0 18px 40px rgba(14,26,54,.12); }
.projektas__media { aspect-ratio: 16 / 11; overflow: hidden; background: var(--bg-2); }
.projektas__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease); }
.projektas:hover .projektas__media img { transform: scale(1.05); }
.projektas__media--empty { display: grid; place-items: center; color: var(--faint); font-weight: 800; }
.projektas__body { padding: 1.15rem 1.3rem 1.35rem; display: flex; flex-direction: column; gap: .65rem; flex: 1; }
.projektas__title { font-size: 1.15rem; font-weight: 800; line-height: 1.2; color: var(--ink); }
.projektas__badges { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: auto; }
.badge { font-size: .72rem; font-weight: 700; padding: .28rem .6rem; border-radius: 7px; background: var(--bg-2); color: var(--text); border: 1px solid var(--border); }
.badge--ecommerce { background: var(--brand-soft); color: var(--brand); border-color: rgba(0,58,147,.2); }
.badge--website { background: #eef0f3; color: var(--text); }
.badge--seo { background: #e6f6ee; color: #1a7a47; border-color: rgba(26,122,71,.2); }
.projektas.is-hidden { display: none; }

.filter { display: flex; flex-wrap: wrap; gap: .55rem; margin-bottom: 2rem; }
.filter button { font-family: var(--font); font-weight: 600; font-size: .92rem; cursor: pointer; padding: .55rem 1.1rem; border-radius: 9px; border: 1px solid var(--border-2); background: var(--surface); color: var(--muted); transition: .18s var(--ease); }
.filter button:hover { border-color: var(--brand); color: var(--brand); }
.filter button.is-active { background: var(--grad); border-color: transparent; color: #fff; }

.cta-strip { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem 2rem; flex-wrap: wrap;
    padding: clamp(1.8rem, 4vw, 2.6rem); border-radius: var(--radius-lg); border: 1px solid var(--border);
    background: var(--brand-soft); }
.cta-strip h3 { margin: 0 0 .35em; color: var(--ink); }
.cta-strip p { margin: 0; color: var(--muted); }

.quotes { grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); }
.quote { background: var(--grad-surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.9rem; box-shadow: 0 4px 16px rgba(8,18,48,.06), 0 1px 2px rgba(8,18,48,.05); }
.quote__stars { color: #f5a623; letter-spacing: .15em; font-size: .9rem; margin-bottom: 1rem; }
.quote blockquote { margin: 0; }
.quote p { font-size: 1rem; color: var(--text); margin: 0 0 1.1rem; }
.quote__by { font-weight: 700; color: var(--ink); font-size: .95rem; }

.faq { max-width: 820px; margin: 0 auto; }
.faq details { border-bottom: 1px solid var(--border); }
.faq summary { cursor: pointer; list-style: none; padding: 1.2rem 2.5rem 1.2rem 0; position: relative; font-weight: 700; color: var(--ink); font-size: 1.05rem; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; position: absolute; right: .2rem; top: 50%; transform: translateY(-50%); font-size: 1.5rem; font-weight: 400; color: var(--brand); transition: transform .2s var(--ease); }
.faq details[open] summary::after { content: "−"; }
.faq details > div { padding: 0 0 1.4rem; color: var(--muted); }
.faq details > div p { margin: 0; }

.post-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); gap: 1.2rem; }
.post-card { background: var(--grad-surface); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column;
    box-shadow: 0 4px 16px rgba(8,18,48,.06), 0 1px 2px rgba(8,18,48,.05);
    transition: border-color .2s var(--ease), box-shadow .25s var(--ease), transform .25s var(--ease); }
.post-card:hover { transform: translateY(-4px); border-color: transparent; box-shadow: 0 18px 40px rgba(14,26,54,.12); }
.post-card__media { aspect-ratio: 16 / 9; background: var(--bg-2); overflow: hidden; }
.post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease); }
.post-card:hover .post-card__media img { transform: scale(1.05); }
.post-card__body { padding: 1.3rem 1.4rem 1.5rem; display: flex; flex-direction: column; gap: .55rem; flex: 1; }
.post-card__cats { display: flex; flex-wrap: wrap; gap: .4rem; }
.post-card__cats a { font-size: .74rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--brand); }
.post-card__title { font-size: 1.22rem; font-weight: 800; line-height: 1.22; color: var(--ink); }
.post-card__excerpt { color: #8fa0b4; font-size: .9rem; line-height: 1.6; }
.post-card__meta { font-size: .85rem; color: var(--faint); margin-top: auto; }

/* =========================================================
   PASLAUGŲ PRISTATYMAS
   ========================================================= */
.svc-intro__layout { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }

.svc-intro__text h2 { font-size: clamp(1.7rem, 3vw, 2.4rem); margin-bottom: .6em; }
.svc-intro__text .lead { margin-bottom: 1.8rem; }

.svc-intro__list { list-style: none; padding: 0; margin: 0 0 2rem; display: flex; flex-direction: column; gap: .75rem; }
.svc-intro__list li { display: flex; align-items: center; gap: .65rem; font-weight: 600; color: var(--ink); font-size: .97rem; }
.svc-intro__list li svg { width: 18px; height: 18px; flex-shrink: 0; color: var(--brand); stroke: var(--brand); }

.svc-intro__cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.svc-intro__cards .svc-intro__card:last-child { grid-column: 1 / -1; }

.svc-intro__card { display: flex; align-items: flex-start; gap: 1rem;
    background: var(--grad-surface); border: 1px solid var(--border); border-radius: var(--radius);
    padding: 1.5rem 1.3rem; height: 100%;
    box-shadow: 0 2px 10px rgba(8,18,48,.05);
    transition: border-color .2s var(--ease), box-shadow .2s var(--ease), transform .2s var(--ease); }
.svc-intro__card:hover { border-color: rgba(var(--brand-rgb),.25); box-shadow: 0 8px 24px rgba(8,18,48,.09); transform: translateY(-3px); }
.svc-intro__card--accent { background: var(--grad); border-color: transparent; }
.svc-intro__card--accent h3 { color: #fff !important; }
.svc-intro__card--accent p { color: rgba(255,255,255,.9) !important; }
.svc-intro__card--accent .svc-intro__tags span { background: rgba(255,255,255,.18); color: #fff !important; border-color: rgba(255,255,255,.25); }
.svc-intro__card--accent .svc-intro__card-icon { background: rgba(255,255,255,.18); color: #fff; }
.svc-intro__card--accent:hover { box-shadow: 0 10px 30px rgba(var(--brand-rgb),.35); }

.svc-intro__card-icon { width: 42px; height: 42px; border-radius: 10px; flex-shrink: 0;
    display: grid; place-items: center; background: var(--brand-soft); color: var(--brand); }
.svc-intro__card-icon svg { width: 22px; height: 22px; }
.svc-intro__card h3 { font-size: 1rem; font-weight: 800; margin: 0 0 .35em; color: var(--ink); }
.svc-intro__card p { font-size: .88rem; color: var(--muted); margin: 0 0 .75rem; line-height: 1.5; }
.svc-intro__tags { display: flex; flex-wrap: wrap; gap: .3rem; margin-top: auto; }
.svc-intro__tags span { font-size: .7rem; font-weight: 600; padding: .2rem .55rem; border-radius: 6px;
    background: var(--brand-soft); color: var(--brand); border: 1px solid rgba(var(--brand-rgb),.15); }
/* stagger pop + idle float: cards pop in, then gently pulse one by one */
@keyframes svc-card-pop {
    0%   { opacity: 0; transform: scale(.94); }
    65%  { opacity: 1; transform: scale(1.04); }
    100% { opacity: 1; transform: scale(1); }
}
@keyframes svc-card-idle {
    0%, 100% { transform: translateY(0);    box-shadow: 0 2px 12px rgba(8,18,48,.06); }
    50%       { transform: translateY(-4px); box-shadow: 0 10px 28px rgba(8,18,48,.13); }
}
.has-js [data-reveal] .svc-intro__card { opacity: 0; }
.has-js [data-reveal].in .svc-intro__card:nth-child(1) { animation: svc-card-pop .42s var(--ease) 0s both,   svc-card-idle 2.8s ease-in-out 1.0s infinite; }
.has-js [data-reveal].in .svc-intro__card:nth-child(2) { animation: svc-card-pop .42s var(--ease) .14s both, svc-card-idle 2.8s ease-in-out 1.7s infinite; }
.has-js [data-reveal].in .svc-intro__card:nth-child(3) { animation: svc-card-pop .42s var(--ease) .28s both, svc-card-idle 2.8s ease-in-out 2.4s infinite; }
.has-js [data-reveal].in .svc-intro__card:nth-child(4) { animation: svc-card-pop .42s var(--ease) .42s both, svc-card-idle 2.8s ease-in-out 3.1s infinite; }

.svc-intro__card h3 { font-size: 1rem; font-weight: 800; margin: 0 0 .35em; color: var(--ink); }
.svc-intro__card p { font-size: .88rem; color: var(--muted); margin: 0 0 .75rem; line-height: 1.5; }
.svc-intro__tags { display: flex; flex-wrap: wrap; gap: .3rem; margin-top: auto; }
.svc-intro__tags span { font-size: .7rem; font-weight: 600; padding: .2rem .55rem; border-radius: 6px;
    background: var(--brand-soft); color: var(--brand); border: 1px solid rgba(var(--brand-rgb),.15); }
/* stagger pop + idle float: cards pop in, then gently pulse one by one */
@keyframes svc-card-pop {
    0%   { opacity: 0; transform: scale(.94); }
    65%  { opacity: 1; transform: scale(1.04); }
    100% { opacity: 1; transform: scale(1); }
}
@keyframes svc-card-idle {
    0%, 100% { transform: translateY(0);    box-shadow: 0 2px 12px rgba(8,18,48,.06); }
    50%       { transform: translateY(-4px); box-shadow: 0 10px 28px rgba(8,18,48,.13); }
}
.has-js [data-reveal] .svc-intro__card { opacity: 0; }
.has-js [data-reveal].in .svc-intro__card:nth-child(1) { animation: svc-card-pop .42s var(--ease) 0s both,   svc-card-idle 2.8s ease-in-out 1.0s infinite; }
.has-js [data-reveal].in .svc-intro__card:nth-child(2) { animation: svc-card-pop .42s var(--ease) .14s both, svc-card-idle 2.8s ease-in-out 1.7s infinite; }
.has-js [data-reveal].in .svc-intro__card:nth-child(3) { animation: svc-card-pop .42s var(--ease) .28s both, svc-card-idle 2.8s ease-in-out 2.4s infinite; }
.has-js [data-reveal].in .svc-intro__card:nth-child(4) { animation: svc-card-pop .42s var(--ease) .42s both, svc-card-idle 2.8s ease-in-out 3.1s infinite; }

.svc-intro__usecases { display: flex; flex-direction: column; gap: .6rem; }
.usecase { display: flex; align-items: center; gap: .85rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: .85rem 1.1rem;
    transition: border-color .2s var(--ease), transform .2s var(--ease), box-shadow .2s var(--ease); }
.usecase:hover { border-color: rgba(var(--brand-rgb),.22); transform: translateX(4px); box-shadow: 0 4px 16px rgba(8,18,48,.07); }
.usecase__icon { width: 36px; height: 36px; border-radius: 8px; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.usecase__icon svg { width: 17px; height: 17px; color: var(--brand); }
.usecase__body { display: flex; flex-direction: column; gap: .1rem; }
.usecase__body strong { font-size: .9rem; font-weight: 700; color: var(--ink); }
.usecase__body span { font-size: .77rem; color: var(--muted); }

@media (max-width: 860px) {
    .svc-intro__layout { grid-template-columns: 1fr; gap: 2.5rem; }
    .svc-intro__cards { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
    .svc-intro__cards { grid-template-columns: 1fr; }
}

.cta { position: relative; }
.cta .container { text-align: center; max-width: 820px; margin: 0 auto; padding: clamp(2.5rem,5vw,3.5rem) 15px;
    border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--brand-soft); }
.cta h2 { color: var(--ink); }
.cta p { color: var(--muted); max-width: 50ch; margin: 0 auto 1.8rem; }
.cta__row { display: flex; flex-wrap: wrap; gap: .8rem; justify-content: center; }
.cta__contacts { list-style: none; padding: 0; margin: 2rem 0 0; display: flex; flex-wrap: wrap; gap: 1rem 2rem; justify-content: center; font-weight: 600; }
.cta__contacts a { color: var(--brand); }
.cta__contacts a:hover { color: #073c86; }

.single-hero { padding: clamp(2.5rem, 5vw, 4rem) 0 0; }
.single-hero .meta { color: var(--muted); font-size: .92rem; display: flex; flex-wrap: wrap; gap: .3rem 1rem; margin-top: .7rem; }
.single-hero .meta a { color: var(--brand); font-weight: 600; }
.featured-wrap { margin: clamp(1.5rem, 4vw, 2.4rem) 0; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--border); }
.entry { max-width: 760px; margin: 0 auto; font-size: 1.1rem; color: var(--text); }
.entry h2 { font-size: clamp(1.5rem, 3vw, 1.95rem); margin-top: 2em; }
.entry h3 { margin-top: 1.7em; }
.entry ul, .entry ol { padding-left: 1.3em; margin: 0 0 1.3em; }
.entry li { margin-bottom: .5em; }
.entry a { color: var(--brand); text-decoration: underline; text-underline-offset: 3px; }
.entry img { border-radius: var(--radius); margin: 1.5em 0; }
.entry blockquote { margin: 1.5em 0; padding: 1rem 1.4rem; border-left: 3px solid var(--brand); background: var(--bg-2); border-radius: 0 var(--radius) var(--radius) 0; }
.proj-meta { display: flex; flex-wrap: wrap; gap: 1.4rem 2.4rem; align-items: center; padding: 1.4rem 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin: 1.5rem 0 2rem; }
.proj-meta__item .k { font-size: .76rem; text-transform: uppercase; letter-spacing: .08em; color: var(--faint); }
.proj-meta__item .v { font-weight: 800; font-size: 1.25rem; color: var(--ink); }

.pagination { display: flex; gap: .4rem; flex-wrap: wrap; justify-content: center; margin-top: 3rem; }
.pagination .page-numbers { min-width: 44px; height: 44px; display: inline-grid; place-items: center; padding: 0 .6rem; border-radius: 10px; border: 1px solid var(--border-2); background: var(--surface); font-weight: 600; color: var(--text); }
.pagination .page-numbers.current { background: var(--grad); color: #fff; border-color: transparent; }
.pagination .page-numbers:hover { border-color: var(--brand); color: var(--brand); }
.pagination .page-numbers.current:hover { color: #fff; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer { background: var(--dk-bg); border-top: 1px solid var(--dk-border); padding: clamp(3rem,5vw,4.5rem) 0 2rem; color: var(--dk-muted); }
.site-footer .logo__text { color: #fff; }
.site-footer .logo__text span { color: #6fa0ff; }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 2.5rem; margin-bottom: 2.5rem; }
.site-footer h4 { color: #fff; font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 1rem; }
.site-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .55rem; }
.site-footer a { color: var(--dk-muted); }
.site-footer a:hover { color: #fff; }
.footer-bottom { border-top: 1px solid var(--dk-border); padding-top: 1.5rem; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; font-size: .88rem; color: var(--dk-faint); }

@keyframes kokybiskaFadeUp { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: none; } }
.site-footer.is-in .footer-grid > div { animation: kokybiskaFadeUp .6s var(--ease) both; }
.site-footer.is-in .footer-grid > div:nth-child(2) { animation-delay: .08s; }
.site-footer.is-in .footer-grid > div:nth-child(3) { animation-delay: .16s; }
.site-footer.is-in .footer-bottom { animation: kokybiskaFadeUp .6s var(--ease) .22s both; }

.has-js [data-reveal] { opacity: 0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.has-js [data-reveal].in { opacity: 1; transform: none; }

.skip-link { position: absolute; left: -999px; top: 0; background: var(--brand); color: #fff; padding: .7rem 1rem; z-index: 100; }
.skip-link:focus { left: 8px; top: 8px; }
.searchform { display: flex; gap: .5rem; max-width: 420px; }
.searchform input[type="search"] { flex: 1; padding: .7rem 1rem; border: 1px solid var(--border-2); border-radius: 10px; font-family: inherit; font-size: 1rem; background: var(--surface); color: var(--text); }
.searchform input[type="search"]:focus { outline: 2px solid var(--brand); border-color: transparent; }
.comments { max-width: 760px; margin: 3rem auto 0; }
.comment-list { list-style: none; padding: 0; }
.comment-list .comment { border-top: 1px solid var(--border); padding: 1.2rem 0; }
.comment-form input[type="text"], .comment-form input[type="email"], .comment-form input[type="url"], .comment-form textarea { width: 100%; padding: .7rem 1rem; border: 1px solid var(--border-2); border-radius: 10px; font-family: inherit; font-size: 1rem; margin-bottom: 1rem; background: var(--surface); color: var(--text); }

.section-head { max-width: 64ch; margin-bottom: clamp(2rem, 4vw, 3rem); }
.section-head--row { display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; max-width: none; flex-wrap: wrap; }
.eyebrow { display: inline-block; font-size: .8rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--brand); margin-bottom: .9rem; }
.bg-panel { background: var(--bg-2); }
.bg-tint { background: var(--brand-soft); }
.bg-ink { background: var(--dk-bg); color: #fff; }
.bg-ink h1, .bg-ink h2, .bg-ink h3 { color: #fff; }
.cta-band { text-align: center; }
.cta-band .lead { margin: 0 auto 1.8rem; }
.cta-band__row { display: flex; flex-wrap: wrap; gap: .8rem; justify-content: center; }
.contact-list { list-style: none; padding: 0; margin: 2rem 0 0; display: flex; flex-wrap: wrap; gap: 1rem 2rem; justify-content: center; font-weight: 600; }
.bg-ink .contact-list a { color: #fff; }
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.2rem; }
.card { background: var(--grad-surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 2rem 1.75rem; box-shadow: 0 4px 16px rgba(8,18,48,.06), 0 1px 2px rgba(8,18,48,.05); }
.card__icon { width: 50px; height: 50px; border-radius: 13px; display: grid; place-items: center; background: var(--brand-soft); color: var(--brand); margin-bottom: 1.1rem; }
.reveal { opacity: 1; }

/* ---------- Responsyvumas ---------- */
@media (max-width: 860px) {
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .hero__layout { grid-template-columns: 1fr; gap: 2rem; padding-right: 0; }
    .hero--video .pill { font-size: .7rem; padding: .3rem .7rem; gap: .35rem; }
    .hero--video h1 { white-space: normal; font-size: clamp(1.8rem, 8vw, 2.8rem); }
    .hero__bubbles { flex-direction: column; gap: .6rem; margin-left: 0; padding-right: 0; }
    .hero__bubble { width: 100%; flex-direction: row; align-items: center; text-align: left; padding: .9rem 1.2rem; border-radius: 4px; transform: none; border-left: none; border-bottom: none; gap: .85rem; }
    .hero__bubble--offset { transform: none; }
    .hero__bubble--offset:hover { transform: none; }
    .hero__bubble svg { width: 22px; height: 22px; transform: none; flex-shrink: 0; }
    .hero__bubble__text { transform: none; }
    .hero__bubble b { font-size: 1.35rem; }
    .hero__bubble span { font-size: .75rem; }
    .topbar__inner { justify-content: center; gap: .5rem; min-height: 34px; }
    .headmain__inner { min-height: 64px; align-items: center; position: static; }
    .site-header { will-change: auto; }
    .nav-toggle { display: flex; flex-shrink: 0; position: relative; z-index: 100; color: var(--ink); }
    .logo__mark { width: 26px; height: 26px; }
    .logo__text { font-size: .72rem; }
    .logo { gap: .35rem; flex: 1; min-width: 0; }
    .logo__tagline { display: block; font-size: .6rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; width: 100%; max-width: 100%; padding-bottom: 2px; }
    .header-panel { position: static; background: none; box-shadow: none; clip-path: none; margin: 0; padding: 0; flex: 0; min-width: 0; }
    .nav { position: absolute; top: 0; left: 0; right: 0; height: 100dvh; height: 100vh; background: #fff;
        flex-direction: column; align-items: stretch; gap: 0;
        padding: 90px 24px 2rem; overflow-y: auto;
        border: none; box-shadow: 0 4px 30px rgba(0,0,0,.12);
        transform: translateX(100%); opacity: 0; transition: transform .35s var(--ease), opacity .3s var(--ease); z-index: 49; }
    .nav.is-open { transform: translateX(0); opacity: 1; }
    .nav ul { flex-direction: column; gap: 0; }
    .nav li { border-bottom: 1px solid var(--border); }
    .nav ul a { display: block; padding: .85rem 0; font-size: 1.1rem; color: var(--ink); }
    .nav ul a:hover { color: var(--brand); }
    .nav .nav-cta { margin-top: 1.2rem; transform: none; width: 100%; justify-content: center; border-radius: 0; font-size: .97rem; letter-spacing: .04em; }
    .nav .nav-cta > span { transform: none; justify-content: center; width: 100%; }
    .nav-phone-btn { display: flex; align-items: center; justify-content: center; gap: .6rem; margin-top: .6rem;
        padding: .78rem 2.2rem; border: 2px solid var(--border-2); border-radius: 0;
        color: var(--ink); font-weight: 800; font-size: .97rem; letter-spacing: .04em; text-transform: uppercase;
        background: transparent; transition: border-color .2s ease, color .2s ease; }
    .nav-phone-btn:hover { border-color: var(--brand); color: var(--brand); }
    .nav-phone-btn svg { width: 18px; height: 18px; flex-shrink: 0; color: currentColor; }
}
@media (max-width: 560px) {
    .topbar__label { display: none; }
    .footer-grid { grid-template-columns: 1fr; }
    .sec-head--row, .section-head--row { align-items: flex-start; }
    .floating-cta span { display: none; }
    .floating-cta { padding: .9rem; }
}

@media (prefers-reduced-motion: reduce) {
    .site-header { animation: none !important; }
    .pill__dot { animation: none !important; }
    .has-js [data-reveal] { opacity: 1 !important; transform: none !important; transition: none !important; }
    .has-js [data-reveal] .svc-intro__card { opacity: 1 !important; transition: none !important; }
    .site-footer.is-in .footer-grid > div, .site-footer.is-in .footer-bottom { animation: none !important; }
    html { scroll-behavior: auto; }
}



/* ---- Cap blocks ---- */
.cap-blocks--grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.cap-block { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg);
    padding: 2rem; display: flex; flex-direction: column; gap: 1.2rem;
    box-shadow: 0 2px 12px rgba(8,18,48,.05); transition: box-shadow .22s var(--ease), transform .22s var(--ease), border-color .22s var(--ease); }
.cap-block:hover { box-shadow: 0 10px 32px rgba(8,18,48,.1); transform: translateY(-3px); border-color: rgba(var(--brand-rgb),.2); }
.cap-block--accent { background: var(--grad); border-color: transparent; }
.cap-block--accent:hover { box-shadow: 0 12px 36px rgba(var(--brand-rgb),.28); }
.cap-block__left { display: flex; align-items: flex-start; gap: .9rem; }
.cap-block__left > div { display: flex; flex-direction: column; gap: .3rem; }
.cap-block__icon { width: 46px; height: 46px; border-radius: 11px; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cap-block__icon svg { width: 22px; height: 22px; color: var(--brand); }
.cap-block--accent .cap-block__icon { background: rgba(255,255,255,.18); }
.cap-block--accent .cap-block__icon svg { color: #fff; }
.cap-block h3 { font-size: 1.1rem; font-weight: 800; color: var(--ink); margin: 0; }
.cap-block--accent h3 { color: #fff; }
.cap-block p { font-size: .87rem; color: var(--muted); margin: 0; line-height: 1.6; }
.cap-block--accent p { color: rgba(255,255,255,.78); }
.cap-block__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; border-top: 1px solid var(--border); padding-top: 1.1rem; margin-top: auto; }
.cap-block--accent .cap-block__list { border-top-color: rgba(255,255,255,.2); }
.cap-block__list li { display: flex; align-items: flex-start; gap: .5rem; font-size: .86rem; font-weight: 500; color: var(--ink); line-height: 1.4; }
.cap-block__list li svg { width: 14px; height: 14px; flex-shrink: 0; margin-top: 3px; stroke: var(--brand); }
.cap-block--accent .cap-block__list li { color: rgba(255,255,255,.92); }
.cap-block--accent .cap-block__list li svg { stroke: #ff6b6b; }
@keyframes cap-in { 0% { opacity:0; transform:translateY(14px) } 100% { opacity:1; transform:none } }
.has-js [data-reveal] .cap-block { opacity: 0; }
.has-js [data-reveal].in .cap-block:nth-child(1) { animation: cap-in .45s var(--ease) 0s   both; }
.has-js [data-reveal].in .cap-block:nth-child(2) { animation: cap-in .45s var(--ease) .14s both; }
@media (prefers-reduced-motion: reduce) { .has-js [data-reveal] .cap-block { opacity:1 !important; animation:none !important; } }
@media (max-width: 700px) { .cap-blocks--grid { grid-template-columns: 1fr; } }

/* ---- Sec-head split (heading + stats) ---- */
.sec-head--info { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; max-width: none; }
.sec-head__main { display: flex; flex-direction: column; gap: .6rem; }
.sec-head__main h2 { margin: 0; }
.sec-head__main .lead { margin: 0; }
.sec-head__info { display: flex; flex-direction: column; gap: 1.4rem; }
.sec-info-item { display: flex; align-items: flex-start; gap: 1rem; }
.sec-info-item__icon { width: 40px; height: 40px; border-radius: 10px; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.sec-info-item__icon svg { width: 18px; height: 18px; color: var(--brand); }
.sec-info-item > div { display: flex; flex-direction: column; gap: .25rem; padding-top: .1rem; }
.sec-info-item strong { font-size: .92rem; font-weight: 700; color: var(--ink); line-height: 1.3; }
.sec-info-item span { font-size: .8rem; color: var(--muted); line-height: 1.5; }
@media (max-width: 860px) { .sec-head--info { grid-template-columns: 1fr; gap: 2rem; } }

/* ---- CTA Hero ---- */
.cta-hero { position: relative; overflow: hidden; background: var(--grad); padding: clamp(3rem, 6vw, 5rem) 0; }
.cta-hero__shapes { position: absolute; inset: 0; pointer-events: none; }
.cta-shape { position: absolute; border-radius: 50%; }
.cta-shape--1 { width: 600px; height: 600px; background: rgba(255,255,255,.055); top: -200px; right: -120px; animation: cta-float1 12s ease-in-out infinite alternate; }
.cta-shape--2 { width: 350px; height: 350px; background: rgba(255,255,255,.045); bottom: -100px; left: 5%; animation: cta-float2 16s ease-in-out infinite alternate; }
.cta-shape--3 { width: 220px; height: 220px; background: rgba(255,255,255,.06); top: 20%; right: 20%; animation: cta-float3 9s ease-in-out infinite alternate; }
.cta-shape--4 { width: 140px; height: 140px; background: rgba(255,255,255,.07); top: 60%; left: 35%; animation: cta-float1 11s ease-in-out 2s infinite alternate-reverse; }
@keyframes cta-float1 { 0% { transform: translate(0, 0) scale(1); } 100% { transform: translate(40px, -50px) scale(1.08); } }
@keyframes cta-float2 { 0% { transform: translate(0, 0) scale(1); } 100% { transform: translate(-30px, -35px) scale(1.12); } }
@keyframes cta-float3 { 0% { transform: translate(0, 0) scale(1) rotate(0deg); } 100% { transform: translate(20px, 30px) scale(0.9) rotate(15deg); } }
.cta-hero__inner { position: relative; z-index: 1; text-align: center; max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: 1.5rem; }
.cta-hero__kicker { display: inline-block; font-size: .75rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: rgba(255,255,255,.65); }
.cta-hero h2 { color: #fff; font-size: clamp(2rem, 4vw, 3rem); margin: 0; line-height: 1.15; }
.cta-hero p { color: rgba(255,255,255,.82); font-size: 1rem; line-height: 1.7; margin: 0; max-width: 52ch; }
.cta-badge { position: absolute; top: 2.2rem; left: 2.5rem; z-index: 2;
    display: flex; flex-direction: row; align-items: center; gap: .75rem;
    background: rgba(212,43,43,.55); backdrop-filter: blur(10px);
    border-radius: 18px; padding: .85rem 1.3rem;
    animation: badge-float 4s ease-in-out infinite alternate;
    box-shadow: 0 6px 20px rgba(212,43,43,.35); }
.cta-badge--mobile { display: none; position: static; flex-direction: row; align-items: center; gap: .75rem; background: rgba(212,43,43,.55); backdrop-filter: blur(10px); border-radius: 18px; padding: .85rem 1.3rem; box-shadow: 0 6px 20px rgba(212,43,43,.35); animation: badge-float 4s ease-in-out infinite alternate; }
@media (max-width: 768px) { .cta-badge { display: none; } .cta-badge--mobile { display: inline-flex; } }
.cta-badge svg { width: 20px; height: 20px; flex-shrink: 0; color: rgba(255,255,255,.9); }
.cta-badge__text { display: flex; flex-direction: column; gap: .1rem; }
.cta-badge__num { font-size: .95rem; font-weight: 900; color: #fff; line-height: 1.2; letter-spacing: -.01em; white-space: nowrap; }
.cta-badge__label { font-size: .68rem; font-weight: 600; color: rgba(255,255,255,.75); text-transform: uppercase; letter-spacing: .08em; white-space: nowrap; }
@keyframes badge-float { 0% { transform: translateY(0) rotate(-1.5deg); } 100% { transform: translateY(-10px) rotate(1.5deg); } }

.cta-hero__btns { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; margin-top: .5rem; }

@media (prefers-reduced-motion: reduce) { .cta-shape { animation: none !important; } }
.hero--ghost-btn { background: transparent; color: #fff; border: 2px solid rgba(255,255,255,.45); border-radius: 0; padding: .85rem 2.2rem; font-weight: 800; font-size: .97rem; letter-spacing: .04em; text-transform: uppercase; }
.hero--ghost-btn span { display: inline-flex; align-items: center; gap: .5rem; }
.hero--ghost-btn:hover { border-color: #fff; background: rgba(255,255,255,.1); color: #fff; }


/* ---- Portfolio marquee ---- */
.port-section { overflow: hidden; }
.port-scroll { display: flex; flex-direction: column; gap: .9rem; margin: 2.5rem 0 0; overflow: hidden; }
.port-scroll:hover .port-track { animation-play-state: paused; }
.port-track { display: flex; gap: .9rem; width: max-content; }
.port-track--fwd { animation: port-fwd 140s linear infinite; }
.port-track--rev { animation: port-rev 160s linear infinite; }
@keyframes port-fwd { from { transform: translateX(0); }    to { transform: translateX(-50%); } }
@keyframes port-rev { from { transform: translateX(-50%); } to { transform: translateX(0); } }
.port-card { position: relative; width: 420px; height: 260px; border-radius: var(--radius-lg); overflow: hidden; flex-shrink: 0; display: block; text-decoration: none; }
.port-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease); display: block; }
.port-card__empty { width: 100%; height: 100%; background: var(--grad-surface); }
.port-card:hover img { transform: scale(1.06); }
.port-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(8,18,48,.82) 38%, transparent); display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-end; padding: .85rem 1rem; gap: .25rem; }
.port-card__name { color: #fff; font-size: .88rem; font-weight: 700; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
.port-card__type { color: rgba(255,255,255,.7); font-size: .72rem; font-weight: 500; }
.port-card__price { position: absolute; top: .65rem; right: .65rem; background: var(--brand); color: #fff; font-size: .7rem; font-weight: 700; padding: .25rem .55rem; border-radius: 8px; z-index: 2; }
@media (prefers-reduced-motion: reduce) { .port-track { animation: none !important; } }
@media (max-width: 560px) { .port-card { width: 280px; height: 180px; } }

/* ---- Atsiliepimai ---- */
.rev-swiper { overflow: hidden; }
.rev-layout { display: grid; grid-template-columns: 1.4fr 1fr; gap: 1.2rem; align-items: stretch; }
.rev-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 2rem; display: flex; flex-direction: column; gap: 1rem;
    box-shadow: 0 2px 12px rgba(8,18,48,.05); }
.rev-card--feat { background: var(--grad); border-color: transparent; position: relative; overflow: hidden;
    transition: opacity .22s ease, transform .22s ease; }

.rev-card--side:hover { border-color: rgba(var(--brand-rgb),.25); box-shadow: 0 6px 20px rgba(8,18,48,.09); transform: translateY(-2px); }




/* keep original after enter */

    box-shadow: 0 8px 32px rgba(var(--brand-rgb),.25); }
.rev-side { display: flex; flex-direction: column; gap: 1.5rem; }
.rev-side .rev-card { flex: none; }
.rev-quote-mark { position: absolute; top: -1rem; right: 1.5rem; font-size: 9rem; line-height: 1; color: rgba(255,255,255,.08); font-family: Georgia, serif; pointer-events: none; }
.rev-stars { color: #fbbf24; font-size: 1rem; letter-spacing: .1em; }
.rev-card--feat .rev-stars { color: #fde68a; }
.rev-card blockquote { margin: 0; flex: 1; }
.rev-card blockquote p { font-size: .93rem; color: var(--muted); line-height: 1.7; margin: 0; }
.rev-card--feat blockquote p { color: rgba(255,255,255,.88); font-size: 1.05rem; }
.rev-author { display: flex; align-items: center; gap: .85rem; margin-top: auto; }
.rev-avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--brand-soft); color: var(--brand); font-size: .8rem; font-weight: 800; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rev-avatar--sm { width: 36px; height: 36px; font-size: .72rem; }
.rev-card--feat .rev-avatar { background: rgba(255,255,255,.2); color: #fff; }
.rev-author > div { display: flex; flex-direction: column; gap: .1rem; }
.rev-author strong { font-size: .88rem; font-weight: 700; color: var(--ink); }
.rev-author span { font-size: .76rem; color: var(--muted); }
.rev-card--feat .rev-author strong { color: #fff; }
.rev-card--feat .rev-author span { color: rgba(255,255,255,.65); }
.rev-nav { display: flex; align-items: center; justify-content: center; gap: 1rem; margin-top: 1.8rem; }
.rev-btn { width: 42px; height: 42px; border-radius: 50%; border: 1.5px solid var(--border-2); background: var(--surface); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .2s, border-color .2s, transform .2s; }
.rev-btn:hover { background: var(--brand); border-color: var(--brand); }
.rev-btn:hover svg { stroke: #fff; }
.rev-btn svg { width: 18px; height: 18px; stroke: var(--ink); }
.rev-pagination { display: flex; gap: .5rem; align-items: center; }
.rev-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--border-2); cursor: pointer; transition: background .2s, transform .2s; }
.rev-dot--active { background: var(--brand); transform: scale(1.3); }
@media (max-width: 768px) { .rev-layout { grid-template-columns: 1fr; } .rev-side { display: none; } .rev-card--feat { min-height: auto; } }

/* ---- Kainos showcase ---- */
.pricing-rows { display: flex; flex-direction: column; gap: 1.2rem; }
.pricing-row { display: grid; grid-template-columns: 280px 1fr; border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 4px 24px rgba(8,18,48,.08); transition: transform .25s var(--ease), box-shadow .25s var(--ease); }
.pricing-row:hover { transform: translateY(-3px); box-shadow: 0 12px 40px rgba(8,18,48,.13); }
.pricing-row__left { background: var(--grad); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1.5rem; padding: 2.5rem 1.5rem; text-align: center; }
.pricing-row__left--red { background: linear-gradient(135deg, #b91c1c 0%, #d42b2b 50%, #991b1b 100%); }
.pricing-row__left--dark { background: linear-gradient(135deg, #0f172a 0%, var(--brand-2) 100%); }
.pricing-row__icon { width: 64px; height: 64px; border-radius: 16px; background: rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; }
.pricing-row__icon svg { width: 32px; height: 32px; color: #fff; }
.pricing-row__price-wrap { display: flex; flex-direction: column; gap: .2rem; }
.pricing-row__from { font-size: .75rem; font-weight: 600; color: rgba(255,255,255,.65); text-transform: uppercase; letter-spacing: .1em; }
.pricing-row__price { font-size: 2rem; font-weight: 900; color: #fff; line-height: 1.1; }
.pricing-row__right { background: var(--surface); padding: 2.2rem 2.5rem; display: flex; flex-direction: column; gap: 1.1rem; }
.pricing-row__right h3 { font-size: 1.25rem; font-weight: 800; color: var(--ink); margin: 0; }
.pricing-row__right > p { font-size: .9rem; color: var(--muted); margin: 0; line-height: 1.7; }
.pricing-feats { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: .45rem .8rem; }
.pricing-feats li { display: flex; align-items: flex-start; gap: .5rem; font-size: .85rem; font-weight: 500; color: var(--ink); line-height: 1.4; }
.pricing-feats li svg { width: 15px; height: 15px; flex-shrink: 0; margin-top: 2px; stroke: var(--brand); }
.pricing-row--alt .pricing-feats li svg { stroke: #d42b2b; }
.pricing-row--custom .pricing-feats li svg { stroke: var(--brand-2); }
/* stagger */
@keyframes pr-in { 0% { opacity:0; transform:translateY(16px) } 100% { opacity:1; transform:none } }
.has-js [data-reveal] .pricing-row { opacity: 0; }
.has-js [data-reveal].in .pricing-row:nth-child(1) { animation: pr-in .45s var(--ease) 0s   both; }
.has-js [data-reveal].in .pricing-row:nth-child(2) { animation: pr-in .45s var(--ease) .12s both; }
.has-js [data-reveal].in .pricing-row:nth-child(3) { animation: pr-in .45s var(--ease) .24s both; }
@media (max-width: 860px) { .pricing-row { grid-template-columns: 1fr; } .pricing-row__left { flex-direction: row; padding: 1.5rem; justify-content: flex-start; gap: 1.2rem; border-radius: 0; } .pricing-row__price { font-size: 1.5rem; } .pricing-feats { grid-template-columns: 1fr; } }

/* ---- DUK 2 kolonų layout ---- */
.faq-section { }
.faq-layout { display: grid; grid-template-columns: 1fr 1.6fr; gap: 4rem; align-items: start; }
.faq-intro { display: flex; flex-direction: column; gap: .7rem; position: sticky; top: 6rem; align-items: flex-start; }
.faq-intro h2 { margin: 0; }
.faq-intro .lead { margin: 0; }
.faq-list { display: flex; flex-direction: column; }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-item:first-child { border-top: 1px solid var(--border); }
.faq-q { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.1rem 0; cursor: pointer; font-size: .97rem; font-weight: 600; color: var(--ink); list-style: none; user-select: none; transition: color .2s; }
.faq-q::-webkit-details-marker { display: none; }
.faq-q:hover { color: var(--brand); }
.faq-icon { width: 18px; height: 18px; flex-shrink: 0; color: var(--muted); transition: transform .25s var(--ease), color .2s; }
.faq-item[open] .faq-icon { transform: rotate(180deg); color: var(--brand); }
.faq-item[open] .faq-q { color: var(--brand); }
.faq-a { padding: 0 0 1.1rem; }
.faq-a p { font-size: .9rem; color: var(--muted); margin: 0; line-height: 1.7; }
@media (max-width: 860px) { .faq-layout { grid-template-columns: 1fr; gap: 2rem; } .faq-intro { position: static; } }
.faq-seo-text { font-size: .82rem; color: var(--muted); line-height: 1.6; margin: .5rem 0 0; }
.faq-seo-text strong { color: var(--ink); font-weight: 600; }
.faq-badges { display: flex; flex-wrap: wrap; gap: .35rem; margin-top: .3rem; }
.faq-badges span { font-size: .72rem; font-weight: 600; padding: .25rem .65rem; border-radius: 100px; background: var(--brand-soft); color: var(--brand); border: 1px solid rgba(var(--brand-rgb),.15); }

/* ---- Procesas ---- */
.proc-steps { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; align-items: center; gap: 0; margin-top: 2.5rem; }
.proc-step { position: relative; overflow: hidden; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 2rem; display: flex; flex-direction: column; gap: .9rem;
    box-shadow: 0 2px 12px rgba(8,18,48,.05); transition: transform .22s var(--ease), box-shadow .22s var(--ease); }
.proc-step:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(8,18,48,.1); }
.proc-step--accent { background: var(--grad); border-color: transparent; box-shadow: 0 4px 20px rgba(var(--brand-rgb),.2); }
.proc-step__num { position: absolute; bottom: -.1em; right: .3rem; font-size: 7rem; font-weight: 900; color: rgba(var(--brand-rgb),.07); line-height: 1; letter-spacing: -.04em; pointer-events: none; user-select: none; }
.proc-step--accent .proc-step__num { color: rgba(255,255,255,.12); }
.proc-step h3 { font-size: 1.05rem; font-weight: 800; color: var(--ink); margin: 0; }
.proc-step--accent h3 { color: #fff; }
.proc-step p { font-size: .87rem; color: var(--muted); margin: 0; line-height: 1.65; }
.proc-step--accent p { color: rgba(255,255,255,.8); }
.proc-arrow { display: flex; align-items: center; justify-content: center; padding: 0 1rem; }
.proc-arrow svg { width: 28px; height: 28px; color: var(--border-2); }
@media (max-width: 860px) {
    .proc-steps { grid-template-columns: 1fr; }
    .proc-arrow { transform: rotate(90deg); padding: .5rem 0; }
}
.proc-section .sec-head { max-width: none; }
.proc-section .sec-head .lead { max-width: none; }
.proc-section .sec-head .lead { font-size: .95rem; }

/* ---- Paskutinis CTA ---- */
.final-cta { background: #d42b2b; padding: clamp(2rem, 4vw, 3rem) 0; }
.final-cta__inner { display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.final-cta__text { display: flex; flex-direction: column; gap: .4rem; }
.final-cta__pre { font-size: .78rem; font-weight: 600; color: rgba(255,255,255,.7); letter-spacing: .04em; }
.final-cta h2 { color: #fff; margin: 0; font-size: clamp(1.4rem, 3vw, 2rem); }
.final-cta__actions { display: flex; align-items: center; gap: 1.2rem; flex-shrink: 0; }
.final-cta__phone { display: flex; align-items: center; gap: .5rem; color: rgba(255,255,255,.9); font-weight: 700; font-size: .95rem; text-decoration: none; transition: color .2s; }
.final-cta__phone:hover { color: #fff; }
.final-cta__phone svg { width: 16px; height: 16px; }
@media (max-width: 768px) { .final-cta__inner { flex-direction: column; align-items: flex-start; gap: 1.2rem; } }

/* ---- Footer ---- */
/* ---- Footer dark ---- */
.site-footer--dark { background: #0f1c3f !important; padding-top: 2.5rem; border-top: 1px solid rgba(255,255,255,.08); }
.site-footer--dark .footer-grid { grid-template-columns: 1.6fr 1fr 1fr; }
.footer-tagline { font-size: .87rem; color: rgba(255,255,255,.5); line-height: 1.65; max-width: 38ch; margin: .6rem 0 0; }
.footer-trust { display: flex; align-items: center; gap: 1.2rem; margin-top: 1rem; }
.footer-trust-item { display: flex; flex-direction: column; gap: .05rem; }
.footer-trust-item strong { font-size: 1.2rem; font-weight: 900; color: #fff; line-height: 1; }
.footer-trust-item span { font-size: .68rem; color: rgba(255,255,255,.4); text-transform: uppercase; letter-spacing: .06em; }
.footer-trust-sep { width: 1px; height: 26px; background: rgba(255,255,255,.12); }
.footer-nav-title { font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.3) !important; margin: 0 0 .8rem !important; }
.footer-badges-row { display: flex; flex-wrap: wrap; gap: .5rem; padding: 1.2rem 0; border-top: 1px solid rgba(255,255,255,.07); margin-top: .5rem; }
.footer-badge-pill { display: flex; align-items: center; gap: .45rem; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); border-radius: 100px; padding: .32rem .85rem; font-size: .75rem; font-weight: 600; color: rgba(255,255,255,.5); }
.footer-badge-pill svg { width: 13px; height: 13px; color: rgba(255,255,255,.3); flex-shrink: 0; }
.footer-contact-block { display: flex; flex-direction: column; gap: .35rem; margin-top: 1.2rem; }
.footer-contact-block a { font-size: .87rem; color: rgba(255,255,255,.5) !important; }
.footer-contact-block a:hover { color: #fff !important; }
.footer-bottom__links { display: flex; gap: 1.2rem; }
.footer-bottom__links a { color: rgba(255,255,255,.28) !important; text-decoration: none; transition: color .2s; }
.footer-bottom__links a:hover { color: rgba(255,255,255,.7) !important; }

/* ---- Footer + CTA shapes ---- */
.site-footer--dark { position: relative; overflow: hidden; }
.footer-shapes { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.site-footer--dark .container { position: relative; z-index: 1; }
.footer-shape { position: absolute; border-radius: 50%; }
.footer-shape--1 { width: 550px; height: 550px; background: rgba(255,255,255,.05); border-radius: 50%; top: -180px; right: -120px; animation: cta-float1 12s ease-in-out infinite alternate; }
.footer-shape--2 { width: 320px; height: 320px; background: rgba(255,255,255,.04); border-radius: 50%; bottom: -80px; left: -60px; animation: cta-float2 16s ease-in-out infinite alternate; }
.footer-shape--3 { width: 180px; height: 180px; background: rgba(212,43,43,.25); border-radius: 50%; top: 25%; left: 32%; animation: cta-float3 9s ease-in-out infinite alternate; }
.footer-shape--4 { width: 120px; height: 120px; background: rgba(255,255,255,.07); border-radius: 50%; bottom: 20%; right: 22%; animation: cta-float1 10s ease-in-out 2s infinite alternate-reverse; }

/* CTA enhanced gradient bg */
.final-cta { background: linear-gradient(135deg, #c0392b 0%, #d42b2b 40%, #a93226 100%); }
@media (prefers-reduced-motion: reduce) { .footer-shape { animation: none !important; } }
@media (max-width: 860px) { .site-footer--dark .footer-grid { grid-template-columns: 1fr 1fr; } .footer-shape--1, .footer-shape--2 { opacity: .4; } .footer-shape--3, .footer-shape--4 { display: none; } }
@media (max-width: 560px) { .site-footer--dark .footer-grid { grid-template-columns: 1fr; } }
@media (max-width: 560px) { .site-footer--dark .footer-grid > div { width: 100%; } .footer-tagline { max-width: none; } .site-footer ul li a { font-size: .9rem; } }
@media (max-width: 860px) { .logo--footer .logo__text { font-size: .9rem; } .logo--footer .logo__mark { width: 32px; height: 32px; } }

/* ---- Kontaktai ---- */
.contact-layout { display: grid; grid-template-columns: 1fr 380px; gap: 4rem; align-items: start; margin-top: 2.5rem; }
.contact-form-wrap { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 2.5rem; box-shadow: 0 2px 16px rgba(8,18,48,.06); }
.contact-form { display: flex; flex-direction: column; gap: 1.2rem; }
.cf-row { display: grid; gap: 1rem; }
.cf-row--2 { grid-template-columns: 1fr 1fr; }
.cf-group { display: flex; flex-direction: column; gap: .4rem; }
.cf-group label { font-size: .82rem; font-weight: 600; color: var(--ink); }
.cf-group input, .cf-group textarea, .cf-group select { width: 100%; padding: .7rem 1rem; border: 1px solid var(--border); border-radius: 8px; font-size: .9rem; font-family: inherit; color: var(--ink); background: var(--bg); transition: border-color .2s, box-shadow .2s; }
.cf-group input:focus, .cf-group textarea:focus, .cf-group select:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px rgba(var(--brand-rgb),.1); }
.cf-group textarea { resize: vertical; min-height: 130px; }
.contact-info { display: flex; flex-direction: column; gap: 2rem; }
.contact-info__block h3 { font-size: .95rem; font-weight: 800; color: var(--ink); margin: 0 0 .9rem; }
.contact-info__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .7rem; }
.contact-info__list li { display: flex; align-items: center; gap: .7rem; font-size: .9rem; }
.contact-info__list svg { width: 18px; height: 18px; color: var(--brand); flex-shrink: 0; }
.contact-info__list a { color: var(--ink); text-decoration: none; font-weight: 500; transition: color .2s; }
.contact-info__list a:hover { color: var(--brand); }
.contact-info__hours { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; }
.contact-info__hours li { display: flex; justify-content: space-between; align-items: center; font-size: .87rem; padding-bottom: .5rem; border-bottom: 1px solid var(--border); }
.contact-info__hours li:last-child { border-bottom: none; }
.contact-info__hours span { color: var(--muted); }
.contact-info__hours strong { color: var(--ink); }
.contact-info__badges { display: flex; flex-direction: column; gap: .6rem; }
.contact-badge { background: var(--brand-soft); border-radius: var(--radius); padding: .9rem 1.1rem; display: flex; flex-direction: column; gap: .15rem; }
.contact-badge strong { font-size: 1.2rem; font-weight: 900; color: var(--brand); line-height: 1; }
.contact-badge span { font-size: .78rem; color: var(--muted); }
.contact-badge--accent { background: linear-gradient(135deg, #c0392b, #d42b2b); }
.contact-badge--accent strong, .contact-badge--accent span { color: #fff; }
@media (max-width: 860px) { .contact-layout { grid-template-columns: 1fr; } .cf-row--2 { grid-template-columns: 1fr; } }

/* ---- Blog archyvas ---- */
.post-card__read { font-size: .82rem; font-weight: 700; color: var(--brand); text-decoration: none; margin-top: auto; }
.post-card__read:hover { text-decoration: underline; }
.blog-pagination { margin-top: 2.5rem; display: flex; justify-content: center; }
.blog-pagination .nav-links { display: flex; gap: .4rem; align-items: center; }
.blog-pagination .page-numbers { padding: .5rem .9rem; border-radius: 8px; font-size: .88rem; font-weight: 600; color: var(--ink); background: var(--surface); border: 1px solid var(--border); text-decoration: none; transition: all .2s; }
.blog-pagination .page-numbers.current, .blog-pagination .page-numbers:hover { background: var(--brand); color: #fff; border-color: var(--brand); }
.blog-empty { color: var(--muted); text-align: center; padding: 3rem 0; }

/* ---- Mega menu ---- */
.nav-has-dropdown { position: relative; display: flex; align-items: center; gap: .2rem; }
.headmain, .headmain__inner, .header-panel, .nav { overflow: visible !important; }
.nav-has-dropdown > a { display: flex; align-items: center; gap: .3rem; }
.nav-mega { display: none; position: fixed; width: 640px; background: #fff; border-radius: 16px; box-shadow: 0 16px 48px rgba(8,18,48,.18); border: 1px solid var(--border); overflow: hidden; z-index: 99999; }
.nav-has-dropdown.is-open .nav-mega { display: flex; flex-direction: column; }
.nav-mega__links { display: grid; grid-template-columns: 1fr 1fr; gap: 0; padding: 1rem; }
.nav-mega__links a { display: flex; align-items: center; gap: .75rem; padding: .75rem .9rem; border-radius: 10px; text-decoration: none; transition: background .15s; }
.nav-mega__links a:hover { background: var(--brand-soft); }
.nav-mega__links svg { width: 20px; height: 20px; color: var(--brand); flex-shrink: 0; }
.nav-mega__links span { display: flex; flex-direction: column; gap: .05rem; }
.nav-mega__links strong { font-size: .87rem; font-weight: 700; color: var(--ink); line-height: 1.2; }
.nav-mega__links em { font-size: .75rem; font-style: normal; color: var(--muted); }
.nav-mega__cta { background: var(--brand-soft); border-top: 1px solid var(--border); padding: 1rem 1.4rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.nav-mega__cta p { font-size: .85rem; color: var(--muted); margin: 0; }
.nav-mega__cta .btn { font-size: .78rem; white-space: nowrap; }
@media (max-width: 1024px) { .nav-mega { width: 540px; } }
@media (max-width: 860px) { .nav-mega { display: none !important; } }

/* ---- Privatumo politika ---- */
.privacy-layout { display: grid; grid-template-columns: 220px 1fr; gap: 4rem; align-items: start; }
.privacy-toc__inner { position: sticky; top: 100px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.4rem; }
.privacy-toc__label { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin: 0 0 .8rem; }
.privacy-toc nav { display: flex; flex-direction: column; gap: .2rem; }
.privacy-toc a { font-size: .84rem; color: var(--muted); text-decoration: none; padding: .35rem .6rem; border-radius: 6px; transition: background .15s, color .15s; }
.privacy-toc a:hover { background: var(--brand-soft); color: var(--brand); }
.privacy-hero { margin-bottom: 2.5rem; }
.privacy-hero h1 { margin: .3rem 0 .6rem; }
.privacy-block { margin-bottom: 2.5rem; padding-bottom: 2.5rem; border-bottom: 1px solid var(--border); }
.privacy-block:last-child { border-bottom: none; }
.privacy-block h2 { display: flex; align-items: center; gap: .7rem; font-size: 1.2rem; font-weight: 800; color: var(--ink); margin: 0 0 1rem; }
.privacy-block h2 span { font-size: .75rem; font-weight: 700; color: var(--brand); background: var(--brand-soft); padding: .2rem .55rem; border-radius: 6px; }
.privacy-block p { color: var(--muted); font-size: .92rem; line-height: 1.75; margin: 0 0 .8rem; }
.privacy-block ul { padding-left: 1.2rem; margin: .5rem 0 .8rem; display: flex; flex-direction: column; gap: .5rem; }
.privacy-block li { font-size: .92rem; color: var(--muted); line-height: 1.65; }
.privacy-block a { color: var(--brand); text-decoration: none; }
.privacy-block a:hover { text-decoration: underline; }
.privacy-contact { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-top: 1rem; }
.privacy-contact div { background: var(--brand-soft); border-radius: var(--radius); padding: 1rem 1.2rem; display: flex; flex-direction: column; gap: .3rem; }
.privacy-contact strong { font-size: .75rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--brand); }
.privacy-contact a { font-size: .87rem; color: var(--ink); font-weight: 500; }
@media (max-width: 860px) { .privacy-layout { grid-template-columns: 1fr; } .privacy-toc { display: none; } .privacy-contact { grid-template-columns: 1fr; } }

/* ---- Single projektas ---- */
.proj-back { display: inline-flex; align-items: center; gap: .4rem; font-size: .84rem; font-weight: 600; color: var(--muted); text-decoration: none; margin-bottom: 2rem; transition: color .2s; }
.proj-back:hover { color: var(--brand); }
.proj-back svg { width: 16px; height: 16px; }
.proj-single-hero { padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(2rem, 4vw, 3rem); }
.proj-single-hero__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 3.5rem; align-items: center; }
.proj-single-hero__text { display: flex; flex-direction: column; gap: 1.2rem; }
.proj-single-hero__text h1 { font-size: clamp(1.8rem, 4vw, 3rem); margin: 0; }
.proj-single-hero__text .lead { margin: 0; }
.proj-single-meta { display: flex; gap: 2rem; flex-wrap: wrap; padding: 1.2rem 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.proj-single-meta__item { display: flex; flex-direction: column; gap: .2rem; }
.proj-single-meta__item span { font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.proj-single-meta__item strong { font-size: 1rem; font-weight: 800; color: var(--ink); }
.proj-single-hero__img { border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 20px 60px rgba(8,18,48,.12); }
.proj-single-hero__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.proj-content { max-width: 72ch; }
@media (max-width: 860px) { .proj-single-hero__inner { grid-template-columns: 1fr; } .proj-single-hero__img { order: -1; } }
.nav-dropdown-btn { background: none; border: none; cursor: pointer; padding: 0; color: rgba(255,255,255,.7); display: inline-flex; align-items: center; line-height: 1; margin-left: .15rem; }
.nav-dropdown-btn:hover { opacity: 1; }

/* ---- Paslaugų archyvas ---- */
.svc-archive-hero { padding-bottom: 1rem; }
.svc-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.svc-card { display: grid; grid-template-columns: 56px 1fr auto auto; align-items: center; gap: 1.2rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.6rem 1.8rem; text-decoration: none; transition: transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease); }
.svc-card:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(8,18,48,.1); border-color: rgba(var(--brand-rgb),.25); }
.svc-card__icon { width: 52px; height: 52px; border-radius: 14px; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.svc-card__icon svg { width: 26px; height: 26px; color: var(--brand); }
.svc-card__body { display: flex; flex-direction: column; gap: .3rem; }
.svc-card__body h2 { font-size: 1rem; font-weight: 800; color: var(--ink); margin: 0; line-height: 1.2; }
.svc-card__body p { font-size: .83rem; color: var(--muted); margin: 0; line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.svc-card__price { font-size: .8rem; font-weight: 700; color: var(--brand); white-space: nowrap; background: var(--brand-soft); padding: .3rem .7rem; border-radius: 8px; }
.svc-card__arrow { width: 32px; height: 32px; border-radius: 50%; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background .2s; }
.svc-card__arrow svg { width: 15px; height: 15px; color: var(--brand); }
.svc-card:hover .svc-card__arrow { background: var(--brand); }
.svc-card:hover .svc-card__arrow svg { color: #fff; }
@media (max-width: 860px) { .svc-cards { grid-template-columns: 1fr; } .svc-card { grid-template-columns: 48px 1fr auto; } .svc-card__price { display: none; } }

/* ---- Single paslauga ---- */
.svc-hero { padding: clamp(2rem,4vw,3.5rem) 0 clamp(2rem,5vw,4rem); }
.svc-hero__inner { display: grid; grid-template-columns: 1fr 380px; gap: 4rem; align-items: start; margin-top: 2rem; }
.svc-hero__text { display: flex; flex-direction: column; gap: 1.2rem; }
.svc-hero__icon { width: 64px; height: 64px; border-radius: 18px; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; }
.svc-hero__icon svg { width: 32px; height: 32px; color: var(--brand); }
.svc-hero__price { display: inline-flex; font-size: .82rem; font-weight: 700; color: var(--brand); background: var(--brand-soft); padding: .3rem .8rem; border-radius: 8px; align-self: flex-start; }
.svc-hero__text h1 { font-size: clamp(2rem,4vw,3rem); margin: 0; }
.svc-hero__text .lead { margin: 0; }
.svc-hero__feats { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: .5rem .8rem; }
.svc-hero__feats li { display: flex; align-items: center; gap: .5rem; font-size: .88rem; font-weight: 500; color: var(--ink); }
.svc-hero__feats svg { width: 16px; height: 16px; flex-shrink: 0; color: var(--brand); }
.svc-hero__actions { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; margin-top: .4rem; }
.svc-hero__phone { display: flex; align-items: center; gap: .5rem; font-size: .9rem; font-weight: 600; color: var(--ink); text-decoration: none; transition: color .2s; }
.svc-hero__phone:hover { color: var(--brand); }
.svc-hero__phone svg { width: 16px; height: 16px; }
.svc-trust-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.8rem; display: flex; flex-direction: column; gap: 1.2rem; box-shadow: 0 4px 24px rgba(8,18,48,.07); }
.svc-trust-card__item { display: flex; align-items: flex-start; gap: .9rem; }
.svc-trust-card__item svg { width: 20px; height: 20px; color: var(--brand); flex-shrink: 0; margin-top: 2px; }
.svc-trust-card__item strong { display: block; font-size: .92rem; font-weight: 700; color: var(--ink); }
.svc-trust-card__item span { font-size: .8rem; color: var(--muted); }
.svc-trust-card__price { border-top: 1px solid var(--border); padding-top: 1rem; display: flex; align-items: center; justify-content: space-between; }
.svc-trust-card__price span { font-size: .75rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.svc-trust-card__price strong { font-size: 1.4rem; font-weight: 900; color: var(--brand); }
.svc-content { max-width: 72ch; }
@media (max-width: 900px) { .svc-hero__inner { grid-template-columns: 1fr; } .svc-hero__feats { grid-template-columns: 1fr; } }

/* ---- Svetainių kūrimas puslapis ---- */
.svc-intro-layout { display: grid; grid-template-columns: 1fr 300px; gap: 4rem; align-items: center; }
.svc-intro-text { display: flex; flex-direction: column; gap: 1rem; }
.svc-intro-text h2 { margin: .3rem 0 0; }
.svc-intro-text p { font-size: .92rem; color: var(--muted); margin: 0; line-height: 1.7; }
.svc-check-list { list-style: none; padding: 0; margin: .5rem 0 0; display: flex; flex-direction: column; gap: .55rem; }
.svc-check-list li { display: flex; align-items: center; gap: .6rem; font-size: .9rem; font-weight: 500; color: var(--ink); }
.svc-check-list svg { width: 16px; height: 16px; color: var(--brand); flex-shrink: 0; }
.svc-intro-stats { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
.svc-stat { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.4rem; display: flex; flex-direction: column; gap: .25rem; }
.svc-stat strong { font-size: 1.8rem; font-weight: 900; color: var(--brand); line-height: 1; }
.svc-stat span { font-size: .78rem; color: var(--muted); }
.svc-stat--accent { background: var(--grad); border-color: transparent; }
.svc-stat--accent strong, .svc-stat--accent span { color: #fff; }

.svc-types { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1.2rem; margin-top: 2.5rem; }
.svc-type-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 2rem; display: flex; flex-direction: column; gap: .8rem; position: relative; overflow: hidden; }
.svc-type-card--accent { background: var(--grad); border-color: transparent; }
.svc-type-card__num { font-size: 5rem; font-weight: 900; color: rgba(var(--brand-rgb),.07); line-height: 1; position: absolute; bottom: -.2em; right: .2rem; }
.svc-type-card--accent .svc-type-card__num { color: rgba(255,255,255,.1); }
.svc-type-card h3 { font-size: 1.05rem; font-weight: 800; color: var(--ink); margin: 0; }
.svc-type-card--accent h3 { color: #fff; }
.svc-type-card > p { font-size: .87rem; color: var(--muted); margin: 0; line-height: 1.6; }
.svc-type-card--accent > p { color: rgba(255,255,255,.8); }
.svc-type-card ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .35rem; }
.svc-type-card li { font-size: .82rem; color: var(--muted); padding-left: .9rem; position: relative; }
.svc-type-card li::before { content: '—'; position: absolute; left: 0; color: var(--brand); font-weight: 700; }
.svc-type-card--accent li { color: rgba(255,255,255,.7); }
.svc-type-card--accent li::before { color: rgba(255,255,255,.6); }

.svc-tech-layout { display: grid; grid-template-columns: 1fr 280px; gap: 4rem; align-items: start; }
.svc-tech-list { display: flex; flex-direction: column; gap: 1.5rem; margin-top: 1.5rem; }
.svc-tech-item { display: flex; align-items: flex-start; gap: 1rem; }
.svc-tech-item__icon { width: 44px; height: 44px; border-radius: 12px; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.svc-tech-item__icon svg { width: 22px; height: 22px; color: var(--brand); }
.svc-tech-item strong { display: block; font-size: .95rem; font-weight: 700; color: var(--ink); margin-bottom: .25rem; }
.svc-tech-item p { font-size: .85rem; color: var(--muted); margin: 0; line-height: 1.6; }
.svc-tech-card { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; position: sticky; top: 6rem; }
.svc-tech-score { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.5rem; display: flex; flex-direction: column; align-items: center; gap: .3rem; text-align: center; }
.svc-tech-score span { font-size: 1.6rem; font-weight: 900; color: var(--brand); }
.svc-tech-score small { font-size: .72rem; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; }
.svc-tech-score--red { background: linear-gradient(135deg,#c0392b,#d42b2b); border-color: transparent; }
.svc-tech-score--red span, .svc-tech-score--red small { color: #fff; }

@media (max-width: 860px) {
    .svc-intro-layout { grid-template-columns: 1fr; }
    .svc-types { grid-template-columns: 1fr; }
    .svc-tech-layout { grid-template-columns: 1fr; }
    .svc-tech-card { position: static; }
}

/* ---- Svc type price badge ---- */
.svc-type-price { font-size: .82rem; font-weight: 800; color: var(--brand); background: var(--brand-soft); padding: .25rem .7rem; border-radius: 8px; align-self: flex-start; }
.svc-type-card--accent .svc-type-price { background: rgba(255,255,255,.2); color: #fff; }

/* ---- Blog shortcode'ai ---- */
.sc-cta { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; border-radius: var(--radius-lg); padding: 1.8rem 2rem; margin: 2rem 0; flex-wrap: wrap; }
.sc-cta--red { background: linear-gradient(135deg, #b91c1c 0%, #dc2626 40%, #991b1b 100%); background-size: 200% 200%; animation: cta-grad-shift 4s ease infinite; box-shadow: 0 8px 32px rgba(185,28,28,.35); }
@keyframes cta-grad-shift { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }
.sc-cta--blue { background: var(--grad); }
.sc-cta__text { display: flex; flex-direction: column; gap: .3rem; }
.sc-cta__pre { font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: rgba(255,255,255,.65); }
.sc-cta p { font-size: 1.05rem; font-weight: 700; color: #fff; margin: 0; }
.sc-quote { border-left: 4px solid var(--brand); background: var(--brand-soft); border-radius: 0 var(--radius) var(--radius) 0; padding: 1.5rem 1.8rem; margin: 2rem 0; position: relative; }
.sc-quote__mark { font-size: 4rem; font-weight: 900; color: rgba(var(--brand-rgb),.15); line-height: 1; position: absolute; top: .5rem; left: 1rem; }
.sc-quote p { font-size: 1rem; font-style: italic; color: var(--ink); margin: 0 0 .6rem; line-height: 1.7; padding-left: 1.5rem; }
.sc-quote cite { font-size: .82rem; font-weight: 700; color: var(--brand); font-style: normal; padding-left: 1.5rem; }
.sc-tip { display: flex; align-items: flex-start; gap: 1rem; background: #fffbeb; border: 1px solid #fde68a; border-radius: var(--radius-lg); padding: 1.2rem 1.4rem; margin: 1.5rem 0; }
.sc-tip__icon { font-size: 1.4rem; flex-shrink: 0; line-height: 1; }
.sc-tip strong { display: block; font-size: .9rem; font-weight: 700; color: #92400e; margin-bottom: .3rem; }
.sc-tip p { font-size: .88rem; color: #78350f; margin: 0; line-height: 1.6; }
.sc-link-box { display: flex; align-items: center; gap: 1rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.1rem 1.4rem; margin: 1.2rem 0; text-decoration: none; transition: border-color .2s, box-shadow .2s; }
.sc-link-box:hover { border-color: rgba(var(--brand-rgb),.3); box-shadow: 0 4px 16px rgba(8,18,48,.08); }
.sc-link-box__icon { width: 40px; height: 40px; border-radius: 10px; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.sc-link-box__icon svg { width: 20px; height: 20px; color: var(--brand); }
.sc-link-box__body { flex: 1; display: flex; flex-direction: column; gap: .15rem; }
.sc-link-box__body strong { font-size: .92rem; font-weight: 700; color: var(--ink); }
.sc-link-box__body span { font-size: .8rem; color: var(--muted); }
.sc-link-box__arrow svg { width: 18px; height: 18px; color: var(--brand); }
.sc-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; margin: 1.5rem 0; }
.sc-stat { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.2rem; text-align: center; }
.sc-stat strong { display: block; font-size: 1.8rem; font-weight: 900; color: var(--brand); line-height: 1; }
.sc-stat span { font-size: .78rem; color: var(--muted); margin-top: .2rem; display: block; }
@media (max-width: 560px) { .sc-cta { flex-direction: column; align-items: flex-start; } .sc-stats { grid-template-columns: 1fr; } }

/* ---- Single post ---- */
.post-hero { background: var(--grad); padding: clamp(2rem,4vw,3.5rem) 0 2rem; }
.post-hero__cats { display: flex; gap: .4rem; flex-wrap: wrap; margin: 1rem 0 .8rem; }
.post-hero__cat { font-size: .72rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; background: rgba(255,255,255,.15); color: rgba(255,255,255,.9); padding: .25rem .7rem; border-radius: 6px; text-decoration: none; }
.post-hero h1 { color: #fff; font-size: clamp(1.6rem,3.5vw,2.6rem); margin: 0 0 1rem; max-width: 78ch; line-height: 1.2; }
.post-hero__meta { display: flex; gap: 1.4rem; align-items: center; }
.post-hero__meta span { display: flex; align-items: center; gap: .4rem; font-size: .83rem; color: rgba(255,255,255,.7); }
.post-hero__meta svg { width: 15px; height: 15px; }
.post-thumb-wrap { margin: 2rem auto; }
.post-thumb { width: 100%; border-radius: var(--radius-lg); display: block; max-height: 480px; object-fit: cover; }
.post-layout { display: grid; grid-template-columns: 1fr 300px; gap: 3rem; align-items: start; }
.post-content-wrap .entry { font-size: .97rem; line-height: 1.8; color: var(--ink); }
.post-content-wrap .entry h2 { font-size: 1.4rem; font-weight: 800; margin: 2rem 0 .8rem; color: var(--ink); }
.post-content-wrap .entry h3 { font-size: 1.1rem; font-weight: 700; margin: 1.5rem 0 .6rem; color: var(--ink); }
.post-content-wrap .entry p { margin: 0 0 1rem; }
.post-content-wrap .entry ul, .post-content-wrap .entry ol { padding-left: 1.4rem; margin: .6rem 0 1rem; display: flex; flex-direction: column; gap: .4rem; }
.post-content-wrap .entry blockquote { border-left: 4px solid var(--brand); padding: 1rem 1.4rem; background: var(--brand-soft); border-radius: 0 var(--radius) var(--radius) 0; margin: 1.5rem 0; }
.post-content-wrap .entry img { max-width: 100%; border-radius: var(--radius); }
.post-content-wrap .entry a { color: var(--brand); text-decoration: underline; text-underline-offset: 3px; }
.post-content-wrap .entry .btn, .post-content-wrap .entry .sc-cta a, .post-content-wrap .entry .sc-link-box { text-decoration: none; color: inherit; }
.post-sidebar { display: flex; flex-direction: column; gap: 1rem; position: sticky; top: 90px; align-self: start; }
.post-sidebar__inner { display: flex; flex-direction: column; gap: 1rem; }
.post-sidebar__card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.4rem; }
.post-sidebar__card--dark { background: var(--grad); border-color: transparent; }
.post-sidebar__label { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin: 0 0 .9rem; }
.post-sidebar__author { display: flex; align-items: center; gap: .8rem; margin-bottom: 1rem; }
.post-sidebar__avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--grad); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 1.1rem; color: #fff; flex-shrink: 0; }
.post-sidebar__author strong { display: block; font-size: .88rem; font-weight: 700; color: var(--ink); }
.post-sidebar__author span { font-size: .75rem; color: var(--muted); }
.post-sidebar__cta { display: flex; align-items: center; gap: .5rem; background: var(--brand); color: #fff; text-decoration: none; padding: .65rem 1rem; border-radius: 8px; font-size: .83rem; font-weight: 700; transition: opacity .2s; justify-content: center; }
.post-sidebar__cta:hover { opacity: .88; }
.post-sidebar__cta svg { width: 16px; height: 16px; }
.post-sidebar__facts { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; }
.post-sidebar__facts li { font-size: .85rem; color: var(--muted); display: flex; gap: .4rem; }
.post-sidebar__facts strong { color: var(--brand); font-weight: 800; }
.post-sidebar__prices { display: flex; flex-direction: column; gap: .5rem; }
.post-sidebar__prices a { display: flex; align-items: center; justify-content: space-between; background: rgba(255,255,255,.08); border-radius: 8px; padding: .55rem .8rem; text-decoration: none; transition: background .15s; }
.post-sidebar__prices a:hover { background: rgba(255,255,255,.15); }
.post-sidebar__prices span { font-size: .82rem; color: rgba(255,255,255,.7); }
.post-sidebar__prices strong { font-size: .85rem; font-weight: 800; color: #fff; }
.post-related { background: var(--bg-2); }
.post-related__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; margin-top: 2rem; }
.post-related__card { display: flex; flex-direction: column; gap: .8rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.4rem; text-decoration: none; transition: transform .2s, box-shadow .2s; }
.post-related__card:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(8,18,48,.1); }
.post-related__icon { width: 44px; height: 44px; border-radius: 12px; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; }
.post-related__icon svg { width: 22px; height: 22px; color: var(--brand); }
.post-related__body { flex: 1; display: flex; flex-direction: column; gap: .3rem; }
.post-related__body strong { font-size: .92rem; font-weight: 800; color: var(--ink); }
.post-related__body p { font-size: .8rem; color: var(--muted); margin: 0; line-height: 1.5; }
.post-related__price { font-size: .78rem; font-weight: 700; color: var(--brand); background: var(--brand-soft); padding: .22rem .6rem; border-radius: 6px; align-self: flex-start; }
@media (max-width: 1024px) { .post-layout { grid-template-columns: 1fr 260px; } .post-related__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 768px) { .post-layout { grid-template-columns: 1fr; } .post-sidebar { position: static; } .post-related__grid { grid-template-columns: 1fr; } }

/* ---- Sidebar papildymai ---- */
.post-sidebar__bio { font-size: .8rem; color: var(--muted); line-height: 1.6; margin: .6rem 0 1rem; }
.post-sidebar__stat-grid { display: grid !important; grid-template-columns: 1fr 1fr; gap: .6rem; }
.post-sidebar__stat { background: var(--bg-2); border-radius: var(--radius); padding: .9rem; display: flex; flex-direction: column; align-items: center; text-align: center; gap: .15rem; }
.post-sidebar__stat strong { font-size: 1.3rem; font-weight: 900; color: var(--brand); line-height: 1; }
.post-sidebar__stat span { font-size: .7rem; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; }
.post-sidebar__label--light { color: rgba(255,255,255,.45) !important; }
.post-sidebar__prices a { display: flex; align-items: center; gap: .6rem; }
.post-sidebar__prices a svg { width: 15px; height: 15px; color: rgba(255,255,255,.5); flex-shrink: 0; }
.post-sidebar__projects-text { font-size: .83rem; color: var(--muted); line-height: 1.6; margin: 0 0 1rem; }
.post-sidebar__proj-btn { display: flex; align-items: center; justify-content: space-between; gap: .5rem; background: var(--brand-soft); color: var(--brand); text-decoration: none; padding: .65rem 1rem; border-radius: 8px; font-size: .83rem; font-weight: 700; transition: background .2s; }
.post-sidebar__proj-btn:hover { background: var(--brand); color: #fff; }
.post-content-wrap .entry { max-width: none; margin: 0; }
.sc-cta .btn.hero-btn-blue, .sc-cta .btn.hero-btn-red { color: #fff !important; text-decoration: none !important; }
.sc-cta .btn.hero-btn-blue span, .sc-cta .btn.hero-btn-red span { color: #fff !important; }
.sc-cta .btn.hero-btn-blue::before { background: rgba(255,255,255,.15) !important; }
.sc-cta .btn.hero-btn-blue:hover { color: #fff !important; }
.sc-cta .btn.hero-btn-blue:hover span { color: #fff !important; }
.sc-cta .btn.hero-btn-red::before { background: rgba(255,255,255,.15) !important; }
.sc-cta .btn.hero-btn-red:hover { color: #fff !important; }
.sc-cta .btn.hero-btn-red:hover span { color: #fff !important; }
.post-sidebar__card--cta { background: var(--brand-soft); border-color: rgba(var(--brand-rgb),.15); }
.post-sidebar__cta-sticky { }
.post-sidebar__related { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .6rem; }
.post-sidebar__related li a { display: flex; align-items: center; gap: .7rem; text-decoration: none; color: var(--ink); font-size: .83rem; font-weight: 600; line-height: 1.4; transition: color .15s; }
.post-sidebar__related li a:hover { color: var(--brand); }
.post-sidebar__related-img { width: 48px; height: 48px; border-radius: 8px; overflow: hidden; flex-shrink: 0; }
.post-sidebar__related-img img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ---- TOC shortcode ---- */
.sc-toc { background: var(--surface); border: 1px solid var(--border); border-left: 3px solid var(--brand); border-radius: var(--radius-lg); padding: 1.4rem 1.6rem; margin: 1.8rem 0; }
.sc-toc__title { font-size: .75rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--brand); margin: 0 0 .8rem; }
.sc-toc ol { margin: 0; padding-left: 1.2rem; display: flex; flex-direction: column; gap: .35rem; }
.sc-toc li { font-size: .88rem; }
.sc-toc a { color: var(--ink); text-decoration: none; transition: color .15s; }
.sc-toc a:hover { color: var(--brand); }

/* ---- Post hero data ---- */
.post-hero__date { font-size: .78rem; color: rgba(255,255,255,.5); margin-top: .5rem; display: block; }

/* ---- Post content h2 anchor offset ---- */
.post-content-wrap .entry h2[id] { scroll-margin-top: 100px; }

/* ---- Kategorijos hero ---- */
.cat-hero { background: var(--grad); padding: clamp(2.5rem,5vw,4rem) 0 2.5rem; }
.cat-hero .proj-back { margin-bottom: 1.2rem; }
.cat-hero .kicker { color: rgba(255,255,255,.6); }
.cat-hero h1 { color: #fff; font-size: clamp(1.5rem,3vw,2.4rem); margin: .6rem 0 1rem; max-width: 70ch; line-height: 1.2; }
.cat-hero__lead { color: rgba(255,255,255,.8); font-size: 1rem; max-width: 65ch; line-height: 1.7; margin: 0 0 1.2rem; }
.cat-hero__badges { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1rem; }
.cat-hero__badge { background: rgba(255,255,255,.12); color: rgba(255,255,255,.9); font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: .25rem .7rem; border-radius: 6px; }
.cat-hero__meta { font-size: .8rem; color: rgba(255,255,255,.45); }

/* ---- Yoast meta kategorijoms ---- */

/* ---- Skaitymo progreso juosta ---- */
.read-progress { position: fixed; top: 0; left: 0; height: 3px; width: 0%; background: linear-gradient(90deg, var(--brand), #e53e3e); z-index: 9999; transition: width .1s linear; }

/* ---- Post placeholder ---- */
.post-placeholder { width: 100%; height: 380px; border-radius: var(--radius-lg); display: flex; align-items: center; justify-content: center; }
.post-placeholder span { font-size: 6rem; font-weight: 900; color: rgba(255,255,255,.15); line-height: 1; }

/* ---- Share mygtukai ---- */
.post-bottom { border-top: 1px solid var(--border); }
.post-share { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.post-share__label { font-size: .8rem; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; }
.post-share__btn { display: inline-flex; align-items: center; gap: .4rem; background: var(--surface); border: 1px solid var(--border); color: var(--ink); padding: .45rem .9rem; border-radius: 8px; font-size: .82rem; font-weight: 600; cursor: pointer; text-decoration: none; transition: border-color .15s, color .15s; }
.post-share__btn:hover { border-color: var(--brand); color: var(--brand); }
.post-share__btn svg { width: 15px; height: 15px; }

/* ---- Prev/Next navigacija ---- */
.post-nav { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.post-nav__item { display: flex; flex-direction: column; gap: .3rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.2rem 1.4rem; text-decoration: none; transition: border-color .2s, transform .2s; }
.post-nav__item:hover { border-color: rgba(var(--brand-rgb),.3); transform: translateY(-2px); }
.post-nav__item--next { text-align: right; }
.post-nav__dir { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--brand); }
.post-nav__title { font-size: .88rem; font-weight: 700; color: var(--ink); line-height: 1.4; }
@media(max-width:600px){ .post-nav { grid-template-columns: 1fr; } .post-nav__item--next { text-align: left; } }

/* ---- Cookie consent ---- */
.cookie-bar { position: fixed; bottom: -100px; left: 1rem; right: 1rem; max-width: 540px; margin: 0 auto; background: var(--ink); color: #fff; border-radius: var(--radius-lg); padding: 1rem 1.4rem; display: flex; align-items: center; gap: 1rem; z-index: 9998; box-shadow: 0 8px 32px rgba(0,0,0,.3); transition: bottom .35s cubic-bezier(.34,1.56,.64,1); }
.cookie-bar.is-visible { bottom: 1rem; }
.cookie-bar p { font-size: .85rem; margin: 0; flex: 1; color: rgba(255,255,255,.85); }
.cookie-bar a { color: #93c5fd; text-decoration: underline; }
.cookie-bar button { background: var(--brand); color: #fff; border: none; padding: .5rem 1.1rem; border-radius: 8px; font-size: .83rem; font-weight: 700; cursor: pointer; white-space: nowrap; transition: opacity .15s; }
.cookie-bar button:hover { opacity: .88; }

/* ---- Susijusių projektų sekcija poste ---- */
.post-proj-section { background: var(--bg-2); }
.post-proj-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.2rem; margin-top: 2rem; }
.post-proj-card { display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; text-decoration: none; transition: transform .2s, box-shadow .2s; }
.post-proj-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(8,18,48,.12); }
.post-proj-card__img { aspect-ratio: 16/10; overflow: hidden; }
.post-proj-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.post-proj-card:hover .post-proj-card__img img { transform: scale(1.04); }
.post-proj-card__body { flex: 1; padding: 1.1rem 1.2rem .8rem; display: flex; flex-direction: column; gap: .35rem; }
.post-proj-card__badges { display: flex; gap: .4rem; flex-wrap: wrap; }
.post-proj-card__body strong { font-size: .92rem; font-weight: 800; color: var(--ink); }
.post-proj-card__url { font-size: .78rem; color: var(--muted); }
.post-proj-card__arrow { padding: .8rem 1.2rem; display: flex; justify-content: flex-end; }
.post-proj-card__arrow svg { width: 18px; height: 18px; color: var(--brand); }
@media(max-width:900px){ .post-proj-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:560px){ .post-proj-grid { grid-template-columns: 1fr; } }

/* ---- Blog filtrai ---- */
.blog-filters { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 2rem; }
.blog-filter { display: inline-flex; align-items: center; gap: .4rem; background: var(--surface); border: 1px solid var(--border); color: var(--muted); padding: .45rem 1rem; border-radius: 50px; font-size: .83rem; font-weight: 600; cursor: pointer; transition: all .2s; }
.blog-filter:hover { border-color: var(--brand); color: var(--brand); }
.blog-filter.is-active { background: var(--brand); border-color: var(--brand); color: #fff; }
.blog-filter__count { background: rgba(255,255,255,.25); font-size: .7rem; padding: .1rem .4rem; border-radius: 10px; }
.blog-filter:not(.is-active) .blog-filter__count { background: var(--bg-2); color: var(--muted); }

/* ---- Post card placeholder ---- */
.post-card__placeholder { width: 100%; aspect-ratio: 16/9; display: flex; align-items: center; justify-content: center; }
.post-card__placeholder span { font-size: 3.5rem; font-weight: 900; color: rgba(255,255,255,.15); }

/* ---- Post card footer ---- */
.post-card__footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: .5rem; }
.post-card__read-time { font-size: .75rem; color: var(--muted); }

/* ---- Post proj marquee spacing ---- */
.post-proj-marquee { background: var(--bg-2); }

@keyframes fadeIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:none; } }

/* ---- Paslaugų puslapio susijusių postų sekcija ---- */
.svc-related-posts { background: var(--bg-2); }
.svc-post-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.2rem; margin-top: 2rem; }
.svc-post-card { display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; text-decoration: none; transition: transform .2s, box-shadow .2s; }
.svc-post-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(8,18,48,.1); }
.svc-post-card__img { aspect-ratio: 16/9; overflow: hidden; }
.svc-post-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.svc-post-card:hover .svc-post-card__img img { transform: scale(1.04); }
.svc-post-card__placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
.svc-post-card__placeholder span { font-size: 2.5rem; font-weight: 900; color: rgba(255,255,255,.15); }
.svc-post-card__body { flex: 1; padding: 1rem 1.1rem; display: flex; flex-direction: column; gap: .35rem; }
.svc-post-card__cat { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--brand); }
.svc-post-card__body strong { font-size: .88rem; font-weight: 700; color: var(--ink); line-height: 1.4; }
.svc-post-card__time { font-size: .75rem; color: var(--muted); margin-top: auto; }
@media(max-width:900px){ .svc-post-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:560px){ .svc-post-grid { grid-template-columns: 1fr; } }

/* ---- Paslaugų puslapio inline kontaktų forma ---- */
.svc-contact-inline { background: var(--grad); }
.svc-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.svc-contact-text .kicker { color: rgba(255,255,255,.6); }
.svc-contact-text h2 { color: #fff; font-size: clamp(1.6rem,2.5vw,2.2rem); margin: .5rem 0 1rem; }
.svc-contact-text .lead { color: rgba(255,255,255,.8); margin: 0 0 1.5rem; }
.svc-contact-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .8rem; }
.svc-contact-list li { display: flex; align-items: center; gap: .7rem; color: rgba(255,255,255,.85); font-size: .9rem; }
.svc-contact-list svg { width: 18px; height: 18px; color: rgba(255,255,255,.5); flex-shrink: 0; }
.svc-contact-list a { color: #fff; text-decoration: none; font-weight: 600; }
.svc-contact-form { background: #fff; border-radius: var(--radius-lg); padding: 2rem; box-shadow: 0 20px 60px rgba(8,18,48,.25); }
.svc-form { display: flex; flex-direction: column; gap: .8rem; }
.svc-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
.svc-form input, .svc-form textarea { width: 100%; padding: .75rem 1rem; border: 1px solid var(--border); border-radius: 10px; font-size: .9rem; font-family: var(--font); color: var(--ink); background: var(--bg); transition: border-color .2s; box-sizing: border-box; }
.svc-form input:focus, .svc-form textarea:focus { outline: none; border-color: var(--brand); }
.svc-form textarea { resize: vertical; min-height: 100px; }
@media(max-width:900px){ .svc-contact-grid { grid-template-columns: 1fr; gap: 2rem; } .svc-form__row { grid-template-columns: 1fr; } }
