/* site2 ortak stil dosyası: tema değişken tabanlı */

html,
body {
    margin: 0;
    padding: 0;
}

html {
    overflow-x: hidden;
}

body {
    font-family: Manrope, sans-serif;
    background:
        radial-gradient(circle at 8% -8%, rgba(63, 131, 255, .22) 0, rgba(63, 131, 255, 0) 45%),
        radial-gradient(circle at 95% 8%, rgba(0, 169, 255, .14) 0, rgba(0, 169, 255, 0) 35%),
        linear-gradient(180deg, var(--theme-bg-start, #f3f7ff) 0%, var(--theme-bg-end, #f8fbff) 100%);
    color: var(--theme-ink, #0c1530);
    overflow-x: hidden;
}

.mesh {
    background-image:
        linear-gradient(to right, rgba(99, 140, 220, .10) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(99, 140, 220, .10) 1px, transparent 1px);
    background-size: 44px 44px;
}

.glass { background: rgba(255, 255, 255, 0.85); backdrop-filter: blur(8px); }
section[id] { scroll-margin-top: 96px; }

.section-orb::before {
    content: "";
    position: absolute;
    inset: -120px auto auto -100px;
    width: 280px;
    height: 280px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(23, 118, 255, .18), rgba(23, 118, 255, 0));
    pointer-events: none;
}

.cta-shell {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(190, 219, 255, .55);
    background: var(--theme-gradient-hero, linear-gradient(130deg, #0c2c6f 0%, #1251bf 52%, #04a8f7 100%));
    isolation: isolate;
}

.cta-shell::before {
    content: "";
    position: absolute;
    width: 320px;
    height: 320px;
    right: -80px;
    top: -120px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(255, 255, 255, .36) 0%, rgba(255, 255, 255, 0) 72%);
    pointer-events: none;
    z-index: -1;
}

.cta-shell::after {
    content: "";
    position: absolute;
    width: 340px;
    height: 340px;
    left: -130px;
    bottom: -170px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(25, 255, 241, .34) 0%, rgba(25, 255, 241, 0) 72%);
    pointer-events: none;
    z-index: -1;
}

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

@keyframes heroFadeInScale {
    from { opacity: 0; transform: translateY(10px) scale(.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

.hero-fade-up { animation: heroFadeUp .42s ease-out both; }
.hero-fade-up-delay { animation: heroFadeUp .52s ease-out .08s both; }
.hero-fade-in-scale { animation: heroFadeInScale .48s ease-out .06s both; }

#sss .faq-shell,
#sss .faq-details,
#sss .faq-contact { transition: all .25s ease; }

#sss.faq-theme-dynamic .faq-shell {
    border-color: #dbeafe;
    background: linear-gradient(to bottom, #ffffff 0%, rgba(239, 246, 255, .75) 100%);
    box-shadow: 0 22px 60px -30px rgba(15, 95, 233, .38);
}

#sss.faq-theme-dynamic .faq-contact {
    background: rgba(255, 255, 255, .92);
    border-color: #bfdbfe;
    box-shadow: 0 12px 30px -20px rgba(15, 95, 233, .45);
}

#sss.faq-theme-dynamic .faq-details[open] {
    background: rgba(239, 246, 255, .45);
    box-shadow: inset 3px 0 0 var(--theme-brand, #0f5fe9), 0 10px 26px rgba(16, 40, 90, .08);
    border-color: #bfdbfe;
}

.blog-controls-shell {
    border: 1px solid #dbeafe;
    background: linear-gradient(135deg, rgba(255, 255, 255, .95), rgba(239, 246, 255, .82));
    box-shadow: 0 10px 28px -18px rgba(15, 95, 233, .45);
}

.blog-nav-btn {
    border: 1px solid #dbeafe;
    background: rgba(255, 255, 255, .9);
    transition: all .25s ease;
}

.blog-nav-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 24px -16px rgba(15, 95, 233, .55);
    background: #eff6ff;
}

.blog-slide {
    transform-origin: center top;
    transition: transform .45s ease, opacity .45s ease, filter .45s ease, box-shadow .45s ease;
}

.blog-slide.is-active {
    opacity: 1;
    transform: scale(1);
    filter: saturate(1);
    box-shadow: 0 18px 40px -24px rgba(15, 95, 233, .45);
}

.blog-slide.is-near { opacity: .92; transform: scale(.985); filter: saturate(.96); }
.blog-slide.is-far { opacity: .72; transform: scale(.962); filter: saturate(.88); }

.blog-title {
    min-height: 3.6rem;
}

.blog-home-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    min-height: 3.4rem;
    line-height: 1.35;
}

.blog-excerpt {
    min-height: 6.1rem;
}

.blog-home-excerpt {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    min-height: 5.25rem;
}

.blog-meta {
    letter-spacing: .01em;
}

.footer-fade-line {
    height: 18px;
    background: linear-gradient(180deg, rgba(34, 211, 238, .10) 0%, rgba(15, 23, 42, .92) 100%);
}

.footer-title-accent {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.footer-title-accent::before {
    content: "";
    width: 28px;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, #22d3ee, #3b82f6);
}

.footer-title-accent::after {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: #38bdf8;
    box-shadow: 0 0 0 4px rgba(56, 189, 248, .18);
}

.story-shell {
    background: linear-gradient(145deg, #0f3f99 0%, #1251bf 48%, #00a6f6 100%);
    border: 1px solid rgba(186, 217, 255, .45);
}

.story-shell::before {
    content: "";
    position: absolute;
    right: -120px;
    top: -120px;
    width: 280px;
    height: 280px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(255, 255, 255, .35) 0%, rgba(255, 255, 255, 0) 72%);
}

.story-shell::after {
    content: "";
    position: absolute;
    left: -140px;
    bottom: -140px;
    width: 260px;
    height: 260px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(20, 255, 241, .28) 0%, rgba(20, 255, 241, 0) 75%);
}

.timeline-line::before,
.step-line::before {
    content: "";
    position: absolute;
    left: 12px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(180deg, #bfdbfe 0%, #dbeafe 100%);
}

.contact-hero,
.blog-hero,
.shop-hero,
.service-hero {
    border: 1px solid rgba(186, 217, 255, .45);
    background: linear-gradient(140deg, #0f3f99 0%, #1251bf 50%, #00a8f8 100%);
}

.contact-hero::before,
.blog-hero::before,
.shop-hero::before,
.service-hero::before {
    content: "";
    position: absolute;
    width: 320px;
    height: 320px;
    right: -100px;
    top: -120px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(255, 255, 255, .32) 0%, rgba(255, 255, 255, 0) 72%);
}

.service-hero::after {
    content: "";
    position: absolute;
    width: 260px;
    height: 260px;
    left: -100px;
    bottom: -130px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(0, 255, 242, .28) 0%, rgba(0, 255, 242, 0) 75%);
}

.glass-panel {
    border: 1px solid rgba(255, 255, 255, .25);
    background: linear-gradient(155deg, rgba(255, 255, 255, .20), rgba(255, 255, 255, .08));
    backdrop-filter: blur(4px);
}

.blog-card,
.product-card { transition: transform .25s ease, box-shadow .25s ease; }

.blog-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 22px 36px -24px rgba(15, 95, 233, .5);
}

.product-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 34px -24px rgba(15, 95, 233, .55);
}

.chip.active {
    border-color: var(--theme-brand, #0f5fe9);
    background: #eff6ff;
    color: var(--theme-brand, #0f5fe9);
}

.filter-shell,
.load-more-shell {
    border: 1px solid #dbeafe;
    background: var(--theme-gradient-surface, linear-gradient(155deg, rgba(255, 255, 255, .95), rgba(239, 246, 255, .84)));
    box-shadow: 0 14px 32px -24px rgba(15, 95, 233, .45);
}

.blog-content {
    color: var(--theme-ink, #0c1530);
    font-size: 1rem;
    line-height: 1.9;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.blog-content section + section {
    margin-top: 2rem;
}

.blog-content h2,
.blog-content h3,
.blog-content h4 {
    margin: 1.5rem 0 .75rem;
    color: var(--theme-ink, #0c1530);
    font-family: Manrope, sans-serif;
    font-weight: 800;
    line-height: 1.25;
    letter-spacing: -.02em;
}

.blog-content h2 {
    font-size: 1.9rem;
}

.blog-content h3 {
    font-size: 1.35rem;
}

.blog-content h4 {
    font-size: 1.1rem;
}

.blog-content p {
    margin: 0 0 1rem;
    color: #334155;
}

.blog-content ul,
.blog-content ol {
    margin: 0 0 1.25rem;
    padding-left: 1.35rem;
    color: #334155;
}

.blog-content li {
    margin-bottom: .55rem;
}

.blog-content strong {
    color: var(--theme-ink, #0c1530);
    font-weight: 800;
}

.blog-content a {
    color: var(--theme-brand, #0f5fe9);
    font-weight: 700;
    text-decoration: none;
}

.blog-content a:hover {
    text-decoration: underline;
}

.blog-content blockquote {
    margin: 1.5rem 0;
    padding: 1rem 1.25rem;
    border-left: 4px solid var(--theme-brand, #0f5fe9);
    border-radius: 0 1rem 1rem 0;
    background: #eff6ff;
    color: #1e3a8a;
}

.blog-content img {
    display: block;
    max-width: 100%;
    height: auto;
    margin: 1.5rem 0;
    border: 1px solid #dbeafe;
    border-radius: 1rem;
}

.blog-content table {
    width: 100%;
    margin: 1.75rem 0;
    border-collapse: collapse;
    border: 1px solid #e2e8f0;
    border-radius: 1rem;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 14px 32px -26px rgba(15, 95, 233, .25);
}

.blog-content thead th {
    background: #f8fafc;
    color: var(--theme-ink, #0c1530);
    font-size: .95rem;
    font-weight: 800;
    letter-spacing: -.01em;
}

.blog-content th,
.blog-content td {
    padding: .95rem 1rem;
    border: 1px solid #e2e8f0;
    text-align: left;
    vertical-align: top;
    color: #334155;
}

.blog-content tbody tr:nth-child(even) {
    background: #f8fbff;
}

.blog-content table p,
.blog-content table ul,
.blog-content table ol {
    margin: 0;
}

.blog-content figure.table {
    display: block;
    width: 100%;
    max-width: 100%;
    margin: 1.75rem 0;
}

.blog-table-wrap {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.service-content {
    color: var(--theme-ink, #0c1530);
    font-size: 1rem;
    line-height: 1.9;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.about-content {
    color: var(--theme-ink, #0c1530);
    font-size: 1rem;
    line-height: 1.9;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.about-content section + section {
    margin-top: 2rem;
}

.about-content h2,
.about-content h3,
.about-content h4 {
    margin: 1.5rem 0 .75rem;
    color: var(--theme-ink, #0c1530);
    font-family: Manrope, sans-serif;
    font-weight: 800;
    line-height: 1.25;
    letter-spacing: -.02em;
}

.about-content h2 {
    font-size: 1.9rem;
}

.about-content h3 {
    font-size: 1.35rem;
}

.about-content h4 {
    font-size: 1.1rem;
}

.about-content p {
    margin: 0 0 1rem;
    color: #334155;
}

.about-content ul,
.about-content ol {
    margin: 0 0 1.25rem;
    padding-left: 1.35rem;
    color: #334155;
}

.about-content li {
    margin-bottom: .55rem;
}

.about-content strong {
    color: var(--theme-ink, #0c1530);
    font-weight: 800;
}

.about-content a {
    color: var(--theme-brand, #0f5fe9);
    font-weight: 700;
    text-decoration: none;
}

.about-content a:hover {
    text-decoration: underline;
}

.about-content blockquote {
    margin: 1.5rem 0;
    padding: 1rem 1.25rem;
    border-left: 4px solid var(--theme-brand, #0f5fe9);
    border-radius: 0 1rem 1rem 0;
    background: #eff6ff;
    color: #1e3a8a;
}

.about-content img {
    display: block;
    max-width: 100%;
    height: auto;
    margin: 1.5rem 0;
    border: 1px solid #dbeafe;
    border-radius: 1rem;
}

.service-content section + section {
    margin-top: 2rem;
}

.service-content h2,
.service-content h3,
.service-content h4 {
    margin: 1.5rem 0 .75rem;
    color: var(--theme-ink, #0c1530);
    font-family: Manrope, sans-serif;
    font-weight: 800;
    line-height: 1.25;
    letter-spacing: -.02em;
}

.service-content h2 {
    font-size: 1.9rem;
}

.service-content h3 {
    font-size: 1.35rem;
}

.service-content h4 {
    font-size: 1.1rem;
}

.service-content p {
    margin: 0 0 1rem;
    color: #334155;
}

.service-content ul,
.service-content ol {
    margin: 0 0 1.25rem;
    padding-left: 1.35rem;
    color: #334155;
}

.service-content li {
    margin-bottom: .55rem;
}

.service-content strong {
    color: var(--theme-ink, #0c1530);
    font-weight: 800;
}

.service-content a {
    color: var(--theme-brand, #0f5fe9);
    font-weight: 700;
    text-decoration: none;
}

.service-content a:hover {
    text-decoration: underline;
}

.service-content blockquote {
    margin: 1.5rem 0;
    padding: 1rem 1.25rem;
    border-left: 4px solid var(--theme-brand, #0f5fe9);
    border-radius: 0 1rem 1rem 0;
    background: #eff6ff;
    color: #1e3a8a;
}

.service-visual-panel {
    background: linear-gradient(155deg, rgba(255, 255, 255, .98), rgba(239, 246, 255, .82));
}

.service-visual-art {
    background: linear-gradient(155deg, rgba(255, 255, 255, .98), rgba(248, 250, 252, .92));
}

.service-visual-frame {
    border: 1px solid #dbeafe;
    background:
        radial-gradient(circle at top left, rgba(37, 99, 235, .14), transparent 30%),
        radial-gradient(circle at bottom right, rgba(6, 182, 212, .12), transparent 28%),
        linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
}

.service-point {
    box-shadow: 0 10px 22px -20px rgba(15, 95, 233, .2);
}

.service-step,
.service-scenario {
    box-shadow: 0 10px 22px -20px rgba(15, 95, 233, .16);
}

.service-story-card,
.service-mini-card {
    box-shadow: 0 14px 30px -24px rgba(15, 95, 233, .2);
}

.service-story-dot {
    box-shadow: 0 14px 28px -20px rgba(15, 95, 233, .35);
}

.service-showcase {
    background: linear-gradient(160deg, rgba(255, 255, 255, .98), rgba(239, 246, 255, .84));
}

.service-showcase-screen {
    border: 1px solid #dbeafe;
    background:
        radial-gradient(circle at top right, rgba(6, 182, 212, .14), transparent 28%),
        radial-gradient(circle at bottom left, rgba(37, 99, 235, .12), transparent 26%),
        linear-gradient(180deg, #f8fbff 0%, #eef6ff 100%);
}

@media (max-width: 767px) {
    .timeline-line::before,
    .step-line::before { display: none; }

    .blog-content {
        font-size: .97rem;
        line-height: 1.8;
    }

    .blog-content h2 {
        font-size: 1.55rem;
    }

    .blog-content h3 {
        font-size: 1.2rem;
    }

    .service-content {
        font-size: .97rem;
        line-height: 1.8;
    }

    .service-content h2 {
        font-size: 1.55rem;
    }

    .service-content h3 {
        font-size: 1.2rem;
    }

    .service-visual-frame {
        min-height: 220px;
    }

    .blog-content figure.table {
        margin: 1.25rem 0;
    }

    .blog-table-wrap {
        overflow: visible;
    }

    .blog-content table,
    .blog-content thead,
    .blog-content tbody,
    .blog-content tr,
    .blog-content th,
    .blog-content td {
        display: block;
        width: 100%;
    }

    .blog-content thead {
        display: none;
    }

    .blog-content table {
        min-width: 0;
        border: 0;
        box-shadow: none;
        background: transparent;
    }

    .blog-content tbody {
        display: grid;
        gap: .9rem;
    }

    .blog-content tbody tr {
        border: 1px solid #e2e8f0;
        border-radius: 1rem;
        background: #fff;
        overflow: hidden;
        box-shadow: 0 10px 24px -20px rgba(15, 95, 233, .18);
    }

    .blog-content tbody tr:nth-child(even) {
        background: #fff;
    }

    .blog-content td {
        border-left: 0;
        border-right: 0;
        border-top: 0;
        padding: .8rem .95rem;
        font-size: .92rem;
    }

    .blog-content td:last-child {
        border-bottom: 0;
    }

    .blog-content td::before {
        content: attr(data-label);
        display: block;
        margin-bottom: .3rem;
        color: var(--theme-ink, #0c1530);
        font-size: .74rem;
        font-weight: 800;
        text-transform: uppercase;
        letter-spacing: .04em;
    }
}
