/* Language Links */
.language-link {
    padding: 6px 12px;
    border-radius: 8px;
    transition: all 0.2s ease;
}
.language-link:hover {
    background: var(--primary-50);
    color: var(--primary-600);
}
.language-link:hover .font-medium {
    color: var(--primary-600);
}

/* Subscription Badges (Large) */
.subscription-badge-lg {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 0.875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.subscription-badge-lg.gold {
    background: linear-gradient(135deg, #f5af19, #f12711);
    color: white;
    box-shadow: 0 2px 8px rgba(245, 175, 25, 0.4);
}
.subscription-badge-lg.premium {
    background: linear-gradient(135deg, #667eea, #764ba2);
    color: white;
    box-shadow: 0 2px 8px rgba(102, 126, 234, 0.4);
}
.subscription-badge-lg i {
    font-size: 0.75rem;
}

/* Answer Badges (Header icinde - uyelik badge yaninda) */
.answer-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 14px;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
    color: white;
    letter-spacing: 0.3px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.15);
    white-space: nowrap;
}
.answer-badge i {
    font-size: 0.7rem;
}

/* Lawyer Badges */
.lawyer-badges-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
}

.lawyer-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: white;
    border: 1px solid var(--gray-200);
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    color: var(--badge-color, var(--gray-700));
    transition: all 0.2s ease;
    cursor: default;
}

.lawyer-badge:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    border-color: var(--badge-color);
}

.lawyer-badge i {
    font-size: 14px;
    color: var(--badge-color);
}

/* Badge kategorilerine göre özel stiller */
.lawyer-badge[title*="Doğrulandı"],
.lawyer-badge[title*="Onaylı"] {
    background: linear-gradient(135deg, rgba(40, 167, 69, 0.1), rgba(40, 167, 69, 0.05));
    border-color: rgba(40, 167, 69, 0.3);
}

.lawyer-badge[title*="Yıl"] {
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.1), rgba(255, 193, 7, 0.05));
    border-color: rgba(255, 193, 7, 0.3);
}

.lawyer-badge[title*="Premium"],
.lawyer-badge[title*="Gold"],
.lawyer-badge[title*="Platinum"] {
    background: linear-gradient(135deg, rgba(184, 134, 11, 0.1), rgba(184, 134, 11, 0.05));
    border-color: rgba(184, 134, 11, 0.3);
}

@media (max-width: 768px) {
    .lawyer-badges-wrapper {
        gap: 6px;
    }

    .lawyer-badge {
        padding: 4px 10px;
        font-size: 11px;
    }

    .lawyer-badge i {
        font-size: 12px;
    }
}

/* Firm Sidebar Card */
.firm-sidebar-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: var(--gray-50);
    border-radius: 12px;
    text-decoration: none;
    color: inherit;
    transition: all 0.2s ease;
}
.firm-sidebar-card:hover {
    background: var(--primary-50);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
.firm-sidebar-logo {
    width: 56px;
    height: 56px;
    border-radius: 10px;
    overflow: hidden;
    flex-shrink: 0;
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--gray-200);
}
.firm-sidebar-logo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.firm-logo-placeholder {
    color: var(--gray-400);
}
.firm-sidebar-info {
    flex: 1;
    min-width: 0;
}
.firm-sidebar-name {
    font-weight: 600;
    font-size: 15px;
    color: var(--gray-800);
    display: flex;
    align-items: center;
    gap: 6px;
    line-height: 1.3;
}
.firm-sidebar-rating {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 4px;
    font-size: 13px;
    color: var(--gray-600);
}

/* Colored Tabs */
.tabs {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    padding: 8px;
    background: var(--gray-50);
    border-radius: var(--radius-lg);
}

.tab-link {
    padding: 12px 20px;
    border: none;
    background: transparent;
    color: var(--gray-600);
    font-weight: 500;
    font-size: 14px;
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 8px;
}

.tab-link:hover {
    background: white;
    color: var(--gray-800);
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

/* Tab renkleri - Hakkında */
.tab-link[data-tab="about"].active {
    background: linear-gradient(135deg, var(--primary-500), var(--primary-600));
    color: white;
    box-shadow: 0 4px 12px rgba(64, 128, 196, 0.3);
}

/* Tab renkleri - Eğitim */
.tab-link[data-tab="education"].active {
    background: linear-gradient(135deg, #10b981, #059669);
    color: white;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}

/* Tab renkleri - Deneyim */
.tab-link[data-tab="experience"].active {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: white;
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3);
}

/* Tab renkleri - Galeri */
.tab-link[data-tab="gallery"].active {
    background: linear-gradient(135deg, #8b5cf6, #7c3aed);
    color: white;
    box-shadow: 0 4px 12px rgba(139, 92, 246, 0.3);
}

/* Tab renkleri - Değerlendirmeler */
.tab-link[data-tab="reviews"].active {
    background: linear-gradient(135deg, #ec4899, #db2777);
    color: white;
    box-shadow: 0 4px 12px rgba(236, 72, 153, 0.3);
}

/* Gallery Grid */
.lawyer-gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
}

.lawyer-gallery-item {
    position: relative;
    aspect-ratio: 4/3;
    border-radius: var(--radius-lg);
    overflow: hidden;
    cursor: pointer;
    background: var(--gray-100);
}

.lawyer-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.lawyer-gallery-item:hover img {
    transform: scale(1.05);
}

.lawyer-gallery-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.lawyer-gallery-item:hover .lawyer-gallery-overlay {
    opacity: 1;
}

/* Lightbox */
.gallery-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.95);
    z-index: 9999;
    align-items: center;
    justify-content: center;
}

.gallery-lightbox.active {
    display: flex;
}

.lightbox-close {
    position: absolute;
    top: 20px;
    right: 20px;
    background: none;
    border: none;
    color: white;
    font-size: 40px;
    cursor: pointer;
    z-index: 10;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s;
}

.lightbox-close:hover {
    transform: scale(1.2);
}

.lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.1);
    border: none;
    color: white;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
    z-index: 10;
}

.lightbox-nav:hover {
    background: rgba(255, 255, 255, 0.2);
}

.lightbox-prev {
    left: 20px;
}

.lightbox-next {
    right: 20px;
}

.lightbox-content {
    max-width: 90vw;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.lightbox-content img {
    max-width: 100%;
    max-height: 80vh;
    object-fit: contain;
    border-radius: var(--radius-lg);
}

.lightbox-title {
    color: white;
    margin-top: 16px;
    font-size: var(--text-lg);
    text-align: center;
}

@media (max-width: 768px) {
    .section .flex.gap-8 {
        flex-direction: column;
    }

    .section aside {
        width: 100% !important;
    }

    .section-sm .flex.gap-6 {
        flex-direction: column;
        text-align: center;
    }

    .section-sm .flex.gap-6 > div:last-child {
        width: 100%;
    }

    .lawyer-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }

    .lightbox-nav {
        width: 40px;
        height: 40px;
    }

    .lightbox-prev {
        left: 10px;
    }

    .lightbox-next {
        right: 10px;
    }

    /* ========= PROFILE HERO MOBILE REDESIGN ========= */

    /* Main container: row + wrap so buttons go below */
    section[style*="linear-gradient"] > .container > .flex.gap-6 {
        flex-direction: row !important;
        flex-wrap: wrap !important;
        align-items: flex-start !important;
        text-align: left !important;
        gap: 10px !important;
    }

    /* Avatar: small, stays left */
    section[style*="linear-gradient"] > .container > .flex > div[style*="flex-shrink"] img {
        width: 70px !important;
        height: 70px !important;
        border-radius: 12px !important;
        border-width: 3px !important;
    }

    /* Info section: flex column for reordering children */
    section[style*="linear-gradient"] > .container > .flex > div[style*="flex:1"] {
        flex: 1 !important;
        min-width: 0 !important;
        display: flex !important;
        flex-direction: column !important;
    }

    /* Name+Meta wrapper: transparent so children can be reordered */
    section[style*="linear-gradient"] .flex.items-center.gap-6.flex-wrap {
        display: contents !important;
    }

    /* Badges row: order 1 */
    section[style*="linear-gradient"] > .container > .flex > div[style*="flex:1"] > .flex.items-center.gap-3.mb-2 {
        order: 1 !important;
        flex-direction: row !important;
        flex-wrap: wrap !important;
        gap: 4px !important;
        margin-bottom: 2px !important;
    }

    /* Name (h1): order 2 */
    section[style*="linear-gradient"] h1 {
        order: 2 !important;
        font-size: 1.15rem !important;
        margin-bottom: 4px !important;
    }

    /* Bio: order 3 */
    section[style*="linear-gradient"] > .container > .flex > div[style*="flex:1"] > p {
        order: 3 !important;
        font-size: 12px !important;
        margin-bottom: 6px !important;
        line-height: 1.4 !important;
        opacity: 0.85 !important;
    }

    /* Meta (location, bar, experience): order 4 - BELOW bio */
    section[style*="linear-gradient"] .flex.flex-wrap.gap-4[style*="color"] {
        order: 4 !important;
        flex-direction: row !important;
        flex-wrap: wrap !important;
        font-size: 12px !important;
        gap: 8px !important;
        margin-bottom: 4px !important;
    }

    /* Meta item icons stay inline */
    section[style*="linear-gradient"] .flex.flex-wrap.gap-4 .flex.items-center.gap-2,
    section[style*="linear-gradient"] .flex.flex-wrap.gap-4 a.flex.items-center.gap-2 {
        flex-direction: row !important;
    }

    /* Rating: order 5 */
    section[style*="linear-gradient"] > .container > .flex > div[style*="flex:1"] > .flex.items-center.gap-3.mt-4 {
        order: 5 !important;
        flex-direction: row !important;
        margin-top: 4px !important;
    }

    section[style*="linear-gradient"] .flex.items-center.gap-3.mt-4 .flex.items-center.gap-1 {
        flex-direction: row !important;
    }

    /* Action buttons: full width horizontal row below everything */
    section[style*="linear-gradient"] > .container > .flex > .flex.flex-col.gap-2 {
        position: static !important;
        flex: 0 0 100% !important;
        flex-direction: row !important;
        gap: 6px !important;
        min-width: auto !important;
        order: 10 !important;
        margin-top: 4px !important;
    }

    section[style*="linear-gradient"] .flex.flex-col.gap-2[style*="min-width"] .btn {
        flex: 1 !important;
        font-size: 11px !important;
        padding: 8px 4px !important;
        justify-content: center !important;
        border-radius: 8px !important;
        white-space: nowrap !important;
    }

    section[style*="linear-gradient"] .flex.flex-col.gap-2[style*="min-width"] .btn svg {
        width: 14px !important;
        height: 14px !important;
    }

    /* Cards */
    .card .grid.grid-cols-2 {
        grid-template-columns: 1fr !important;
    }

    .tabs {
        padding: 6px;
    }

    .tab-link {
        padding: 10px 14px;
        font-size: 13px;
    }

    /* Contact Card */
    .card-body .flex.gap-3 {
        font-size: 14px;
    }

    /* Stats Card */
    .card-body .grid.grid-cols-2.gap-4 > div > div:first-child {
        font-size: 20px !important;
    }
}

@media (max-width: 480px) {
    section[style*="linear-gradient"] {
        padding: 8px 0 !important;
    }

    section[style*="linear-gradient"] > .container > .flex.gap-6 {
        gap: 8px !important;
    }

    section[style*="linear-gradient"] > .container > .flex > div[style*="flex-shrink"] img {
        width: 56px !important;
        height: 56px !important;
        border-radius: 10px !important;
        border-width: 2px !important;
    }

    section[style*="linear-gradient"] h1 {
        font-size: 0.95rem !important;
    }

    section[style*="linear-gradient"] > .container > .flex > div[style*="flex:1"] > p {
        font-size: 11px !important;
        line-height: 1.3 !important;
        margin-bottom: 4px !important;
    }

    section[style*="linear-gradient"] > .container > .flex > div[style*="flex:1"] > .flex.items-center.gap-3.mb-2 {
        gap: 2px !important;
        margin-bottom: 1px !important;
    }

    section[style*="linear-gradient"] .flex.flex-wrap.gap-4 {
        font-size: 10px !important;
        gap: 6px !important;
    }

    section[style*="linear-gradient"] .flex.flex-wrap.gap-4 i {
        font-size: 9px !important;
    }

    /* Rating stars compact */
    section[style*="linear-gradient"] .flex.items-center.gap-3.mt-4 {
        gap: 4px !important;
        margin-top: 4px !important;
    }

    section[style*="linear-gradient"] .flex.items-center.gap-3.mt-4 svg {
        width: 14px !important;
        height: 14px !important;
    }

    section[style*="linear-gradient"] .flex.items-center.gap-3.mt-4 span[style*="font-size:20px"] {
        font-size: 13px !important;
    }

    section[style*="linear-gradient"] .flex.items-center.gap-3.mt-4 span[style*="color:var(--primary-300)"] {
        font-size: 10px !important;
    }

    /* Action buttons: icon-only on small phones */
    section[style*="linear-gradient"] > .container > .flex > .flex.flex-col.gap-2 {
        gap: 4px !important;
    }

    section[style*="linear-gradient"] .flex.flex-col.gap-2[style*="min-width"] .btn {
        font-size: 0 !important;
        padding: 7px !important;
        flex: 0 !important;
        width: auto !important;
    }

    section[style*="linear-gradient"] .flex.flex-col.gap-2[style*="min-width"] .btn svg {
        width: 16px !important;
        height: 16px !important;
    }

    /* Main content section */
    section[style*="padding:24px"] {
        padding: 12px 0 !important;
    }

    /* Badges section compact */
    section[style*="padding:12px"] {
        padding: 8px 0 !important;
    }

    .lawyer-gallery-grid {
        grid-template-columns: 1fr 1fr;
        gap: 4px;
    }

    .lawyer-gallery-item {
        aspect-ratio: 1;
    }

    .tabs {
        gap: 2px;
    }

    .tab-link {
        padding: 8px 10px;
        font-size: 11px;
    }

    .card-header h3 {
        font-size: 13px !important;
    }

    .card-body .flex.gap-3 > div:first-child {
        width: 32px !important;
        height: 32px !important;
    }

    .card-body .flex.gap-3 svg {
        width: 16px !important;
        height: 16px !important;
    }

    /* Card spacing minimal */
    .card.mb-6 {
        margin-bottom: 12px !important;
    }

    .card.mb-4 {
        margin-bottom: 8px !important;
    }

    /* About section compact */
    .card-body[style*="line-height:1.7"] {
        font-size: 13px !important;
        line-height: 1.5 !important;
    }

    /* Education/Experience items */
    .card-body .flex.justify-between {
        flex-direction: column !important;
        gap: 2px !important;
    }

    /* Social links compact */
    .flex.gap-2.flex-wrap.mt-4.pt-4.border-t a {
        width: 32px !important;
        height: 32px !important;
    }

    /* Similar lawyers grid */
    .grid.grid-cols-2 {
        grid-template-columns: 1fr !important;
        gap: 8px !important;
    }

    /* Modal body compact */
    .modal-body {
        padding: 12px !important;
    }

    .modal-header {
        padding: 10px 12px !important;
    }

    .modal-footer {
        padding: 10px 12px !important;
    }

    /* Star rating input bigger touch target */
    .star-input svg {
        width: 28px !important;
        height: 28px !important;
    }

    /* Detail rating compact */
    .detail-rating-row {
        font-size: 13px !important;
    }
}

@media (max-width: 360px) {
    section[style*="linear-gradient"] > .container > .flex.gap-6 {
        gap: 6px !important;
    }

    section[style*="linear-gradient"] > .container > .flex > div[style*="flex-shrink"] img {
        width: 48px !important;
        height: 48px !important;
        border-radius: 8px !important;
    }

    section[style*="linear-gradient"] h1 {
        font-size: 0.85rem !important;
    }

    section[style*="linear-gradient"] .flex.flex-wrap.gap-4[style*="color"] {
        font-size: 9px !important;
        gap: 4px !important;
    }

    section[style*="linear-gradient"] > .container > .flex > div[style*="flex:1"] > p {
        font-size: 10px !important;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    /* Badges smaller */
    section[style*="linear-gradient"] .subscription-badge-lg {
        padding: 1px 6px !important;
        font-size: 9px !important;
    }

    section[style*="linear-gradient"] .badge-featured {
        padding: 1px 5px !important;
        font-size: 8px !important;
    }

    section[style*="linear-gradient"] span[style*="background:var(--success-500)"] {
        padding: 1px 6px !important;
        font-size: 8px !important;
    }

    /* Buttons even smaller icons */
    section[style*="linear-gradient"] .flex.flex-col.gap-2[style*="min-width"] .btn {
        padding: 5px !important;
    }

    section[style*="linear-gradient"] .flex.flex-col.gap-2[style*="min-width"] .btn svg {
        width: 14px !important;
        height: 14px !important;
    }

    .tab-link {
        padding: 6px 8px;
        font-size: 10px;
    }

    .card-body {
        padding: 8px !important;
    }

    .card-header {
        padding: 6px 8px !important;
    }
}

/* Contact Items */
.contact-item {
    display: flex;
    gap: 12px;
}

.contact-icon {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    background: var(--primary-50);
    color: var(--primary-500);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* Avukatı Ara Bloğu (Sidebar Üst) */
.contact-card { overflow: hidden; }

.call-attorney-block {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    background: linear-gradient(135deg, var(--primary-600, #2563eb) 0%, var(--primary-700, #1d4ed8) 100%);
    color: #fff;
    border: 0;
    border-radius: 10px;
    padding: 14px 14px;
    margin-bottom: 14px;
    text-decoration: none;
    cursor: pointer;
    font-family: inherit;
    transition: transform .15s ease, box-shadow .15s ease;
    box-shadow: 0 4px 12px rgba(37, 99, 235, .25);
    text-align: left;
}
.call-attorney-block:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(37, 99, 235, .35);
    color: #fff;
    text-decoration: none;
}
.call-attorney-locked {
    background: linear-gradient(135deg, #1e40af 0%, #1e3a8a 100%);
}
.call-attorney-icon {
    width: 38px; height: 38px;
    background: rgba(255,255,255,.18);
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    color: #fff;
    flex-shrink: 0;
}
.call-attorney-content { flex: 1; min-width: 0; }
.call-attorney-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.2px;
    opacity: .85;
    text-transform: uppercase;
    margin-bottom: 2px;
}
.call-attorney-number {
    font-size: 19px;
    font-weight: 700;
    letter-spacing: .3px;
    line-height: 1.1;
}
.call-attorney-cta {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.25;
    color: #fff;
}
.call-attorney-arrow {
    font-size: 22px;
    font-weight: 300;
    color: #fff;
    flex-shrink: 0;
    line-height: 1;
}

/* Adres / Website satırları (resimdeki gibi) */
.contact-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--neutral-100, #f3f4f6);
    text-decoration: none;
    color: inherit;
}
.contact-row:last-of-type { border-bottom: 0; }
.contact-row-link:hover {
    color: var(--primary-600, #2563eb);
}
.contact-row-icon {
    width: 32px; height: 32px;
    border-radius: 8px;
    background: var(--neutral-100, #f3f4f6);
    color: var(--neutral-600, #4b5563);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    margin-top: 2px;
}
.contact-row-body { flex: 1; min-width: 0; }
.contact-row-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.1px;
    color: var(--neutral-500, #6b7280);
    text-transform: uppercase;
    margin-bottom: 2px;
}
.contact-row-value {
    font-size: 14px;
    color: var(--neutral-900, #111827);
    font-weight: 500;
    line-height: 1.35;
    word-break: break-word;
}
.contact-row-website {
    color: var(--primary-600, #2563eb);
}
.contact-row-locality {
    color: var(--neutral-600, #4b5563);
    font-weight: 500;
    font-size: 13px;
}

/* Harita & Yol Tarifi */
.contact-map-wrap {
    margin-top: 14px;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--neutral-200, #e5e7eb);
}
.get-directions-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 10px;
    padding: 8px 14px;
    background: #fff;
    border: 1px solid var(--neutral-200, #e5e7eb);
    border-radius: 999px;
    color: var(--primary-600, #2563eb);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    box-shadow: 0 1px 2px rgba(0,0,0,.05);
    transition: background .15s ease, border-color .15s ease;
}
.get-directions-btn:hover {
    background: var(--primary-50, #eff6ff);
    border-color: var(--primary-200, #bfdbfe);
    color: var(--primary-700, #1d4ed8);
    text-decoration: none;
}

/* Profile Stats Grid */
.profile-stats-grid {
    display: flex;
    gap: 16px;
}

.profile-stat-item {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: var(--gray-50);
    border-radius: 10px;
}

.profile-stat-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--primary-100);
    color: var(--primary-600);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.profile-stat-icon.star {
    background: #fef3c7;
    color: #f59e0b;
}

.profile-stat-content {
    flex: 1;
}

.profile-stat-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--gray-900);
    line-height: 1;
}

.profile-stat-label {
    font-size: 12px;
    color: var(--gray-500);
    margin-top: 2px;
}

@media (max-width: 768px) {
    .profile-stats-grid {
        flex-direction: column;
        gap: 12px;
    }
}

/* Sidebar Lawyer List - Unified Clean Design */
.sidebar-lawyer-list {
    display: flex;
    flex-direction: column;
}

.sidebar-lawyer-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    text-decoration: none;
    color: inherit;
    border-bottom: 1px solid var(--gray-100);
    transition: background 0.15s ease;
}

.sidebar-lawyer-row:last-child {
    border-bottom: none;
}

.sidebar-lawyer-row:hover {
    background: var(--gray-50);
}

.sidebar-lawyer-photo {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    border: 2px solid var(--gray-100);
}

.sidebar-lawyer-content {
    flex: 1;
    min-width: 0;
}

.sidebar-lawyer-name {
    font-weight: 600;
    font-size: 13px;
    color: var(--gray-800);
    line-height: 1.3;
    margin-bottom: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sidebar-lawyer-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--gray-500);
}

.sidebar-lawyer-meta .meta-rating {
    color: #f59e0b;
    font-weight: 600;
}

/* Sidebar Badge for Featured */
.sidebar-badge {
    display: inline-block;
    font-size: 10px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
    margin-bottom: 4px;
}

.sidebar-badge.gold {
    background: linear-gradient(135deg, #fef3c7, #fde68a);
    color: #92400e;
}

.sidebar-badge.blue {
    background: linear-gradient(135deg, #dbeafe, #bfdbfe);
    color: #1e40af;
}

.sidebar-badge.green {
    background: linear-gradient(135deg, #d1fae5, #a7f3d0);
    color: #065f46;
}

.sidebar-badge.purple {
    background: linear-gradient(135deg, #ede9fe, #ddd6fe);
    color: #5b21b6;
}

/* Featured list has slightly different styling */
.sidebar-lawyer-list.featured .sidebar-lawyer-row {
    padding: 14px 16px;
}

.sidebar-lawyer-list.featured .sidebar-lawyer-photo {
    width: 44px;
    height: 44px;
}

@media (max-width: 480px) {
    .sidebar-lawyer-row {
        padding: 10px 12px;
        gap: 10px;
    }

    .sidebar-lawyer-photo {
        width: 36px;
        height: 36px;
    }

    .sidebar-lawyer-name {
        font-size: 12px;
    }

    .sidebar-lawyer-meta {
        font-size: 11px;
    }

    .sidebar-badge {
        font-size: 9px;
        padding: 2px 6px;
    }
}

/* Similar Firm Item */
.similar-firm-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    text-decoration: none;
    color: inherit;
    border-bottom: 1px solid var(--gray-100);
}

.similar-firm-item:last-child {
    border-bottom: none;
}

.similar-firm-item:hover {
    opacity: 0.8;
}

.similar-firm-logo {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    overflow: hidden;
    flex-shrink: 0;
    background: var(--gray-100);
}

.similar-firm-logo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.logo-placeholder-sm {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 12px;
    color: var(--gray-500);
    background: var(--gray-100);
}

.similar-firm-info {
    flex: 1;
    min-width: 0;
}

.similar-firm-name {
    font-weight: 600;
    font-size: 13px;
    color: var(--gray-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.similar-firm-meta {
    font-size: 12px;
    color: var(--gray-500);
    display: flex;
    align-items: center;
    gap: 8px;
}

.similar-firm-meta .rating-inline {
    color: #f59e0b;
}

/* Star Rating Input */
.star-rating-input {
    display: flex;
    gap: 4px;
}

.star-input {
    cursor: pointer;
    color: var(--gray-300);
    transition: color 0.15s ease, transform 0.15s ease;
}

.star-input:hover {
    transform: scale(1.1);
}

.star-input.active {
    color: #f59e0b;
}

.star-input.active svg {
    fill: currentColor;
}

.star-input:hover,
.star-input.hover {
    color: #f59e0b;
}

/* Detail Ratings Section */
.detail-ratings-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    background: var(--gray-50);
    border-radius: 8px;
    cursor: pointer;
    margin-bottom: 16px;
    font-size: 14px;
    color: var(--gray-600);
    transition: background 0.2s ease;
}

.detail-ratings-toggle:hover {
    background: var(--gray-100);
}

.detail-ratings-toggle svg {
    transition: transform 0.2s ease;
}

.detail-ratings-toggle.open svg {
    transform: rotate(180deg);
}

.detail-ratings-section {
    background: var(--gray-50);
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 16px;
}

.detail-rating-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid var(--gray-200);
}

.detail-rating-row:last-child {
    border-bottom: none;
}

.detail-rating-label {
    font-size: 13px;
    color: var(--gray-700);
    flex: 1;
}

.detail-star-rating {
    display: flex;
    gap: 2px;
}

.detail-star {
    font-size: 26px;
    color: var(--gray-300);
    cursor: pointer;
    transition: color 0.15s ease, transform 0.15s ease;
}

.detail-star:hover {
    transform: scale(1.2);
}

.detail-star.active {
    color: #f59e0b;
}

.detail-star.hover {
    color: #fbbf24;
}

/* Booking Modal Styles */
.booking-modal .modal-dialog {
    max-height: 90vh;
    display: flex;
    flex-direction: column;
}

.booking-modal .modal-header {
    flex-shrink: 0;
}

.booking-modal .modal-header .modal-title {
    display: flex;
    align-items: center;
    gap: 10px;
}

.booking-modal .modal-body {
    flex: 1;
    overflow-y: auto;
}

.booking-modal .modal-close-btn {
    background: none;
    border: none;
    font-size: 28px;
    cursor: pointer;
    color: var(--gray-500);
    line-height: 1;
}

.booking-steps {
    display: flex;
    justify-content: space-between;
    padding: 20px 24px;
    background: var(--gray-50);
    border-bottom: 1px solid var(--gray-200);
}

.booking-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    flex: 1;
    position: relative;
}

.booking-step::after {
    content: '';
    position: absolute;
    top: 14px;
    left: 60%;
    width: 80%;
    height: 2px;
    background: var(--gray-200);
}

.booking-step:last-child::after {
    display: none;
}

.booking-step .step-number {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--gray-200);
    color: var(--gray-500);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 13px;
    position: relative;
    z-index: 1;
    transition: all 0.3s ease;
}

.booking-step .step-label {
    font-size: 12px;
    color: var(--gray-500);
    font-weight: 500;
}

.booking-step.active .step-number {
    background: var(--primary-500);
    color: white;
}

.booking-step.active .step-label {
    color: var(--primary-600);
    font-weight: 600;
}

.booking-step.completed .step-number {
    background: var(--success-500);
    color: white;
}

.booking-step.completed::after {
    background: var(--success-500);
}

.booking-step-content {
    display: none;
    padding: 24px;
}

.booking-step-content.active {
    display: block;
}

.step-content-inner {
    max-width: 100%;
}

.step-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--gray-800);
    margin-bottom: 20px;
}

/* Appointment Type Cards */
.appointment-type-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.appointment-type-card {
    cursor: pointer;
}

.appointment-type-card input {
    display: none;
}

.type-card-inner {
    padding: 24px;
    border: 2px solid var(--gray-200);
    border-radius: 12px;
    text-align: center;
    transition: all 0.2s ease;
}

.appointment-type-card input:checked + .type-card-inner {
    border-color: var(--primary-500);
    background: var(--primary-50);
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.1);
}

.appointment-type-card:hover .type-card-inner {
    border-color: var(--primary-300);
}

.type-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--gray-100);
    border-radius: 50%;
    color: var(--primary-500);
}

.type-icon.online {
    background: linear-gradient(135deg, #dbeafe, #e0e7ff);
    color: var(--primary-600);
}

.type-card-inner h6 {
    font-size: 16px;
    font-weight: 600;
    color: var(--gray-800);
    margin: 0 0 8px;
}

.type-card-inner p {
    font-size: 13px;
    color: var(--gray-500);
    margin: 0 0 12px;
}

.type-price {
    display: inline-block;
    padding: 6px 16px;
    background: var(--gray-100);
    border-radius: 20px;
    font-weight: 600;
    color: var(--gray-700);
}

.type-price.free {
    background: var(--success-100);
    color: var(--success-700);
}

/* Calendar Styles */
.datetime-picker-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

.calendar-section {
    background: var(--gray-50);
    border-radius: 12px;
    padding: 16px;
}

.calendar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.calendar-month-label {
    font-weight: 600;
    color: var(--gray-800);
}

.calendar-nav {
    background: white;
    border: 1px solid var(--gray-200);
    border-radius: 8px;
    padding: 6px;
    cursor: pointer;
    color: var(--gray-600);
}

.calendar-nav:hover {
    background: var(--gray-100);
}

.calendar-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
    margin-bottom: 8px;
}

.calendar-weekdays span {
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    color: var(--gray-500);
    padding: 8px 0;
}

.calendar-days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
}

.calendar-day {
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.2s ease;
    background: white;
    border: 1px solid transparent;
}

.calendar-day:hover:not(.disabled):not(.selected) {
    background: var(--primary-50);
    border-color: var(--primary-200);
}

.calendar-day.disabled {
    color: var(--gray-300);
    cursor: not-allowed;
    background: transparent;
}

.calendar-day.today {
    border-color: var(--primary-500);
    font-weight: 600;
}

.calendar-day.selected {
    background: var(--primary-500);
    color: white;
    font-weight: 600;
}

.calendar-day.other-month {
    color: var(--gray-400);
}

/* Time Slots */
.time-slots-section {
    background: var(--gray-50);
    border-radius: 12px;
    padding: 16px;
}

.time-slots-header {
    font-weight: 600;
    color: var(--gray-800);
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--gray-200);
}

.time-slots-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    max-height: 280px;
    overflow-y: auto;
}

.time-slot {
    padding: 10px 12px;
    background: white;
    border: 1px solid var(--gray-200);
    border-radius: 8px;
    text-align: center;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.2s ease;
}

.time-slot:hover {
    border-color: var(--primary-300);
    background: var(--primary-50);
}

.time-slot.selected {
    background: var(--primary-500);
    border-color: var(--primary-500);
    color: white;
}

.no-slots-message {
    grid-column: 1 / -1;
    text-align: center;
    color: var(--gray-500);
    padding: 40px 20px;
}

/* Booking Form */
.booking-form {
    max-width: 480px;
}

.booking-form .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.booking-user-info {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    background: var(--gray-50);
    border-radius: 12px;
    margin-bottom: 20px;
}

.booking-user-info img {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
}

.booking-user-info div {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.booking-user-info strong {
    font-size: 15px;
    color: var(--gray-800);
}

.booking-user-info span {
    font-size: 13px;
    color: var(--gray-500);
}

/* Booking Summary */
.booking-summary {
    max-width: 480px;
}

.summary-card {
    background: var(--gray-50);
    border-radius: 12px;
    padding: 20px;
    margin-bottom: 20px;
}

.summary-lawyer {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--gray-200);
    margin-bottom: 16px;
}

.summary-lawyer img {
    width: 56px;
    height: 56px;
    border-radius: 12px;
    object-fit: cover;
}

.summary-lawyer div {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.summary-lawyer strong {
    font-size: 16px;
    color: var(--gray-800);
}

.summary-lawyer span {
    font-size: 13px;
    color: var(--gray-500);
}

.summary-details {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.summary-label {
    font-size: 14px;
    color: var(--gray-500);
}

.summary-value {
    font-size: 14px;
    font-weight: 600;
    color: var(--gray-800);
}

.summary-price {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 16px;
    border-top: 1px solid var(--gray-200);
    margin-top: 16px;
}

.price-label {
    font-size: 15px;
    font-weight: 600;
    color: var(--gray-700);
}

.price-value {
    font-size: 24px;
    font-weight: 700;
    color: var(--primary-600);
}

.booking-terms {
    padding: 16px;
    background: var(--warning-50);
    border-radius: 12px;
    border: 1px solid var(--warning-200);
}

.booking-terms .checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 13px;
    color: var(--gray-600);
    cursor: pointer;
}

.booking-terms input[type="checkbox"] {
    margin-top: 2px;
}

.booking-terms a {
    color: var(--primary-600);
}

/* Booking Footer */
.booking-footer {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    border-top: 1px solid var(--gray-200);
    padding: 16px 24px;
}

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

/* Responsive */
@media (max-width: 768px) {
    .appointment-type-grid {
        grid-template-columns: 1fr;
    }

    .datetime-picker-grid {
        grid-template-columns: 1fr;
    }

    .time-slots-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .booking-form .form-row {
        grid-template-columns: 1fr;
    }

    .booking-steps {
        padding: 16px;
    }

    .booking-step .step-label {
        display: none;
    }
}

/* Appointment Payment Modal */
.appt-payment-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
}
.appt-payment-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.6);
    backdrop-filter: blur(4px);
}
.appt-payment-content {
    position: relative;
    background: white;
    border-radius: 16px;
    width: 90%;
    max-width: 480px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 25px 60px rgba(0,0,0,0.3);
    animation: apptPaySlideUp 0.3s ease;
}
@keyframes apptPaySlideUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}
.appt-payment-close {
    position: absolute;
    top: 16px;
    right: 16px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--gray-400);
    padding: 4px;
    border-radius: 8px;
    transition: all 0.2s;
    z-index: 1;
}
.appt-payment-close:hover {
    background: var(--gray-100);
    color: var(--gray-700);
}
.appt-payment-header {
    padding: 24px 24px 16px;
    border-bottom: 1px solid var(--gray-200);
}
.appt-payment-header h3 {
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 4px;
    color: var(--gray-900);
}
.appt-payment-header p {
    font-size: 14px;
    color: var(--gray-500);
    margin: 0;
}
.appt-payment-body {
    padding: 24px;
}
.appt-payment-summary {
    background: var(--gray-50);
    border: 1px solid var(--gray-200);
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 20px;
}
.appt-summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    font-size: 14px;
    color: var(--gray-600);
}
.appt-summary-row + .appt-summary-row {
    border-top: 1px solid var(--gray-200);
}
.appt-summary-row span:last-child {
    font-weight: 600;
    color: var(--gray-900);
}
.appt-summary-total {
    font-size: 16px;
}
.appt-summary-total span:last-child {
    color: var(--primary-600);
    font-size: 18px;
}
.appt-stripe-element {
    padding: 16px;
    border: 1px solid var(--gray-300);
    border-radius: 10px;
    margin-bottom: 16px;
    min-height: 60px;
    transition: border-color 0.2s;
}
.appt-stripe-element:focus-within {
    border-color: var(--primary-500);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}
.appt-payment-error {
    background: #fef2f2;
    border: 1px solid #fca5a5;
    color: #dc2626;
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 14px;
    margin-bottom: 16px;
}
.appt-btn-pay {
    width: 100%;
    padding: 14px 24px;
    background: var(--primary-600);
    color: white;
    border: none;
    border-radius: 10px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: all 0.2s;
}
.appt-btn-pay:hover:not(:disabled) {
    background: var(--primary-700);
}
.appt-btn-pay:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}
.appt-payment-secure {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: 16px;
    font-size: 12px;
    color: var(--gray-500);
}
.appt-payment-secure svg {
    color: var(--success-500);
}
                /* === Standart contact-cta-card (show-unclaimed.php ile birebir aynı stil) === */
                .contact-cta-card {
                    background: #fff;
                    border: 1px solid var(--gray-200, #e5e7eb);
                    border-radius: 12px;
                    overflow: hidden;
                    box-shadow: 0 1px 3px rgba(15,23,42,0.05);
                }
                .contact-cta-banner {
                    display: flex; align-items: center; gap: 10px;
                    padding: 10px 14px;
                    background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
                    color: #047857;
                    border-bottom: 1px solid #bbf7d0;
                    font-size: 12px;
                    line-height: 1.4;
                }
                .contact-cta-banner i { font-size: 16px; color: #059669; flex-shrink: 0; }
                .contact-cta-banner-text { display: flex; flex-direction: column; gap: 1px; }
                .contact-cta-banner-text strong { color: #064e3b; font-weight: 700; font-size: 12.5px; letter-spacing: 0.01em; }
                .contact-cta-banner-text span { color: #047857; font-size: 11.5px; }

                .contact-cta-call-number-mix {
                    font-size: 17px; font-weight: 700; color: #fff;
                    letter-spacing: 0.04em;
                    font-variant-numeric: tabular-nums;
                    display: inline-flex; align-items: baseline; gap: 6px;
                }
                .contact-cta-call-number-mix .visible-part { color: #fff; }
                .contact-cta-call-number-mix .blur-part {
                    filter: blur(3px); user-select: none;
                    color: rgba(255,255,255,0.85); letter-spacing: 0.1em;
                }
                .contact-cta-call-lock-pill {
                    width: 30px; height: 30px;
                    background: rgba(255,255,255,0.18);
                    border-radius: 50%;
                    display: flex; align-items: center; justify-content: center;
                    color: #fbbf24; font-size: 12px; flex-shrink: 0;
                }
                .contact-cta-unlock-btn {
                    display: flex; align-items: center; justify-content: center; gap: 8px;
                    padding: 11px 14px;
                    background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
                    color: #78350f; font-size: 12.5px; font-weight: 700;
                    text-decoration: none; border: none; cursor: pointer;
                    font-family: inherit; transition: filter 0.15s ease;
                    text-align: center; letter-spacing: 0.01em; width: 100%;
                }
                .contact-cta-unlock-btn:hover { filter: brightness(1.08); }
                .contact-cta-unlock-btn i { font-size: 13px; }
                .contact-cta-call {
                    display: flex; align-items: center; gap: 14px;
                    padding: 16px 18px;
                    background: linear-gradient(135deg, #1e3a5f 0%, #2c5282 100%);
                    color: #fff; text-decoration: none;
                    transition: filter 0.15s ease, transform 0.1s ease;
                    border: none; width: 100%; cursor: pointer;
                    font-family: inherit; text-align: left;
                }
                .contact-cta-call:hover { filter: brightness(1.08); }
                .contact-cta-call:active { transform: translateY(1px); }
                .contact-cta-call-icon {
                    width: 42px; height: 42px;
                    background: rgba(255,255,255,0.15);
                    border-radius: 10px;
                    display: flex; align-items: center; justify-content: center;
                    font-size: 18px; flex-shrink: 0;
                }
                .contact-cta-call-text { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
                .contact-cta-call-label {
                    font-size: 10.5px; letter-spacing: 0.12em;
                    color: rgba(255,255,255,0.78); font-weight: 600;
                }
                .contact-cta-call-number {
                    font-size: 17px; font-weight: 700; color: #fff;
                    letter-spacing: 0.03em; font-variant-numeric: tabular-nums;
                }
                .contact-cta-call-arrow { color: rgba(255,255,255,0.6); font-size: 13px; flex-shrink: 0; }
                .contact-cta-call-locked .contact-cta-call-icon { background: rgba(255,255,255,0.1); }

                .contact-cta-row {
                    display: flex; align-items: flex-start; gap: 12px;
                    padding: 14px 18px;
                    border-top: 1px solid var(--gray-100, #f1f5f9);
                    text-decoration: none; color: inherit;
                    transition: background 0.12s ease;
                }
                .contact-cta-row-link:hover { background: var(--gray-50, #f9fafb); }
                .contact-cta-row-icon {
                    width: 32px; height: 32px;
                    background: var(--gray-100, #f1f5f9);
                    border-radius: 8px;
                    display: flex; align-items: center; justify-content: center;
                    color: var(--gray-600, #4b5563);
                    font-size: 13px; flex-shrink: 0; margin-top: 2px;
                }
                .contact-cta-row-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
                .contact-cta-row-label {
                    font-size: 10.5px; letter-spacing: 0.1em;
                    color: var(--gray-500, #6b7280); font-weight: 600;
                }
                .contact-cta-row-value {
                    font-size: 13.5px; font-weight: 600;
                    color: var(--gray-900, #111827);
                    line-height: 1.45; word-break: break-word;
                }
                .contact-cta-row-value .visible-part { color: var(--gray-900, #111827); font-weight: 700; }
                .contact-cta-row-value .blur-part {
                    filter: blur(4px); user-select: none;
                    color: var(--gray-500, #6b7280); letter-spacing: 0.06em;
                }
                .contact-cta-row-value .address-sep {
                    color: var(--gray-400, #9ca3af); margin: 0 4px; font-weight: 400;
                }
                .contact-cta-row-unlock {
                    background: none; border: none; padding: 0; margin-top: 6px;
                    color: var(--primary-600, #1e40af);
                    font-size: 12.5px; font-weight: 600;
                    cursor: pointer; font-family: inherit;
                    text-decoration: underline; align-self: flex-start;
                }
                .contact-cta-row-arrow { color: var(--gray-400, #9ca3af); font-size: 12px; flex-shrink: 0; margin-top: 6px; }

                .contact-cta-map { border-top: 1px solid var(--gray-100, #f1f5f9); position: relative; }
                .contact-cta-map iframe { width: 100%; height: 170px; border: 0; display: block; }
                .contact-cta-map-direction {
                    position: absolute; top: 10px; left: 10px;
                    background: #fff; color: var(--primary-600, #2563eb);
                    padding: 6px 11px; border-radius: 6px;
                    font-size: 11.5px; font-weight: 600;
                    text-decoration: none; display: inline-flex; align-items: center; gap: 5px;
                    box-shadow: 0 2px 6px rgba(0,0,0,0.15);
                }

                /* === Sosyal Medya — marka renkli icon butonlari === */
                .contact-cta-social {
                    padding: 14px 18px;
                    border-top: 1px solid var(--gray-100, #f1f5f9);
                }
                .contact-cta-social-label {
                    font-size: 10.5px;
                    letter-spacing: 0.1em;
                    color: var(--gray-500, #6b7280);
                    font-weight: 600;
                    margin-bottom: 10px;
                }
                .contact-cta-social-grid {
                    display: flex;
                    flex-wrap: wrap;
                    gap: 8px;
                }
                .contact-cta-social-btn {
                    width: 38px; height: 38px;
                    border-radius: 10px;
                    display: inline-flex;
                    align-items: center;
                    justify-content: center;
                    color: #fff;
                    font-size: 15px;
                    text-decoration: none;
                    transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
                    position: relative;
                    isolation: isolate;
                }
                .contact-cta-social-btn:hover {
                    transform: translateY(-2px) scale(1.06);
                    filter: brightness(1.06);
                    color: #fff;
                }
                .contact-cta-social-btn::after {
                    content: '';
                    position: absolute;
                    inset: 0;
                    border-radius: inherit;
                    box-shadow: inset 0 1px 0 rgba(255,255,255,0.20);
                    z-index: -1;
                    pointer-events: none;
                }
                /* Marka renkleri */
                .contact-cta-social-btn.sm-linkedin  { background: #0a66c2; box-shadow: 0 3px 8px rgba(10, 102, 194, 0.30); }
                .contact-cta-social-btn.sm-twitter   { background: #000;    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.30); }
                .contact-cta-social-btn.sm-instagram { background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%); box-shadow: 0 3px 8px rgba(220, 39, 67, 0.30); }
                .contact-cta-social-btn.sm-facebook  { background: #1877f2; box-shadow: 0 3px 8px rgba(24, 119, 242, 0.30); }
                .contact-cta-social-btn.sm-youtube   { background: #ff0000; box-shadow: 0 3px 8px rgba(255, 0, 0, 0.30); }
                .contact-cta-social-btn.sm-tiktok    { background: linear-gradient(135deg, #25f4ee 0%, #000 50%, #fe2c55 100%); box-shadow: 0 3px 8px rgba(254, 44, 85, 0.30); }

                /* Anonim için locked CTA */
                .contact-cta-social-locked-btn {
                    display: flex; align-items: center; justify-content: center; gap: 8px;
                    width: 100%;
                    padding: 10px 12px;
                    background: linear-gradient(135deg, #f5f3ff 0%, #ede9fe 100%);
                    color: #6d28d9;
                    border: 1px solid #ddd6fe;
                    border-radius: 8px;
                    font-size: 12px;
                    font-weight: 600;
                    cursor: pointer;
                    font-family: inherit;
                    text-align: center;
                    transition: all 0.15s ease;
                }
                .contact-cta-social-locked-btn:hover {
                    background: linear-gradient(135deg, #ede9fe 0%, #ddd6fe 100%);
                    border-color: #c4b5fd;
                }
                .contact-cta-social-locked-btn i { font-size: 11px; }
                .service-options-header { text-align:center; margin-bottom:20px; }
                .service-options-grid {
                    display:grid;
                    grid-template-columns: repeat(2, 1fr);
                    gap:20px;
                }
                @media (max-width: 768px) {
                    .service-options-grid { grid-template-columns: 1fr; gap:14px; }
                }

                /* Platform Güvenceli Online Danışmanlık Banner */
                .online-trust-banner {
                    display:flex;
                    gap:20px;
                    align-items:flex-start;
                    background:linear-gradient(135deg,#f5f9ff 0%,#eef4fc 100%);
                    border:1px solid #dbe7f7;
                    border-left:5px solid #1e3a5f;
                    border-radius:14px;
                    padding:22px 24px;
                    margin-bottom:22px;
                    position:relative;
                }
                .online-trust-banner::after {
                    content:"";
                    position:absolute;
                    top:14px;
                    right:14px;
                    width:42px;
                    height:42px;
                    background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23d4a84b' opacity='.18'><path d='M12 2l3 6.6 7 .9-5.1 5 1.3 7-6.2-3.3-6.2 3.3 1.3-7L2 9.5l7-.9z'/></svg>") no-repeat center;
                    background-size:contain;
                    pointer-events:none;
                }
                .online-trust-shield {
                    flex-shrink:0;
                    width:56px;
                    height:56px;
                    border-radius:14px;
                    background:linear-gradient(135deg,#1a365d 0%,#2c5282 100%);
                    color:#d4a84b;
                    display:flex;
                    align-items:center;
                    justify-content:center;
                    box-shadow:0 6px 14px rgba(26,54,93,0.2);
                }
                .online-trust-body { flex:1; min-width:0; }
                .online-trust-eyebrow {
                    font-size:11px;
                    font-weight:800;
                    letter-spacing:1.5px;
                    text-transform:uppercase;
                    color:#1a365d;
                    margin-bottom:6px;
                }
                .online-trust-title {
                    font-size:16.5px;
                    font-weight:700;
                    color:#0f1a2b;
                    margin:0 0 10px;
                    line-height:1.4;
                    letter-spacing:-0.1px;
                }
                .online-trust-desc {
                    font-size:13.5px;
                    color:#334155;
                    line-height:1.65;
                    margin:0 0 14px;
                }
                .online-trust-desc strong { color:#0f1a2b; font-weight:700; }
                .online-trust-features {
                    list-style:none;
                    padding:0;
                    margin:0;
                    display:grid;
                    grid-template-columns:repeat(2,1fr);
                    gap:8px 18px;
                }
                .online-trust-features li {
                    display:flex;
                    align-items:flex-start;
                    gap:9px;
                    font-size:12.5px;
                    color:#1f2937;
                    line-height:1.5;
                }
                .online-trust-features li i {
                    color:#1a365d;
                    font-size:13px;
                    margin-top:3px;
                    flex-shrink:0;
                }
                .online-trust-features li strong { color:#0f1a2b; font-weight:700; }
                .online-trust-disclaimer {
                    margin:14px 0 0;
                    padding:10px 12px;
                    background:#ffffff;
                    border:1px dashed #cbd5e1;
                    border-radius:8px;
                    font-size:11.5px;
                    color:#475569;
                    line-height:1.55;
                }
                .online-trust-disclaimer strong { color:#0f1a2b; font-weight:700; }
                .online-trust-disclaimer a {
                    color:#1a365d;
                    font-weight:600;
                    text-decoration:underline;
                    text-decoration-color:#94a3b8;
                    text-underline-offset:2px;
                }
                .online-trust-disclaimer a:hover { color:#0f1a2b; text-decoration-color:#1a365d; }

                /* Booking modal — Misafir KVKK rıza kutusu */
                .booking-kvkk-box {
                    margin-top:14px;
                    padding:14px 16px;
                    background:#f8fafc;
                    border:1px solid #cbd5e1;
                    border-radius:10px;
                }
                .booking-kvkk-label {
                    display:flex;
                    align-items:flex-start;
                    gap:10px;
                    font-size:13px;
                    color:#0f172a;
                    line-height:1.55;
                    cursor:pointer;
                    margin-bottom:10px;
                }
                .booking-kvkk-label input[type="checkbox"] {
                    margin-top:3px;
                    flex-shrink:0;
                    width:18px;
                    height:18px;
                    accent-color:#1a365d;
                    cursor:pointer;
                }
                .booking-kvkk-label strong { color:#0f172a; font-weight:700; }
                .booking-kvkk-info {
                    display:flex;
                    gap:9px;
                    align-items:flex-start;
                    background:#eff6ff;
                    border-left:3px solid #2c5282;
                    padding:10px 12px;
                    border-radius:0 8px 8px 0;
                    font-size:12.5px;
                    color:#1e3a5f;
                    line-height:1.55;
                }
                .booking-kvkk-info i { color:#1a365d; font-size:14px; margin-top:1px; flex-shrink:0; }
                .booking-kvkk-info strong { color:#0f1a2b; font-weight:700; }

                /* Randevu Al kartında butonun ÜSTÜNDEKİ "Nasıl alınır?" rehber linki
                   margin-top:auto → howto + button bloğu kartın altına yapışır,
                   böylece sol-sağ kart butonları aynı hizada kalır */
                .service-card-howto {
                    display:flex;
                    align-items:center;
                    justify-content:center;
                    gap:8px;
                    margin-top:auto;
                    margin-bottom:10px;
                    padding:8px 12px;
                    color:#475569;
                    font-size:12.5px;
                    text-decoration:none;
                    border-radius:8px;
                    transition:background .15s, color .15s;
                }
                .service-card-howto:hover {
                    background:#f1f5f9;
                    color:#1a365d;
                }
                .service-card-howto i { font-size:14px; color:#1a365d; }
                .service-card-howto strong { color:#0f172a; font-weight:700; }
                /* Howto link button'dan önce ise button'un margin'ini sıfırla;
                   böylece howto + button bloğu birlikte alta yapışır */
                .service-card-howto + .service-card-btn { margin-top:0; }

                @media (max-width:680px) {
                    .online-trust-banner { flex-direction:column; gap:14px; padding:18px 18px; }
                    .online-trust-shield { width:48px; height:48px; }
                    .online-trust-banner::after { display:none; }
                    .online-trust-title { font-size:15.5px; }
                    .online-trust-features { grid-template-columns:1fr; gap:7px; }
                    .online-trust-disclaimer { font-size:11px; padding:8px 10px; }
                }
                .service-card {
                    background:#fff;
                    border-radius:16px;
                    padding:24px;
                    border:1px solid var(--gray-200,#e5e7eb);
                    box-shadow:0 1px 3px rgba(0,0,0,0.04);
                    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
                    display:flex;
                    flex-direction:column;
                    position:relative;
                    overflow:hidden;
                }
                .service-card::before {
                    content:'';
                    position:absolute;
                    top:0; left:0; right:0;
                    height:4px;
                    border-radius:16px 16px 0 0;
                }
                .service-card-ask::before { background: linear-gradient(90deg,#0891b2,#06b6d4); }
                .service-card-appt::before { background: linear-gradient(90deg,#1a365d,#2c5282); }
                .service-card:hover {
                    transform: translateY(-3px);
                    box-shadow:0 10px 24px rgba(0,0,0,0.10);
                    border-color: var(--gray-300,#d1d5db);
                }
                .service-card-head {
                    display:flex;
                    align-items:center;
                    gap:14px;
                    margin-bottom:14px;
                }
                .service-card-icon {
                    width:48px; height:48px;
                    border-radius:12px;
                    display:flex; align-items:center; justify-content:center;
                    font-size:20px;
                    color:#fff;
                    flex-shrink:0;
                }
                .service-card-ask .service-card-icon { background: linear-gradient(135deg,#0891b2,#06b6d4); }
                .service-card-appt .service-card-icon { background: linear-gradient(135deg,#1a365d,#2c5282); }
                .service-card-title {
                    margin:0;
                    font-size:18px;
                    font-weight:700;
                    color:var(--gray-900,#111827);
                    line-height:1.2;
                }
                .service-card-desc {
                    margin:0 0 16px;
                    font-size:14px;
                    line-height:1.6;
                    color:var(--gray-600,#4b5563);
                    flex:1;
                }
                .service-card-features {
                    list-style:none;
                    padding:0;
                    margin:0 0 18px;
                }
                .service-card-features li {
                    padding:6px 0;
                    font-size:13px;
                    color:var(--gray-700,#374151);
                    display:flex;
                    align-items:center;
                    gap:8px;
                }
                .service-card-features li i {
                    font-size:11px;
                    width:16px; height:16px;
                    border-radius:50%;
                    display:inline-flex; align-items:center; justify-content:center;
                    color:#fff;
                    flex-shrink:0;
                }
                .service-card-ask .service-card-features li i { background:#06b6d4; }
                .service-card-appt .service-card-features li i { background:#2c5282; }
                .service-card-btn {
                    display:inline-flex;
                    align-items:center;
                    justify-content:center;
                    gap:8px;
                    padding:12px 20px;
                    border-radius:10px;
                    font-weight:600;
                    font-size:14px;
                    text-decoration:none;
                    color:#fff;
                    transition: filter .15s ease, transform .15s ease;
                    border:none;
                    cursor:pointer;
                    margin-top:auto; /* Her iki kartta da butonu kart altına sabitler */
                }
                .service-card-ask .service-card-btn { background: linear-gradient(135deg,#0891b2,#06b6d4); }
                .service-card-appt .service-card-btn { background: linear-gradient(135deg,#1a365d,#2c5282); }
                .service-card-btn:hover { filter: brightness(1.1); transform: translateY(-1px); }
                .service-card-btn i { font-size:12px; }
                .seo-editorial-wrapper {
                    margin: 32px 0;
                    display: flex;
                    flex-direction: column;
                    gap: 28px;
                }
                .seo-block {
                    background: #ffffff;
                    border: 1px solid #e2e8f0;
                    border-radius: 14px;
                    padding: 28px 32px;
                    box-shadow: 0 2px 8px rgba(15,23,42,0.03);
                }
                .seo-eyebrow {
                    font-size: 11px;
                    font-weight: 800;
                    letter-spacing: 1.5px;
                    text-transform: uppercase;
                    color: #1a365d;
                    margin-bottom: 8px;
                }
                .seo-h2 {
                    font-family: 'Playfair Display', Georgia, serif;
                    font-size: 22px;
                    color: #0f172a;
                    font-weight: 800;
                    letter-spacing: -0.3px;
                    margin: 0 0 18px;
                    line-height: 1.3;
                }
                .seo-h3 {
                    font-family: 'Playfair Display', Georgia, serif;
                    font-size: 17px;
                    color: #1a365d;
                    font-weight: 700;
                    margin: 22px 0 10px;
                    letter-spacing: -0.2px;
                }
                .seo-body p {
                    font-size: 14.5px;
                    color: #334155;
                    line-height: 1.75;
                    margin: 0 0 12px;
                }
                .seo-body p:last-child { margin-bottom: 0; }
                .seo-body p strong { color: #0f172a; font-weight: 700; }
                .seo-body p em {
                    font-style: normal;
                    background: #fef3c7;
                    padding: 1px 5px;
                    border-radius: 3px;
                    color: #78350f;
                    font-size: 13.5px;
                    font-weight: 600;
                }
                .seo-steps {
                    counter-reset: seo-step;
                    list-style: none;
                    padding: 0;
                    margin: 14px 0 0;
                }
                .seo-steps li {
                    padding: 12px 0 12px 0;
                    border-bottom: 1px solid #f1f5f9;
                    font-size: 14px;
                    color: #334155;
                    line-height: 1.65;
                }
                .seo-steps li:last-child { border-bottom: none; padding-bottom: 0; }
                .seo-steps li strong { color: #0f172a; font-weight: 700; display: block; margin-bottom: 4px; }
                .seo-qa {
                    padding: 14px 0;
                    border-bottom: 1px solid #f1f5f9;
                }
                .seo-qa:last-child { border-bottom: none; padding-bottom: 0; }
                .seo-q {
                    display: flex;
                    gap: 10px;
                    font-weight: 700;
                    color: #0f172a;
                    font-size: 14.5px;
                    line-height: 1.55;
                    margin-bottom: 8px;
                }
                .seo-q::before {
                    content: '?';
                    flex-shrink: 0;
                    width: 24px;
                    height: 24px;
                    border-radius: 50%;
                    background: linear-gradient(135deg, #d4a84b, #b8862c);
                    color: #ffffff;
                    text-align: center;
                    line-height: 24px;
                    font-family: 'Playfair Display', Georgia, serif;
                    font-size: 14px;
                    font-weight: 900;
                }
                .seo-a {
                    color: #475569;
                    font-size: 14px;
                    line-height: 1.7;
                    padding-left: 34px;
                }
                .seo-a strong, .seo-a em {
                    color: #0f172a;
                    font-weight: 700;
                    font-style: normal;
                }
                @media (max-width: 680px) {
                    .seo-block { padding: 20px 18px; }
                    .seo-h2 { font-size: 19px; }
                    .seo-h3 { font-size: 15.5px; }
                    .seo-body p { font-size: 13.5px; }
                }

                /* AI Quick Facts kartı — Google AI Overview, Perplexity, ChatGPT Search için optimize */
                .ai-quickfacts {
                    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
                    border: 1px solid #cbd5e1;
                    border-radius: 14px;
                    padding: 26px 30px;
                    margin: 32px 0 28px;
                    box-shadow: 0 4px 16px rgba(15,23,42,0.05);
                    position: relative;
                }
                .ai-quickfacts::before {
                    content: '';
                    position: absolute;
                    top: 0; left: 0;
                    width: 4px; height: 100%;
                    background: linear-gradient(180deg, #d4a84b, #1a365d);
                    border-radius: 14px 0 0 14px;
                }
                .ai-quickfacts-head { margin-bottom: 18px; }
                .ai-quickfacts-eyebrow {
                    display: inline-flex;
                    align-items: center;
                    gap: 6px;
                    font-size: 11px;
                    font-weight: 800;
                    letter-spacing: 1.5px;
                    text-transform: uppercase;
                    color: #1a365d;
                    background: rgba(212,168,75,0.12);
                    padding: 5px 11px;
                    border-radius: 14px;
                    margin-bottom: 12px;
                }
                .ai-quickfacts-eyebrow i { color: #b8862c; font-size: 11px; }
                .ai-quickfacts-title {
                    font-family: 'Playfair Display', Georgia, serif;
                    font-size: 21px;
                    color: #0f172a;
                    font-weight: 800;
                    letter-spacing: -0.3px;
                    margin: 0 0 10px;
                    line-height: 1.3;
                }
                .ai-quickfacts-summary {
                    font-size: 14.5px;
                    color: #334155;
                    line-height: 1.7;
                    margin: 0;
                }
                .ai-quickfacts-summary strong { color: #0f172a; font-weight: 700; }
                .ai-quickfacts-list {
                    display: grid;
                    grid-template-columns: repeat(2, minmax(0, 1fr));
                    gap: 10px 28px;
                    margin: 18px 0 0;
                    padding: 18px 0 0;
                    border-top: 1px solid #e2e8f0;
                }
                .ai-quickfacts-list dt {
                    display: flex;
                    align-items: center;
                    gap: 7px;
                    font-size: 11px;
                    font-weight: 700;
                    color: #64748b;
                    letter-spacing: 0.5px;
                    text-transform: uppercase;
                    grid-column: 1;
                    align-self: center;
                }
                .ai-quickfacts-list dt i { color: #1a365d; font-size: 12px; width: 16px; text-align: center; }
                .ai-quickfacts-list dd {
                    font-size: 14px;
                    color: #0f172a;
                    font-weight: 600;
                    margin: 0;
                    grid-column: 2;
                    align-self: center;
                }
                @media (max-width: 680px) {
                    .ai-quickfacts-list { grid-template-columns: 1fr; gap: 6px; }
                    .ai-quickfacts-list dt { grid-column: 1; }
                    .ai-quickfacts-list dd {
                        grid-column: 1;
                        padding-left: 23px;
                        margin-bottom: 8px;
                    }
                }
                .ai-quickfacts-foot {
                    margin-top: 18px;
                    padding-top: 16px;
                    border-top: 1px solid #e2e8f0;
                }
                .ai-quickfacts-source {
                    display: flex;
                    gap: 9px;
                    align-items: flex-start;
                    font-size: 12.5px;
                    color: #475569;
                    line-height: 1.55;
                    background: #fffbeb;
                    border-left: 3px solid #f59e0b;
                    padding: 10px 12px;
                    border-radius: 0 8px 8px 0;
                }
                .ai-quickfacts-source i { color: #b45309; font-size: 14px; margin-top: 2px; flex-shrink: 0; }
                .ai-quickfacts-source strong { color: #78350f; font-weight: 700; }
                .ai-quickfacts-hint {
                    font-size: 11.5px;
                    color: #94a3b8;
                    margin: 10px 0 0;
                    font-style: italic;
                    line-height: 1.55;
                }
                .ai-quickfacts-time {
                    display: block;
                    margin-top: 6px;
                    font-size: 11px;
                    color: #94a3b8;
                    letter-spacing: 0.3px;
                }
.city-resources-card {
    border: 1px solid var(--gray-200);
}
.city-resources-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.city-resources-list li {
    border-bottom: 1px solid var(--gray-100);
}
.city-resources-list li:last-child {
    border-bottom: none;
}
.city-resources-list li a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    color: var(--gray-700);
    text-decoration: none;
    font-size: 0.875rem;
    transition: all 0.2s;
}
.city-resources-list li a:hover {
    background: var(--gray-50);
    color: var(--primary-600);
}
.city-resources-list li a i {
    color: var(--gray-400);
    width: 16px;
    text-align: center;
    font-size: 0.8rem;
}
.city-resources-list li a:hover i {
    color: var(--primary-500);
}
.city-resources-list li.section-header {
    padding: 8px 16px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--gray-500);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: var(--gray-50);
    display: flex;
    align-items: center;
    gap: 8px;
    border-bottom: none;
    margin-bottom: 0;
}
.city-resources-list li.section-header i {
    color: var(--primary-500);
}
.city-resources-list li.view-all a {
    color: var(--primary-600);
    font-weight: 500;
    justify-content: space-between;
}
.city-resources-list li.view-all a i {
    color: var(--primary-500);
}

/* İlgili İçtihat Kararları */
.related-ictihat-list { padding: 0; }
.related-ictihat-item {
    display: block;
    padding: 12px 16px;
    border-bottom: 1px solid var(--gray-100);
    text-decoration: none;
    color: var(--gray-700);
    transition: background 0.2s;
}
.related-ictihat-item:last-child { border-bottom: none; }
.related-ictihat-item:hover { background: var(--gray-50); }
.ri-mahkeme { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; }
.ri-badge {
    font-size: 10px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 4px;
    background: var(--primary-50, #eff6ff);
    color: var(--primary-600, #2563eb);
}
.ri-alan {
    font-size: 10px;
    padding: 2px 6px;
    border-radius: 4px;
    background: #f0fdf4;
    color: #16a34a;
}
.ri-info {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--gray-500);
    margin-bottom: 4px;
}
.ri-birim { font-weight: 500; color: var(--gray-700); }
.ri-no { font-family: monospace; }
.ri-tarih { font-size: 11px; }
.ri-ozet { font-size: 12px; line-height: 1.5; color: var(--gray-500); }
.ri-more-link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 12px;
    color: var(--primary-600);
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    border-top: 1px solid var(--gray-100);
    transition: background 0.2s;
}
.ri-more-link:hover { background: var(--gray-50); }

/* Avukat Fihristi widget (sidebar) */
.fihrist-card { border: 1px solid var(--gray-200); }
.fihrist-alpha-mini {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 4px;
    margin-bottom: 10px;
}
.fihrist-alpha-mini .fl {
    display: flex; align-items: center; justify-content: center;
    height: 28px; border-radius: 4px;
    font-size: 12px; font-weight: 700;
    text-decoration: none;
    background: var(--gray-50, #f8fafc);
    color: var(--primary-600, #1e40af);
    transition: all 0.12s ease;
}
.fihrist-alpha-mini .fl:hover {
    background: var(--primary-500, #1e40af);
    color: #fff;
}
.fihrist-alpha-mini .fl.active {
    background: var(--primary-500, #1e40af);
    color: #fff;
    box-shadow: 0 1px 4px rgba(30,64,175,0.3);
}
.fihrist-alpha-mini .fl.disabled {
    background: var(--gray-50, #f8fafc);
    color: var(--gray-300, #d1d5db);
    cursor: not-allowed;
}
.fihrist-all-link {
    display: flex; align-items: center; justify-content: center;
    gap: 6px; padding: 8px 10px;
    font-size: 12px; font-weight: 600;
    color: var(--primary-600, #1e40af);
    text-decoration: none;
    border-top: 1px solid var(--gray-100, #f3f4f6);
    margin-top: 4px;
    transition: background 0.15s ease;
}
.fihrist-all-link:hover {
    background: var(--gray-50, #f8fafc);
}
                .service-options-header { text-align:center; margin-bottom:20px; }
                .service-options-grid {
                    display:grid;
                    grid-template-columns: repeat(2, 1fr);
                    gap:20px;
                }
                @media (max-width: 768px) {
                    .service-options-grid { grid-template-columns: 1fr; gap:14px; }
                }
                .service-card {
                    background:#fff;
                    border-radius:16px;
                    padding:24px;
                    border:1px solid var(--gray-200,#e5e7eb);
                    box-shadow:0 1px 3px rgba(0,0,0,0.04);
                    transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
                    display:flex;
                    flex-direction:column;
                    position:relative;
                    overflow:hidden;
                }
                .service-card::before {
                    content:'';
                    position:absolute;
                    top:0; left:0; right:0;
                    height:4px;
                    border-radius:16px 16px 0 0;
                }
                .service-card-ask::before { background: linear-gradient(90deg,#0891b2,#06b6d4); }
                .service-card-appt::before { background: linear-gradient(90deg,#1a365d,#2c5282); }
                .service-card:hover {
                    transform: translateY(-3px);
                    box-shadow:0 10px 24px rgba(0,0,0,0.10);
                    border-color: var(--gray-300,#d1d5db);
                }
                .service-card-head {
                    display:flex;
                    align-items:center;
                    gap:14px;
                    margin-bottom:14px;
                }
                .service-card-icon {
                    width:48px; height:48px;
                    border-radius:12px;
                    display:flex; align-items:center; justify-content:center;
                    font-size:20px;
                    color:#fff;
                    flex-shrink:0;
                }
                .service-card-ask .service-card-icon { background: linear-gradient(135deg,#0891b2,#06b6d4); }
                .service-card-appt .service-card-icon { background: linear-gradient(135deg,#1a365d,#2c5282); }
                .service-card-title {
                    margin:0;
                    font-size:18px;
                    font-weight:700;
                    color:var(--gray-900,#111827);
                    line-height:1.2;
                }
                .service-card-desc {
                    margin:0 0 16px;
                    font-size:14px;
                    line-height:1.6;
                    color:var(--gray-600,#4b5563);
                    flex:1;
                }
                .service-card-features {
                    list-style:none;
                    padding:0;
                    margin:0 0 18px;
                }
                .service-card-features li {
                    padding:6px 0;
                    font-size:13px;
                    color:var(--gray-700,#374151);
                    display:flex;
                    align-items:center;
                    gap:8px;
                }
                .service-card-features li i {
                    font-size:11px;
                    width:16px; height:16px;
                    border-radius:50%;
                    display:inline-flex; align-items:center; justify-content:center;
                    color:#fff;
                    flex-shrink:0;
                }
                .service-card-ask .service-card-features li i { background:#06b6d4; }
                .service-card-appt .service-card-features li i { background:#2c5282; }
                .service-card-btn {
                    display:inline-flex;
                    align-items:center;
                    justify-content:center;
                    gap:8px;
                    padding:12px 20px;
                    border-radius:10px;
                    font-weight:600;
                    font-size:14px;
                    text-decoration:none;
                    color:#fff;
                    transition: filter .15s ease, transform .15s ease;
                    border:none;
                    cursor:pointer;
                    margin-top:auto; /* Her iki kartta butonu kart altına sabitler — buton hizalama */
                }
                .service-card-ask .service-card-btn { background: linear-gradient(135deg,#0891b2,#06b6d4); }
                .service-card-appt .service-card-btn { background: linear-gradient(135deg,#1a365d,#2c5282); }
                .service-card-btn:hover { filter: brightness(1.1); transform: translateY(-1px); }
                .service-card-btn i { font-size:12px; }

                /* Howto link butonun üstünde; margin-top:auto ile howto+button bloğu kart altına yapışır */
                .service-card-howto {
                    display:flex;
                    align-items:center;
                    justify-content:center;
                    gap:8px;
                    margin-top:auto;
                    margin-bottom:10px;
                    padding:8px 12px;
                    color:#475569;
                    font-size:12.5px;
                    text-decoration:none;
                    border-radius:8px;
                    transition:background .15s, color .15s;
                }
                .service-card-howto:hover { background:#f1f5f9; color:#1a365d; }
                .service-card-howto i { font-size:14px; color:#1a365d; }
                .service-card-howto strong { color:#0f172a; font-weight:700; }
                .service-card-howto + .service-card-btn { margin-top:0; }
                .seo-editorial-wrapper { margin: 24px 0; display:flex; flex-direction:column; gap:24px; }
                .seo-block {
                    background:#ffffff; border:1px solid #e2e8f0; border-radius:14px;
                    padding:28px 32px; box-shadow:0 2px 8px rgba(15,23,42,0.03);
                }
                .seo-eyebrow {
                    font-size:11px; font-weight:800; letter-spacing:1.5px;
                    text-transform:uppercase; color:#1a365d; margin-bottom:8px;
                }
                .seo-h2 {
                    font-family:'Playfair Display',Georgia,serif;
                    font-size:22px; color:#0f172a; font-weight:800;
                    letter-spacing:-0.3px; margin:0 0 18px; line-height:1.3;
                }
                .seo-body p { font-size:14.5px; color:#334155; line-height:1.75; margin:0 0 12px; }
                .seo-body p:last-child { margin-bottom:0; }
                .seo-body p strong { color:#0f172a; font-weight:700; }
                .seo-body p em {
                    font-style:normal; background:#fef3c7; padding:1px 5px;
                    border-radius:3px; color:#78350f; font-size:13.5px; font-weight:600;
                }
                .seo-mini-note {
                    font-size:12.5px; color:#64748b; line-height:1.6;
                    background:#f8fafc; border-left:3px solid #cbd5e1;
                    padding:10px 14px; border-radius:0 6px 6px 0;
                }
                .seo-data-table { width:100%; border-collapse:collapse; margin:14px 0; font-size:14px; }
                .seo-data-table th, .seo-data-table td {
                    padding:10px 14px; border-bottom:1px solid #e2e8f0; text-align:left;
                }
                .seo-data-table th {
                    color:#64748b; font-size:11.5px; text-transform:uppercase;
                    letter-spacing:0.5px; font-weight:700; width:40%;
                }
                .seo-data-table td { color:#0f172a; font-weight:600; }
                .seo-data-table tr:last-child th, .seo-data-table tr:last-child td { border-bottom:none; }
                .seo-bullets { list-style:none; padding:0; margin:14px 0 0; }
                .seo-bullets li {
                    padding:10px 0 10px 24px; border-bottom:1px solid #f1f5f9;
                    font-size:14px; color:#334155; line-height:1.7; position:relative;
                }
                .seo-bullets li:last-child { border-bottom:none; }
                .seo-bullets li::before {
                    content:''; position:absolute; left:0; top:18px;
                    width:6px; height:6px; border-radius:50%; background:#d4a84b;
                }
                .seo-bullets li strong { color:#0f172a; font-weight:700; }
                .seo-bullets li em {
                    font-style:normal; background:#fef3c7; padding:1px 5px;
                    border-radius:3px; color:#78350f; font-weight:600; font-size:13.5px;
                }
                .seo-qa { padding:14px 0; border-bottom:1px solid #f1f5f9; }
                .seo-qa:last-child { border-bottom:none; padding-bottom:0; }
                .seo-q {
                    display:flex; gap:10px; font-weight:700; color:#0f172a;
                    font-size:14.5px; line-height:1.55; margin-bottom:8px;
                }
                .seo-q::before {
                    content:'?'; flex-shrink:0; width:24px; height:24px; border-radius:50%;
                    background:linear-gradient(135deg,#d4a84b,#b8862c); color:#fff;
                    text-align:center; line-height:24px;
                    font-family:'Playfair Display',Georgia,serif; font-size:14px; font-weight:900;
                }
                .seo-a { color:#475569; font-size:14px; line-height:1.7; padding-left:34px; }
                .seo-a strong, .seo-a em { color:#0f172a; font-weight:700; font-style:normal; }
                .seo-claim-cta {
                    display:inline-flex; align-items:center; gap:10px;
                    padding:13px 26px; margin-top:10px;
                    background:linear-gradient(135deg,#1a365d,#2c5282);
                    color:#fff; text-decoration:none; border-radius:10px;
                    font-weight:800; font-size:14.5px;
                    box-shadow:0 6px 18px rgba(26,54,93,0.28);
                    transition:transform .15s, box-shadow .15s;
                }
                .seo-claim-cta:hover { transform:translateY(-1px); box-shadow:0 8px 22px rgba(26,54,93,0.32); }
                .seo-claim-cta i { color:#d4a84b; }
                @media (max-width: 680px) {
                    .seo-block { padding:20px 18px; }
                    .seo-h2 { font-size:19px; }
                    .seo-body p { font-size:13.5px; }
                }

                /* AI Quick Facts kartı — AI search engine ve klasik bots ortak yapı */
                .ai-quickfacts {
                    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
                    border: 1px solid #cbd5e1;
                    border-radius: 14px;
                    padding: 26px 30px;
                    margin: 32px 0 28px;
                    box-shadow: 0 4px 16px rgba(15,23,42,0.05);
                    position: relative;
                }
                .ai-quickfacts::before {
                    content: '';
                    position: absolute;
                    top: 0; left: 0;
                    width: 4px; height: 100%;
                    background: linear-gradient(180deg, #d4a84b, #1a365d);
                    border-radius: 14px 0 0 14px;
                }
                .ai-quickfacts-head { margin-bottom: 18px; }
                .ai-quickfacts-eyebrow {
                    display: inline-flex; align-items: center; gap: 6px;
                    font-size: 11px; font-weight: 800;
                    letter-spacing: 1.5px; text-transform: uppercase;
                    color: #1a365d;
                    background: rgba(212,168,75,0.12);
                    padding: 5px 11px; border-radius: 14px; margin-bottom: 12px;
                }
                .ai-quickfacts-eyebrow i { color: #b8862c; font-size: 11px; }
                .ai-quickfacts-title {
                    font-family: 'Playfair Display', Georgia, serif;
                    font-size: 21px; color: #0f172a; font-weight: 800;
                    letter-spacing: -0.3px; margin: 0 0 10px; line-height: 1.3;
                }
                .ai-quickfacts-summary {
                    font-size: 14.5px; color: #334155; line-height: 1.7; margin: 0;
                }
                .ai-quickfacts-summary strong { color: #0f172a; font-weight: 700; }
                .ai-quickfacts-list {
                    display: grid;
                    grid-template-columns: repeat(2, minmax(0, 1fr));
                    gap: 10px 28px; margin: 18px 0 0; padding: 18px 0 0;
                    border-top: 1px solid #e2e8f0;
                }
                .ai-quickfacts-list dt {
                    display: flex; align-items: center; gap: 7px;
                    font-size: 11px; font-weight: 700; color: #64748b;
                    letter-spacing: 0.5px; text-transform: uppercase;
                    grid-column: 1; align-self: center;
                }
                .ai-quickfacts-list dt i { color: #1a365d; font-size: 12px; width: 16px; text-align: center; }
                .ai-quickfacts-list dd {
                    font-size: 14px; color: #0f172a; font-weight: 600; margin: 0;
                    grid-column: 2; align-self: center;
                }
                @media (max-width: 680px) {
                    .ai-quickfacts-list { grid-template-columns: 1fr; gap: 6px; }
                    .ai-quickfacts-list dt { grid-column: 1; }
                    .ai-quickfacts-list dd { grid-column: 1; padding-left: 23px; margin-bottom: 8px; }
                }
                .ai-quickfacts-foot { margin-top: 18px; padding-top: 16px; border-top: 1px solid #e2e8f0; }
                .ai-quickfacts-source {
                    display: flex; gap: 9px; align-items: flex-start;
                    font-size: 12.5px; color: #475569; line-height: 1.55;
                    background: #fffbeb; border-left: 3px solid #f59e0b;
                    padding: 10px 12px; border-radius: 0 8px 8px 0;
                }
                .ai-quickfacts-source i { color: #b45309; font-size: 14px; margin-top: 2px; flex-shrink: 0; }
                .ai-quickfacts-source strong { color: #78350f; font-weight: 700; }
                .ai-quickfacts-hint {
                    font-size: 11.5px; color: #94a3b8; margin: 10px 0 0;
                    font-style: italic; line-height: 1.55;
                }
                .ai-quickfacts-time {
                    display: block; margin-top: 6px;
                    font-size: 11px; color: #94a3b8; letter-spacing: 0.3px;
                }
                .contact-cta-card {
                    background: #fff;
                    border: 1px solid var(--gray-200, #e5e7eb);
                    border-radius: 12px;
                    overflow: hidden;
                    box-shadow: 0 1px 3px rgba(15,23,42,0.05);
                }
                /* Ust banner: "Bu avukatin iletisim bilgileri kayitli" */
                .contact-cta-banner {
                    display: flex; align-items: center; gap: 10px;
                    padding: 10px 14px;
                    background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
                    color: #047857;
                    border-bottom: 1px solid #bbf7d0;
                    font-size: 12px;
                    line-height: 1.4;
                }
                .contact-cta-banner i {
                    font-size: 16px;
                    color: #059669;
                    flex-shrink: 0;
                }
                .contact-cta-banner-text { display: flex; flex-direction: column; gap: 1px; }
                .contact-cta-banner-text strong {
                    color: #064e3b;
                    font-weight: 700;
                    font-size: 12.5px;
                    letter-spacing: 0.01em;
                }
                .contact-cta-banner-text span { color: #047857; font-size: 11.5px; }

                /* Telefon karisik (net + blur) */
                .contact-cta-call-number-mix {
                    font-size: 17px;
                    font-weight: 700;
                    color: #fff;
                    letter-spacing: 0.04em;
                    font-variant-numeric: tabular-nums;
                    display: inline-flex; align-items: baseline; gap: 6px;
                }
                .contact-cta-call-number-mix .visible-part {
                    color: #fff;
                }
                .contact-cta-call-number-mix .blur-part {
                    filter: blur(3px);
                    user-select: none;
                    color: rgba(255,255,255,0.85);
                    letter-spacing: 0.1em;
                }

                /* Lock pill */
                .contact-cta-call-lock-pill {
                    width: 30px; height: 30px;
                    background: rgba(255,255,255,0.18);
                    border-radius: 50%;
                    display: flex; align-items: center; justify-content: center;
                    color: #fbbf24;
                    font-size: 12px;
                    flex-shrink: 0;
                }

                /* Tam-genislik unlock CTA */
                .contact-cta-unlock-btn {
                    display: flex; align-items: center; justify-content: center; gap: 8px;
                    padding: 11px 14px;
                    background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
                    color: #78350f;
                    font-size: 12.5px;
                    font-weight: 700;
                    text-decoration: none;
                    border: none;
                    cursor: pointer;
                    font-family: inherit;
                    transition: filter 0.15s ease;
                    text-align: center;
                    letter-spacing: 0.01em;
                }
                .contact-cta-unlock-btn:hover { filter: brightness(1.08); }
                .contact-cta-unlock-btn i { font-size: 13px; }
                /* AVUKATI ARA mavi CTA */
                .contact-cta-call {
                    display: flex; align-items: center; gap: 14px;
                    padding: 16px 18px;
                    background: linear-gradient(135deg, #1e3a5f 0%, #2c5282 100%);
                    color: #fff;
                    text-decoration: none;
                    transition: filter 0.15s ease, transform 0.1s ease;
                    border: none;
                    width: 100%;
                    cursor: pointer;
                    font-family: inherit;
                    text-align: left;
                }
                .contact-cta-call:hover { filter: brightness(1.08); }
                .contact-cta-call:active { transform: translateY(1px); }
                .contact-cta-call-icon {
                    width: 42px; height: 42px;
                    background: rgba(255,255,255,0.15);
                    border-radius: 10px;
                    display: flex; align-items: center; justify-content: center;
                    font-size: 18px;
                    flex-shrink: 0;
                }
                .contact-cta-call-text { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
                .contact-cta-call-label {
                    font-size: 10.5px;
                    letter-spacing: 0.12em;
                    color: rgba(255,255,255,0.78);
                    font-weight: 600;
                }
                .contact-cta-call-number {
                    font-size: 17px;
                    font-weight: 700;
                    color: #fff;
                    letter-spacing: 0.03em;
                    font-variant-numeric: tabular-nums;
                }
                .contact-cta-call-blur {
                    filter: blur(3px);
                    letter-spacing: 0.15em;
                }
                .contact-cta-call-arrow {
                    color: rgba(255,255,255,0.6);
                    font-size: 13px;
                    flex-shrink: 0;
                }
                .contact-cta-call-locked .contact-cta-call-icon {
                    background: rgba(255,255,255,0.1);
                }

                /* Adres + Web sitesi satirlari */
                .contact-cta-row {
                    display: flex; align-items: flex-start; gap: 12px;
                    padding: 14px 18px;
                    border-top: 1px solid var(--gray-100, #f1f5f9);
                    text-decoration: none;
                    color: inherit;
                    transition: background 0.12s ease;
                }
                .contact-cta-row-link:hover { background: var(--gray-50, #f9fafb); }
                .contact-cta-row-icon {
                    width: 32px; height: 32px;
                    background: var(--gray-100, #f1f5f9);
                    border-radius: 8px;
                    display: flex; align-items: center; justify-content: center;
                    color: var(--gray-600, #4b5563);
                    font-size: 13px;
                    flex-shrink: 0;
                    margin-top: 2px;
                }
                .contact-cta-row-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
                .contact-cta-row-label {
                    font-size: 10.5px;
                    letter-spacing: 0.1em;
                    color: var(--gray-500, #6b7280);
                    font-weight: 600;
                }
                .contact-cta-row-value {
                    font-size: 13.5px;
                    font-weight: 600;
                    color: var(--gray-900, #111827);
                    line-height: 1.45;
                    word-break: break-word;
                }
                .contact-cta-row-meta {
                    font-size: 12px;
                    color: var(--gray-500, #6b7280);
                    margin-top: 1px;
                }
                .contact-cta-row-blur {
                    filter: blur(3px);
                    user-select: none;
                }
                .contact-cta-row-value .visible-part {
                    color: var(--gray-900, #111827);
                    font-weight: 700;
                }
                .contact-cta-row-value .blur-part {
                    filter: blur(4px);
                    user-select: none;
                    color: var(--gray-500, #6b7280);
                    letter-spacing: 0.06em;
                }
                .contact-cta-row-value .address-sep {
                    color: var(--gray-400, #9ca3af);
                    margin: 0 4px;
                    font-weight: 400;
                }
                .contact-cta-row-unlock {
                    background: none; border: none; padding: 0; margin-top: 6px;
                    color: var(--primary-600, #1e40af);
                    font-size: 12.5px; font-weight: 600;
                    cursor: pointer; font-family: inherit;
                    text-decoration: underline;
                    align-self: flex-start;
                }
                .contact-cta-row-arrow { color: var(--gray-400, #9ca3af); font-size: 12px; flex-shrink: 0; margin-top: 6px; }

                /* Harita */
                .contact-cta-map { border-top: 1px solid var(--gray-100, #f1f5f9); position: relative; }
                .contact-cta-map iframe {
                    width: 100%; height: 170px; border: 0; display: block;
                }
                .contact-cta-map-direction {
                    display: flex; align-items: center; justify-content: center; gap: 8px;
                    padding: 10px 14px;
                    background: var(--gray-50, #f9fafb);
                    color: var(--primary-700, #1e3a5f);
                    font-size: 13px; font-weight: 600;
                    text-decoration: none;
                    border-top: 1px solid var(--gray-100, #f1f5f9);
                    transition: background 0.12s ease;
                }
                .contact-cta-map-direction:hover { background: var(--gray-100, #f1f5f9); }
