/* SEO Optimization Service Page Styles */

/* Extends main.css with SEO-specific styling */



/* Navigation Logo Fix - Ensure consistency with main page */

.nav-logo {

    height: 5rem !important;

    display: flex !important;

    align-items: center !important;

}



.nav-logo a {

    height: 100% !important;

    display: flex !important;

    align-items: center !important;

    text-decoration: none;

}



.nav-logo img {

    height: 100% !important;

    width: auto !important;

    object-fit: contain !important;

    max-height: 5rem !important;

    max-width: 200px !important;

}



/* Header consistency */

.header {

    position: fixed;

    top: 0;

    width: 100%;

    height: var(--header-height);

    z-index: 1000;

    background: rgba(15, 23, 42, 0.9);

    backdrop-filter: blur(20px);

    border-bottom: 1px solid var(--border);

    transition: var(--transition);

}



.nav {

    padding: var(--space-md) 0;

    height: 100%;

}



.nav-container {

    display: flex;

    align-items: center;

    justify-content: space-between;

    height: 100%;

    max-width: 1200px;

    margin: 0 auto;

    padding: 0 var(--space-lg);

}



/* Responsive logo adjustments */

@media (max-width: 768px) {

    .nav-logo {

        height: 4rem !important;

    }



    .nav-logo img {

        max-height: 4rem !important;

        max-width: 150px !important;

    }

}



@media (max-width: 480px) {

    .nav-logo {

        height: 3.5rem !important;

    }



    .nav-logo img {

        max-height: 3.5rem !important;

        max-width: 120px !important;

    }

}



/* Service Hero Section */

.service-hero {

    position: relative;

    min-height: 90vh;

    display: flex;

    align-items: center;

    overflow: hidden;

    padding-top: var(--header-height);

    background: var(--bg-primary);

}



.service-hero-content {

    max-width: 800px;

    margin: 0 auto;

    text-align: center;

    padding: var(--space-3xl) 0;

    animation: fadeInUp 1s ease-out;

}



@keyframes fadeInUp {

    from {

        opacity: 0;

        transform: translateY(30px);

    }

    to {

        opacity: 1;

        transform: translateY(0);

    }

}



.service-breadcrumb {

    margin-bottom: var(--space-lg);

    font-size: 0.875rem;

    color: var(--text-light);

}



.service-breadcrumb a {

    color: var(--primary);

    text-decoration: none;

    transition: var(--transition);

}



.service-breadcrumb a:hover {

    color: var(--primary-dark);

}



.service-badge {

    display: inline-flex;

    align-items: center;

    padding: var(--space-sm) var(--space-md);

    background: rgba(99, 102, 241, 0.2);

    color: var(--text-primary);

    border-radius: var(--radius-xl);

    font-size: 0.875rem;

    font-weight: 500;

    margin-bottom: var(--space-xl);

    border: 1px solid rgba(99, 102, 241, 0.3);

    backdrop-filter: blur(10px);

}



.service-hero-title {

    font-size: 3.5rem;

    font-weight: 800;

    margin-bottom: var(--space-lg);

    line-height: 1.1;

    color: var(--text-primary);

    font-family: var(--font-display);

}



.title-line {

    display: block;

}



.service-hero-description {

    font-size: 1.25rem;

    color: var(--text-secondary);

    margin-bottom: var(--space-2xl);

    line-height: 1.6;

    max-width: 700px;

    margin-left: auto;

    margin-right: auto;

}



.service-hero-cta {

    display: flex;

    gap: var(--space-md);

    justify-content: center;

    margin-bottom: var(--space-3xl);

}



.service-hero-stats {

    display: flex;

    gap: var(--space-2xl);

    justify-content: center;

}



/* Service Overview */

.service-overview {

    padding: var(--space-3xl) 0;

    background: var(--bg-secondary);

}



.overview-grid {

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: var(--space-3xl);

    align-items: center;

}



.overview-content .section-title {

    text-align: left;

    margin-bottom: var(--space-lg);

}



.overview-description {

    font-size: 1.125rem;

    color: var(--text-secondary);

    margin-bottom: var(--space-2xl);

    line-height: 1.6;

}



.benefits-list {

    display: flex;

    flex-direction: column;

    gap: var(--space-lg);

}



.benefit-item {

    display: flex;

    align-items: flex-start;

    gap: var(--space-md);

    padding: var(--space-lg);

    background: rgba(255, 255, 255, 0.05);

    border-radius: var(--radius-lg);

    border: 1px solid var(--border);

    transition: var(--transition);

}



.benefit-item:hover {

    transform: translateY(-2px);

    background: rgba(255, 255, 255, 0.08);

    border-color: rgba(99, 102, 241, 0.3);

}



.benefit-icon {

    font-size: 1.5rem;

    margin-top: var(--space-xs);

}



.benefit-content h4 {

    color: var(--text-primary);

    margin-bottom: var(--space-xs);

    font-weight: 600;

}



.benefit-content p {

    color: var(--text-secondary);

    line-height: 1.5;

    margin: 0;

}



/* SEO Analytics Visualization */

.overview-visual {

    display: flex;

    justify-content: center;

    align-items: center;

}



.seo-analytics {

    background: #1a1a1a;

    border-radius: var(--radius-lg);

    overflow: hidden;

    box-shadow: var(--shadow-xl);

    width: 100%;

    max-width: 500px;

    border: 1px solid #333;

}



.analytics-header {

    background: #2a2a2a;

    padding: var(--space-md);

    border-bottom: 1px solid #333;

}



.analytics-tabs {

    display: flex;

    gap: var(--space-md);

}



.tab {

    padding: var(--space-xs) var(--space-sm);

    color: #999;

    font-size: 0.875rem;

    cursor: pointer;

    border-radius: var(--radius-sm);

    transition: var(--transition);

}



.tab.active {

    background: rgba(99, 102, 241, 0.2);

    color: var(--primary);

}



.analytics-content {

    padding: var(--space-lg);

}



.metric-card {

    background: rgba(255, 255, 255, 0.05);

    border-radius: var(--radius-md);

    padding: var(--space-md);

    margin-bottom: var(--space-md);

    border: 1px solid #333;

}



.metric-label {

    color: #999;

    font-size: 0.875rem;

    margin-bottom: var(--space-xs);

}



.metric-value {

    color: var(--primary);

    font-size: 1.5rem;

    font-weight: 700;

    margin-bottom: var(--space-xs);

}



.metric-trend {

    color: #10b981;

    font-size: 0.875rem;

}



.traffic-chart {

    margin-top: var(--space-lg);

}



.chart-bars {

    display: flex;

    align-items: end;

    gap: var(--space-xs);

    height: 80px;

    margin-bottom: var(--space-sm);

}



.bar {

    background: linear-gradient(to top, var(--primary), var(--secondary));

    width: 100%;

    border-radius: 2px 2px 0 0;

    animation: growUp 1s ease-out;

}



@keyframes growUp {

    from { height: 0 !important; }

}



.chart-labels {

    display: flex;

    justify-content: space-between;

    color: #999;

    font-size: 0.75rem;

}



/* SEO Services Section */

.seo-services {

    padding: var(--space-3xl) 0;

    background: var(--bg-primary);

}



.services-grid {

    display: grid;

    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));

    gap: var(--space-xl);

}



.seo-service-card {

    background: var(--bg-secondary);

    border-radius: var(--radius-xl);

    padding: var(--space-2xl);

    border: 1px solid var(--border);

    transition: var(--transition-slow);

    position: relative;

    overflow: hidden;

}



.seo-service-card::before {

    content: '';

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 4px;

    background: var(--gradient-primary);

    transform: scaleX(0);

    transform-origin: left;

    transition: var(--transition-slow);

}



.seo-service-card:hover::before {

    transform: scaleX(1);

}



.seo-service-card:hover {

    transform: translateY(-8px);

    box-shadow: var(--shadow-xl);

    border-color: rgba(99, 102, 241, 0.3);

}



.service-icon {

    font-size: 2.5rem;

    margin-bottom: var(--space-lg);

    display: block;

}



.service-title {

    font-size: 1.5rem;

    font-weight: 600;

    margin-bottom: var(--space-md);

    color: var(--text-primary);

}



.service-description {

    color: var(--text-secondary);

    line-height: 1.6;

    margin-bottom: var(--space-lg);

}



.service-features {

    display: flex;

    flex-wrap: wrap;

    gap: var(--space-sm);

}



.feature-tag {

    background: rgba(99, 102, 241, 0.2);

    color: var(--primary);

    padding: var(--space-xs) var(--space-sm);

    border-radius: var(--radius-sm);

    font-size: 0.75rem;

    font-weight: 500;

    border: 1px solid rgba(99, 102, 241, 0.3);

}



/* SEO Process */

.seo-process {

    padding: var(--space-3xl) 0;

    background: var(--bg-secondary);

}



.process-timeline {

    display: flex;

    flex-direction: column;

    gap: var(--space-2xl);

    max-width: 800px;

    margin: 0 auto;

}



.process-step {

    display: flex;

    gap: var(--space-xl);

    align-items: flex-start;

    position: relative;

}



.process-step:not(:last-child)::after {

    content: '';

    position: absolute;

    left: 30px;

    top: 80px;

    width: 2px;

    height: calc(100% + var(--space-2xl));

    background: linear-gradient(to bottom, var(--primary), transparent);

}



.step-number {

    width: 60px;

    height: 60px;

    background: var(--gradient-primary);

    border-radius: 50%;

    display: flex;

    align-items: center;

    justify-content: center;

    font-weight: 700;

    font-size: 1.25rem;

    color: white;

    flex-shrink: 0;

    box-shadow: var(--shadow-md);

}



.step-content {

    flex: 1;

    background: var(--bg-primary);

    padding: var(--space-xl);

    border-radius: var(--radius-lg);

    border: 1px solid var(--border);

}



.step-title {

    font-size: 1.5rem;

    font-weight: 600;

    margin-bottom: var(--space-md);

    color: var(--text-primary);

}



.step-description {

    color: var(--text-secondary);

    line-height: 1.6;

    margin-bottom: var(--space-lg);

}



.step-deliverables {

    display: flex;

    gap: var(--space-sm);

    flex-wrap: wrap;

}



.deliverable {

    background: rgba(99, 102, 241, 0.2);

    color: var(--primary);

    padding: var(--space-xs) var(--space-sm);

    border-radius: var(--radius-sm);

    font-size: 0.75rem;

    font-weight: 500;

    border: 1px solid rgba(99, 102, 241, 0.3);

}



/* SEO Portfolio Results */

.seo-portfolio {

    padding: var(--space-3xl) 0;

    background: var(--bg-primary);

}



.portfolio-grid {

    display: grid;

    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));

    gap: var(--space-xl);

}



.result-card {

    background: var(--bg-secondary);

    border-radius: var(--radius-xl);

    padding: var(--space-2xl);

    border: 1px solid var(--border);

    transition: var(--transition-slow);

}



.result-card:hover {

    transform: translateY(-8px);

    box-shadow: var(--shadow-xl);

    border-color: rgba(99, 102, 241, 0.3);

}



.result-header {

    display: flex;

    align-items: center;

    gap: var(--space-md);

    margin-bottom: var(--space-lg);

}



.result-icon {

    font-size: 2rem;

    width: 60px;

    height: 60px;

    background: var(--gradient-primary);

    border-radius: var(--radius-lg);

    display: flex;

    align-items: center;

    justify-content: center;

    flex-shrink: 0;

}



.result-title {

    font-size: 1.25rem;

    font-weight: 600;

    color: var(--text-primary);

    margin: 0 0 var(--space-xs) 0;

}



.result-industry {

    font-size: 0.875rem;

    color: var(--text-light);

    font-style: italic;

}



.result-content {

    display: flex;

    flex-direction: column;

    gap: var(--space-lg);

}



.result-description {

    color: var(--text-secondary);

    line-height: 1.6;

}



.result-metrics {

    display: grid;

    grid-template-columns: repeat(3, 1fr);

    gap: var(--space-md);

}



.metric {

    text-align: center;

    padding: var(--space-md);

    background: var(--bg-primary);

    border-radius: var(--radius-md);

    border: 1px solid var(--border);

}



.metric-number {

    display: block;

    font-size: 1.5rem;

    font-weight: 700;

    color: var(--primary);

    font-family: var(--font-display);

}



.metric-label {

    font-size: 0.875rem;

    color: var(--text-light);

}



.result-timeline {

    align-self: flex-end;

    background: rgba(99, 102, 241, 0.2);

    color: var(--primary);

    padding: var(--space-xs) var(--space-sm);

    border-radius: var(--radius-sm);

    font-size: 0.875rem;

    font-weight: 500;

    border: 1px solid rgba(99, 102, 241, 0.3);

    width: fit-content;

}



/* Pricing Packages */

.pricing-packages {

    padding: var(--space-3xl) 0;

    background: var(--bg-primary);

}



.pricing-grid {

    display: grid;

    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));

    gap: var(--space-xl);

    margin-bottom: var(--space-2xl);

}



.pricing-card {

    background: var(--bg-primary);

    border-radius: var(--radius-xl);

    padding: var(--space-2xl);

    border: 2px solid var(--border);

    transition: var(--transition-slow);

    position: relative;

    overflow: hidden;

}



.pricing-card:hover {

    transform: translateY(-8px);

    box-shadow: var(--shadow-xl);

    border-color: rgba(99, 102, 241, 0.3);

}



.pricing-card.featured {

    border-color: var(--primary);

    transform: scale(1.05);

}



.pricing-card.featured:hover {

    transform: scale(1.05) translateY(-8px);

}



.featured-badge {

    position: absolute;

    top: var(--space-md);

    right: var(--space-md);

    background: var(--gradient-primary);

    color: white;

    padding: var(--space-xs) var(--space-sm);

    border-radius: var(--radius-sm);

    font-size: 0.75rem;

    font-weight: 600;

}



.pricing-header {

    text-align: center;

    margin-bottom: var(--space-xl);

}



.package-name {

    font-size: 1.5rem;

    font-weight: 600;

    margin-bottom: var(--space-md);

    color: var(--text-primary);

}



.package-price {

    display: flex;

    flex-direction: column;

    align-items: center;

}



.price {

    font-size: 2.5rem;

    font-weight: 700;

    color: var(--primary);

    font-family: var(--font-display);

}



.period {

    font-size: 0.875rem;

    color: var(--text-light);

}



.pricing-features {

    margin-bottom: var(--space-xl);

}



.feature {

    padding: var(--space-sm) 0;

    color: var(--text-secondary);

    border-bottom: 1px solid var(--border);

    font-size: 0.875rem;

}



.feature:last-child {

    border-bottom: none;

}



.pricing-cta {

    margin-bottom: var(--space-lg);

}



.pricing-cta .btn {

    width: 100%;

    justify-content: center;

}



.package-ideal {

    text-align: center;

    font-size: 0.875rem;

    color: var(--text-light);

    font-style: italic;

    margin-bottom: var(--space-sm);

}



.package-timeline {

    text-align: center;

    font-size: 0.75rem;

    color: var(--text-light);

    background: rgba(255, 255, 255, 0.05);

    padding: var(--space-xs);

    border-radius: var(--radius-sm);

}



/* Add-on Services */

.add-on-services {

    margin-top: var(--space-2xl);

    padding-top: var(--space-2xl);

    border-top: 1px solid var(--border);

}



.add-on-title {

    text-align: center;

    font-size: 1.5rem;

    font-weight: 600;

    margin-bottom: var(--space-lg);

    color: var(--text-primary);

}



.add-on-grid {

    display: grid;

    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));

    gap: var(--space-md);

}



.add-on-item {

    display: flex;

    justify-content: space-between;

    align-items: center;

    padding: var(--space-md);

    background: var(--bg-primary);

    border-radius: var(--radius-md);

    border: 1px solid var(--border);

}



.add-on-name {

    font-weight: 500;

    color: var(--text-primary);

}



.add-on-price {

    font-weight: 600;

    color: var(--primary);

    font-size: 0.875rem;

}



/* FAQ Section */

.faq-section {

    padding: var(--space-3xl) 0;

    background: var(--bg-secondary);

}



.faq-grid {

    display: grid;

    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));

    gap: var(--space-lg);

    max-width: 1000px;

    margin: 0 auto;

}



.faq-item {

    background: var(--bg-secondary);

    border-radius: var(--radius-lg);

    padding: var(--space-lg);

    border: 1px solid var(--border);

    transition: var(--transition);

    cursor: pointer;

}



.faq-item:hover {

    background: var(--bg-tertiary);

    border-color: rgba(99, 102, 241, 0.3);

}



.faq-question {

    font-weight: 600;

    color: var(--text-primary);

    margin-bottom: var(--space-md);

    font-size: 1.125rem;

}



.faq-answer {

    color: var(--text-secondary);

    line-height: 1.6;

}



/* Related Services */

.related-services {

    padding: var(--space-3xl) 0;

    background: var(--bg-primary);

}



.related-grid {

    display: grid;

    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));

    gap: var(--space-xl);

}



.related-service {

    background: var(--bg-primary);

    border-radius: var(--radius-lg);

    padding: var(--space-xl);

    border: 1px solid var(--border);

    transition: var(--transition);

    text-align: center;

}



.related-service:hover {

    transform: translateY(-4px);

    box-shadow: var(--shadow-lg);

    border-color: rgba(99, 102, 241, 0.3);

}



.related-icon {

    font-size: 2rem;

    margin-bottom: var(--space-md);

}



.related-title {

    font-size: 1.25rem;

    font-weight: 600;

    margin-bottom: var(--space-md);

    color: var(--text-primary);

}



.related-description {

    color: var(--text-secondary);

    margin-bottom: var(--space-lg);

    line-height: 1.5;

}



.related-link {

    color: var(--primary);

    text-decoration: none;

    font-weight: 600;

    transition: var(--transition);

}



.related-link:hover {

    color: var(--primary-dark);

}



/* Contact Section */

.contact-section {

    padding: var(--space-3xl) 0;

    background: var(--bg-secondary);

}



.contact-highlights {

    margin-bottom: var(--space-2xl);

}



.highlight-item {

    display: flex;

    align-items: center;

    gap: var(--space-md);

    margin-bottom: var(--space-lg);

}



.highlight-icon {

    font-size: 1.5rem;

}



.highlight-item h4 {

    margin-bottom: var(--space-xs);

    color: var(--text-primary);

    font-weight: 600;

}



.highlight-item p {

    color: var(--text-secondary);

    margin: 0;

    font-size: 0.875rem;

}



/* Contact Form Enhancement */


#seoContactForm .form-group {

    margin-bottom: var(--space-lg);


}



#seoContactForm .btn {

    width: 100%;

    justify-content: center;

    margin-top: var(--space-md);

}



/* Active Navigation State */

.nav-dropdown .dropdown-content a.active {

    background: var(--primary);

    color: white;

}



.nav-dropdown .dropdown-content a.active:hover {

    background: var(--primary-dark);

}



/* Responsive Adjustments */

@media (max-width: 1024px) {

    .overview-grid {

        grid-template-columns: 1fr;

        gap: var(--space-2xl);

        text-align: center;

    }



    .pricing-card.featured {

        transform: none;

    }



    .pricing-card.featured:hover {

        transform: translateY(-8px);

    }



    .result-metrics {

        grid-template-columns: 1fr;

    }



    .add-on-grid {

        grid-template-columns: 1fr;

    }

}



@media (max-width: 768px) {

    .service-hero-title {

        font-size: 2.5rem;

    }



    .service-hero-cta {

        flex-direction: column;

        align-items: center;

    }



    .service-hero-stats {

        flex-wrap: wrap;

        gap: var(--space-lg);

    }



    .benefits-list {

        gap: var(--space-md);

    }



    .benefit-item {

        padding: var(--space-md);

    }



    .process-step {

        flex-direction: column;

        text-align: center;

    }



    .process-step::after {

        display: none;

    }



    .step-number {

        align-self: center;

    }



    .pricing-grid {

        grid-template-columns: 1fr;

    }



    .faq-grid {

        grid-template-columns: 1fr;

    }



    .related-grid {

        grid-template-columns: 1fr;

    }



    .services-grid {

        grid-template-columns: 1fr;

    }



    .portfolio-grid {

        grid-template-columns: 1fr;

    }



    .analytics-tabs {

        flex-wrap: wrap;

    }

}



@media (max-width: 480px) {

    .service-hero-title {

        font-size: 2rem;

    }



    .seo-analytics {

        max-width: 100%;

    }



    .step-content {

        padding: var(--space-lg);

    }



    .seo-service-card {

        padding: var(--space-lg);

    }



    .result-card {

        padding: var(--space-lg);

    }



    .result-header {

        flex-direction: column;

        text-align: center;

    }



    .result-metrics {

        grid-template-columns: 1fr;

    }

}



/* Loading and Animation States */

.seo-service-card.loading {

    opacity: 0.6;

}



.seo-service-card.loading::after {

    content: '';

    position: absolute;

    top: 50%;

    left: 50%;

    width: 20px;

    height: 20px;

    margin: -10px 0 0 -10px;

    border: 2px solid transparent;

    border-top: 2px solid var(--primary);

    border-radius: 50%;

    animation: spin 1s linear infinite;

}



/* Hover states for interactive elements */

.result-card:hover .result-icon {

    transform: scale(1.1);

    transition: transform 0.3s ease;

}



.seo-service-card:hover .service-icon {

    transform: scale(1.1);

    transition: transform 0.3s ease;

}



.metric:hover {

    transform: scale(1.05);

    transition: transform 0.3s ease;

}



/* Special animations for SEO analytics */

.seo-analytics:hover .metric-value {

    color: var(--secondary);

    transition: color 0.3s ease;

}



.chart-bars:hover .bar {

    opacity: 0.8;

    transition: opacity 0.3s ease;

}



@keyframes pulse {

    0%, 100% {

        transform: scale(1);

    }

    50% {

        transform: scale(1.05);

    }

}



@keyframes float {

    0%, 100% {

        transform: translateY(0px);

    }

    50% {

        transform: translateY(-10px);

    }

}
