/* =============================================
   Endospine Turkiye - Responsive CSS
   Premium Medical WordPress Theme
   Sky Blue Design System - Tailwind-inspired
   Font: Plus Jakarta Sans
   ============================================= */


/* ===========================================
   TABLET — max-width: 1024px
   =========================================== */
@media (max-width: 1024px) {

    /* --- Services --- */
    .services-grid,
    .services-grid-6 {
        grid-template-columns: repeat(2, 1fr);
    }

    /* --- About --- */
    .about-grid {
        gap: 32px;
    }

    /* --- Why Endoscopic --- */
    .why-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* --- Testimonials --- */
    .testimonial-card {
        min-width: calc(50% - 12px);
    }

    /* --- Blog --- */
    .blog-layout {
        grid-template-columns: 1fr;
    }

    .blog-sidebar {
        display: none;
    }

    /* --- Ameliyat (Surgery) --- */
    .ameliyat-layout {
        grid-template-columns: 1fr;
    }

    .ameliyat-sidebar {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }

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

    /* --- Footer --- */
    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* --- About Page --- */
    .doctor-profile {
        grid-template-columns: 250px 1fr;
    }

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

    /* --- Testimonials Page --- */
    .testimonials-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* --- Hero Keywords --- */
    .hero-keywords {
        gap: 8px;
    }
}


/* ===========================================
   MOBILE — max-width: 768px
   =========================================== */
@media (max-width: 768px) {

    /* --- Section Utilities --- */
    .section-padding {
        padding: 48px 0;
    }

    .section-title {
        font-size: 24px;
    }

    .section-subtitle {
        font-size: 14px;
    }

    .section-header {
        margin-bottom: 32px;
    }

    /* -----------------------------------------------
       Top Bar
       ----------------------------------------------- */
    .top-bar-hours {
        display: none;
    }

    .top-bar {
        padding: 6px 0;
        font-size: 12px;
    }

    .top-bar-left {
        gap: 10px;
    }

    /* -----------------------------------------------
       Header & Mobile Navigation
       ----------------------------------------------- */
    .header-inner {
        padding: 8px 0;
    }

    /* CRITICAL: Show the hamburger menu toggle */
    .menu-toggle {
        display: flex !important;
    }

    /* Off-canvas mobile navigation panel — !important overrides desktop resets */
    .main-navigation {
        position: fixed !important;
        top: 0 !important;
        left: -280px !important;
        right: auto !important;
        width: 280px !important;
        height: 100vh !important;
        background: var(--color-bg-white) !important;
        box-shadow: var(--shadow-xl) !important;
        z-index: 2000;
        padding: 80px 0 20px 0 !important;
        transition: left 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch;
        display: flex !important;
        flex-direction: column;
        justify-content: flex-start;
    }

    .main-navigation.active {
        left: 0 !important;
    }

    /* Menu overlay — darken background when menu is open */
    .menu-overlay.active {
        opacity: 1;
        visibility: visible;
    }

    /* Menu lists stack vertically */
    .primary-menu,
    .fallback-menu {
        flex-direction: column;
        gap: 0;
        width: 100%;
    }

    .primary-menu li,
    .fallback-menu li {
        width: 100%;
    }

    /* Menu links — tappable with 48px min touch targets */
    .primary-menu li a,
    .fallback-menu li a {
        padding: 14px 20px;
        border-bottom: 1px solid var(--color-border-light);
        font-size: 15px;
        border-radius: 0;
        display: flex;
        align-items: center;
        min-height: 48px;
        color: var(--color-text);
        transition: all var(--transition);
    }

    /* Remove desktop underline effect */
    .primary-menu li a::after {
        display: none;
    }

    /* Active & hover menu items */
    .primary-menu li a:hover,
    .primary-menu li.current-menu-item > a,
    .primary-menu li.current_page_item > a,
    .fallback-menu li a:hover {
        background-color: var(--color-primary-light);
        color: var(--color-primary);
    }

    /* Sub-menus — static, always visible on mobile */
    .primary-menu li .sub-menu {
        position: static;
        opacity: 1;
        visibility: visible;
        transform: none;
        box-shadow: none;
        padding-left: 20px;
        min-width: auto;
        border-radius: 0;
        border: none;
        background: var(--color-bg-light);
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
    }

    .primary-menu li .sub-menu li a {
        font-size: 14px;
        padding: 12px 20px;
        color: var(--color-text-light);
        min-height: 44px;
        border-bottom: 1px solid var(--color-border-light);
    }

    .primary-menu li .sub-menu li a:hover {
        color: var(--color-primary);
        padding-left: 24px;
        background-color: rgba(14, 165, 233, 0.04);
    }

    /* Hide header CTA button on mobile */
    .header-cta {
        display: none;
    }

    /* -----------------------------------------------
       Hero Section
       ----------------------------------------------- */
    .hero-section {
        min-height: 440px;
    }

    .hero-content {
        padding: 40px 0;
    }

    .hero-title {
        font-size: 28px;
    }

    .hero-subtitle {
        font-size: 14px;
        margin-bottom: 20px;
    }

    .hero-badge {
        font-size: 12px;
        padding: 5px 14px;
        margin-bottom: 14px;
    }

    .hero-buttons {
        flex-direction: column;
        gap: 10px;
        margin-bottom: 24px;
    }

    .hero-buttons .btn {
        width: 100%;
    }

    .hero-stats {
        display: flex;
        flex-direction: row;
        justify-content: center;
        gap: 16px;
    }

    .hero-stat {
        flex: 1;
        text-align: center;
    }

    .hero-stat-number {
        font-size: 24px;
    }

    .hero-stat-label {
        font-size: 11px;
    }

    .hero-stat-text {
        font-size: 20px;
    }

    .hero-keywords {
        flex-wrap: wrap;
        gap: 6px;
        margin-bottom: 20px;
    }

    .hero-keyword-item {
        font-size: 11px;
        padding: 4px 10px;
    }

    /* -----------------------------------------------
       Services
       ----------------------------------------------- */
    .services-grid,
    .services-grid-6 {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    /* Horizontal card layout on mobile */
    .service-card {
        display: flex;
        gap: 16px;
        align-items: flex-start;
        text-align: left;
        padding: 20px;
    }

    .service-card:hover {
        transform: translateY(-2px);
    }

    .service-card-icon {
        width: 48px;
        height: 48px;
        margin: 0;
        font-size: 20px;
        flex-shrink: 0;
        border-radius: var(--radius-md);
    }

    .service-card-content {
        flex: 1;
        min-width: 0;
    }

    .service-card-title {
        font-size: 16px;
        margin-bottom: 4px;
    }

    .service-card-desc {
        font-size: 13px;
        margin-bottom: 8px;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .service-card-meta {
        justify-content: flex-start;
        gap: 12px;
        margin-bottom: 8px;
        font-size: 12px;
    }

    .service-card-link {
        font-size: 13px;
    }

    .services-seo-text {
        font-size: 13px;
        padding: 16px;
    }

    /* -----------------------------------------------
       About
       ----------------------------------------------- */
    .about-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .about-image-placeholder {
        height: 260px;
        font-size: 80px;
    }

    .about-image::after {
        display: none;
    }

    .about-experience-badge {
        bottom: -10px;
        right: 16px;
        padding: 14px;
    }

    .experience-number {
        font-size: 28px;
    }

    .about-stats {
        flex-direction: row;
        gap: 10px;
    }

    .about-stat {
        flex: 1;
        padding: 12px 10px;
    }

    /* Why Endoscopic */
    .why-endoscopic {
        padding: 28px 20px;
        border-radius: var(--radius-lg);
    }

    .why-title {
        font-size: 22px;
        margin-bottom: 24px;
    }

    .why-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .why-item {
        padding: 12px;
    }

    .why-icon {
        width: 44px;
        height: 44px;
        font-size: 18px;
        margin-bottom: 10px;
    }

    .why-item h4 {
        font-size: 13px;
    }

    .why-item p {
        font-size: 12px;
    }

    /* -----------------------------------------------
       Testimonials
       ----------------------------------------------- */
    .testimonial-card {
        min-width: 100%;
        padding: 20px;
    }

    .testimonial-content {
        font-size: 14px;
    }

    /* -----------------------------------------------
       FAQ
       ----------------------------------------------- */
    .faq-question {
        font-size: 14px;
        padding: 16px 18px;
    }

    .faq-answer {
        padding: 0 18px 16px;
        font-size: 14px;
    }

    /* -----------------------------------------------
       CTA
       ----------------------------------------------- */
    .cta-title {
        font-size: 24px;
    }

    .cta-text {
        font-size: 14px;
    }

    .cta-buttons {
        flex-direction: column;
        align-items: center;
    }

    .cta-buttons .btn {
        width: 100%;
        max-width: 300px;
    }

    /* -----------------------------------------------
       Page Hero
       ----------------------------------------------- */
    .page-hero {
        padding: 100px 0 32px;
    }

    .page-hero-title {
        font-size: 26px;
    }

    .page-hero-subtitle {
        font-size: 14px;
    }

    /* -----------------------------------------------
       Blog
       ----------------------------------------------- */
    .blog-grid {
        grid-template-columns: 1fr;
    }

    /* -----------------------------------------------
       Single Post
       ----------------------------------------------- */
    .single-title {
        font-size: 22px;
        padding: 16px 20px;
    }

    .single-content {
        padding: 0 20px 20px;
    }

    .single-meta {
        padding: 12px 20px 0;
        flex-wrap: wrap;
        gap: 8px;
        font-size: 12px;
    }

    .post-navigation .nav-links {
        flex-direction: column;
        gap: 12px;
    }

    .nav-previous,
    .nav-next {
        max-width: 100%;
    }

    .nav-next {
        text-align: left;
    }

    /* -----------------------------------------------
       Ameliyat (Surgery) Pages
       ----------------------------------------------- */
    .ameliyat-hero-title {
        font-size: 26px;
    }

    .ameliyat-hero-subtitle {
        font-size: 13px;
    }

    .info-cards-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 8px;
    }

    .info-card {
        padding: 14px 10px;
    }

    .info-card-value {
        font-size: 13px;
    }

    .info-card-icon {
        font-size: 18px;
    }

    .ameliyat-sidebar {
        grid-template-columns: 1fr;
    }

    .ameliyatlar-grid {
        grid-template-columns: 1fr;
    }

    /* -----------------------------------------------
       Contact
       ----------------------------------------------- */
    .contact-grid {
        grid-template-columns: 1fr;
    }

    /* -----------------------------------------------
       Appointment
       ----------------------------------------------- */
    .appointment-grid {
        grid-template-columns: 1fr;
    }

    /* -----------------------------------------------
       About Page
       ----------------------------------------------- */
    .doctor-profile {
        grid-template-columns: 1fr;
    }

    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    /* -----------------------------------------------
       Testimonials Page
       ----------------------------------------------- */
    .testimonials-grid {
        grid-template-columns: 1fr;
    }

    /* -----------------------------------------------
       Gallery
       ----------------------------------------------- */
    .gallery-grid,
    .gallery-grid-full {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    /* -----------------------------------------------
       Footer
       ----------------------------------------------- */
    .footer-grid {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    .footer-top {
        padding: 36px 0 20px;
    }

    .footer-heading {
        font-size: 15px;
        margin-bottom: 12px;
    }

    .footer-about-text {
        font-size: 13px;
    }

    /* -----------------------------------------------
       Page Section / Single Post / Archive / Search
       ----------------------------------------------- */
    .page-section,
    .single-post.section-padding,
    .archive-section,
    .search-section,
    .error-404,
    .blog-section {
        padding-top: 100px;
    }

    .page-main-title {
        font-size: 26px;
    }

    .single-title {
        font-size: 22px;
        padding: 16px 20px 0;
    }

    .single-content {
        padding: 16px 20px 24px;
    }

    .single-meta {
        padding: 12px 20px 0;
        flex-wrap: wrap;
        gap: 8px;
        font-size: 12px;
    }

    .post-navigation .nav-links {
        flex-direction: column;
        gap: 12px;
    }

    .nav-previous,
    .nav-next {
        max-width: 100%;
    }

    .nav-next {
        text-align: left;
    }

    /* -----------------------------------------------
       404
       ----------------------------------------------- */
    .error-number {
        font-size: 60px;
    }

    .error-links-grid {
        flex-direction: column;
        align-items: center;
    }
}


/* ===========================================
   SMALL PHONE — max-width: 480px
   =========================================== */
@media (max-width: 480px) {

    /* --- Container --- */
    .container {
        padding: 0 16px;
    }

    /* --- Section Utilities --- */
    .section-padding {
        padding: 36px 0;
    }

    .section-title {
        font-size: 22px;
    }

    .section-subtitle {
        font-size: 13px;
    }

    /* --- Buttons --- */
    .btn-lg {
        padding: 14px 28px;
        font-size: 14px;
    }

    /* -----------------------------------------------
       Top Bar
       ----------------------------------------------- */
    .top-bar {
        font-size: 11px;
        padding: 5px 0;
    }

    .top-bar .container {
        flex-direction: column;
        gap: 4px;
        align-items: center;
    }

    .top-bar-left {
        flex-wrap: wrap;
        justify-content: center;
        gap: 8px;
    }

    .top-bar-right {
        justify-content: center;
    }

    /* -----------------------------------------------
       Header
       ----------------------------------------------- */
    .site-title,
    .site-title-accent {
        font-size: 20px;
    }

    .site-description {
        font-size: 10px;
    }

    .site-branding .custom-logo {
        max-height: 40px;
    }

    /* -----------------------------------------------
       Hero
       ----------------------------------------------- */
    .hero-section {
        min-height: 380px;
    }

    .hero-content {
        padding: 32px 0;
    }

    .hero-title {
        font-size: 24px;
    }

    .hero-subtitle {
        font-size: 13px;
        margin-bottom: 16px;
    }

    .hero-badge {
        font-size: 11px;
        padding: 4px 12px;
        margin-bottom: 12px;
    }

    .hero-stats {
        display: flex;
        flex-direction: row;
        justify-content: center;
        gap: 10px;
        padding-top: 20px;
    }

    .hero-stat {
        flex: 1;
        text-align: center;
        padding: 10px 6px;
        background: rgba(255, 255, 255, 0.1);
        border-radius: var(--radius-md);
    }

    .hero-stat-number {
        font-size: 20px;
        display: block;
    }

    .hero-stat-label {
        font-size: 10px;
        display: block;
    }

    .hero-stat-text {
        font-size: 16px;
    }

    .hero-keyword-item {
        font-size: 10px;
        padding: 3px 8px;
    }

    /* -----------------------------------------------
       Services
       ----------------------------------------------- */
    .service-card {
        padding: 16px;
        gap: 12px;
    }

    .service-card-icon {
        width: 42px;
        height: 42px;
        font-size: 18px;
        border-radius: 10px;
    }

    .service-card-title {
        font-size: 15px;
    }

    .service-card-desc {
        font-size: 12px;
    }

    /* -----------------------------------------------
       About
       ----------------------------------------------- */
    .about-image-placeholder {
        height: 200px;
        font-size: 64px;
    }

    .about-experience-badge {
        padding: 10px;
        right: 12px;
        bottom: -8px;
    }

    .experience-number {
        font-size: 24px;
    }

    .about-stat {
        padding: 10px 12px;
    }

    .about-stats-section {
        padding: 24px 16px;
    }

    .stat-number {
        font-size: 28px;
    }

    /* Why Grid — single column on phone */
    .why-grid {
        grid-template-columns: 1fr;
    }

    .why-endoscopic {
        padding: 20px 16px;
    }

    .why-title {
        font-size: 20px;
    }

    .why-item {
        padding: 14px;
    }

    .why-item h4 {
        font-size: 14px;
    }

    .why-item p {
        font-size: 12px;
    }

    /* -----------------------------------------------
       Info Cards — single column
       ----------------------------------------------- */
    .info-cards-grid {
        grid-template-columns: 1fr;
    }

    .info-card {
        padding: 12px;
    }

    /* -----------------------------------------------
       Testimonials
       ----------------------------------------------- */
    .testimonial-card {
        padding: 16px;
    }

    .testimonial-content {
        font-size: 13px;
    }

    /* -----------------------------------------------
       FAQ
       ----------------------------------------------- */
    .faq-question {
        font-size: 13px;
        padding: 14px 16px;
    }

    .faq-answer {
        padding: 0 16px 14px;
        font-size: 13px;
    }

    /* -----------------------------------------------
       CTA
       ----------------------------------------------- */
    .cta-title {
        font-size: 20px;
    }

    .cta-text {
        font-size: 13px;
    }

    .cta-buttons .btn {
        max-width: 100%;
    }

    /* -----------------------------------------------
       Ameliyat
       ----------------------------------------------- */
    .ameliyat-hero-title {
        font-size: 22px;
    }

    .ameliyat-hero-subtitle {
        font-size: 12px;
    }

    .ameliyat-main-content {
        padding: 20px 14px;
    }

    /* -----------------------------------------------
       Gallery — single column on phone
       ----------------------------------------------- */
    .gallery-grid,
    .gallery-grid-full {
        grid-template-columns: 1fr;
    }

    .gallery-item img {
        height: 180px;
    }

    /* -----------------------------------------------
       Blog
       ----------------------------------------------- */
    .blog-card-content {
        padding: 14px;
    }

    .blog-card-title {
        font-size: 16px;
    }

    /* -----------------------------------------------
       Single Post
       ----------------------------------------------- */
    .single-title {
        font-size: 20px;
        padding: 14px 16px;
    }

    .single-content {
        padding: 0 16px 16px;
        font-size: 14px;
    }

    .single-meta {
        padding: 10px 16px 0;
    }

    /* -----------------------------------------------
       Page Hero
       ----------------------------------------------- */
    .page-hero {
        padding: 90px 0 24px;
    }

    .page-hero-title {
        font-size: 22px;
    }

    .page-hero-subtitle {
        font-size: 13px;
    }

    /* -----------------------------------------------
       Contact & Appointment
       ----------------------------------------------- */
    .contact-info-item {
        padding: 14px;
    }

    .form-row {
        flex-direction: column;
        gap: 12px;
    }

    /* -----------------------------------------------
       Doctor Profile
       ----------------------------------------------- */
    .doctor-photo {
        max-width: 200px;
        margin: 0 auto;
    }

    .stats-grid {
        gap: 10px;
    }

    /* -----------------------------------------------
       Footer
       ----------------------------------------------- */
    .footer-top {
        padding: 28px 0 14px;
    }

    .footer-heading {
        font-size: 14px;
        margin-bottom: 10px;
    }

    .footer-about-text {
        font-size: 12px;
    }

    .footer-bottom {
        font-size: 12px;
        padding: 14px 0;
    }

    /* -----------------------------------------------
       Breadcrumb
       ----------------------------------------------- */
    .breadcrumb {
        font-size: 12px;
        padding: 8px 0;
    }

    .breadcrumb .separator {
        margin: 0 5px;
    }

    /* -----------------------------------------------
       Page Section / Single Post
       ----------------------------------------------- */
    .page-section,
    .single-post.section-padding,
    .archive-section,
    .search-section,
    .error-404,
    .blog-section {
        padding-top: 90px;
    }

    .page-main-title {
        font-size: 22px;
    }

    .single-title {
        font-size: 20px;
        padding: 14px 16px 0;
    }

    .single-content {
        padding: 14px 16px 20px;
        font-size: 14px;
    }

    .single-meta {
        padding: 10px 16px 0;
    }

    /* -----------------------------------------------
       404 Page
       ----------------------------------------------- */
    .error-number {
        font-size: 48px;
    }

    .error-title {
        font-size: 20px;
    }

    .error-text {
        font-size: 14px;
    }

    /* -----------------------------------------------
       Search Form
       ----------------------------------------------- */
    .search-form {
        flex-direction: column;
    }

    .search-form input[type="search"],
    .search-form .search-field {
        width: 100%;
        border-radius: var(--radius-lg);
    }

    .search-form .search-submit,
    .search-form button {
        width: 100%;
        border-radius: var(--radius-lg);
    }

    /* -----------------------------------------------
       Comments
       ----------------------------------------------- */
    .comments-area {
        padding: 16px;
    }

    .comment-body {
        padding: 14px;
    }

    .comment-meta {
        font-size: 12px;
    }

    /* -----------------------------------------------
       Widgets / Sidebar
       ----------------------------------------------- */
    .widget {
        padding: 16px;
    }

    /* -----------------------------------------------
       Premium Page Overrides
       ----------------------------------------------- */
    .about-doctor-grid,
    .faq-page-layout {
        grid-template-columns: 1fr !important;
    }

    .about-stats-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 8px !important;
    }

    .about-stats-grid .about-stat-card {
        padding: 16px 8px !important;
    }

    .about-stats-grid .about-stat-number {
        font-size: 20px !important;
    }

    .about-stats-grid .about-stat-label {
        font-size: 11px !important;
    }

    .about-stats-grid .about-stat-icon {
        font-size: 20px !important;
        margin-bottom: 6px !important;
    }

    .info-strip-grid,
    .quick-cards-grid {
        grid-template-columns: 1fr !important;
    }

    .about-why-grid,
    .ameliyatlar-grid,
    .testimonials-grid,
    .advantages-grid {
        grid-template-columns: 1fr !important;
    }

    .gallery-grid-full {
        grid-template-columns: 1fr !important;
    }

    .ameliyat-hero-actions,
    .about-doctor-cta {
        flex-direction: column !important;
    }

    .trust-bar-grid {
        flex-direction: column !important;
        gap: 12px !important;
    }

    .appointment-trust {
        flex-direction: column !important;
    }

    .faq-sidebar {
        grid-template-columns: 1fr !important;
    }
}
