/* ==========================================================================
   REDMONO BRANDING DESIGN SYSTEM (Based on redmono.com/tr - Sticky Sliding Deck)
   ========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,700;1,9..40,400&family=Space+Grotesk:wght@400;500;600;700;900&display=swap');

:root {
    /* redmono.com brand colors */
    --red: #f00;
    --black: #080808;
    --white: #fff;
    --soft: #f4f1eb;
    
    /* System Mapping (Premium Dark Style to avoid eye strain) */
    --bg-primary: var(--black);
    --bg-secondary: rgba(255, 255, 255, 0.05);
    --bg-tertiary: #121215;
    
    --text-primary: var(--white);
    --text-secondary: rgba(255, 255, 255, 0.85);
    --text-muted: rgba(255, 255, 255, 0.5);
    
    --border-color: rgba(255, 255, 255, 0.15);
    --border-color-hover: rgba(255, 255, 255, 0.35);
    
    --font-heading: 'Space Grotesk', sans-serif;
    --font-body: 'DM Sans', sans-serif;
    
    --transition-fast: 0.2s cubic-bezier(0.16, 1, 0.3, 1);
    --transition-normal: 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    
    --container-width: 1200px;
    --border-radius-sm: 0px; /* Redmono sharp corner theme */
    --border-radius-md: 0px;
    --border-radius-lg: 0px;
}

/* ==========================================================================
   RESET & BASE STYLES
   ========================================================================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-body);
    background-color: var(--bg-primary);
    color: var(--text-primary);
    line-height: 1.6;
    overflow-x: hidden;
}

.container {
    width: 100%;
    max-width: var(--container-width);
    margin: 0 auto;
    padding: 0 24px;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 700;
    letter-spacing: -0.04em;
    text-transform: lowercase; /* redmono.com signature lowercase headings */
}

/* Red Dot accent matching redmono.com headings */
.red-square-dot {
    display: inline-block;
    width: 0.18em;
    height: 0.18em;
    background-color: var(--red);
    margin-left: 0.25em;
    vertical-align: baseline;
}

/* ==========================================================================
   STICKY SLIDING DECK STYLING (redmono.com/tr Style)
   ========================================================================== */
.hero-section {
    position: relative;
    z-index: 1;
    min-height: auto;
    background-color: #080808; /* Pure dark start */
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding: 30px 0 50px;
}

.pricing-section {
    position: relative;
    z-index: 2;
    background-color: #0d0d10; /* Slightly lighter deep card background */
    border-top-left-radius: 32px;
    border-top-right-radius: 32px;
    box-shadow: 0 -30px 60px rgba(0, 0, 0, 0.6);
    margin-top: -32px; /* Overlap border radius of previous card */
    padding: 80px 0;
}

.custom-quote-section {
    position: relative;
    z-index: 3;
    background-color: #121216; /* Lighter grey dark section */
    border-top-left-radius: 32px;
    border-top-right-radius: 32px;
    box-shadow: 0 -30px 60px rgba(0, 0, 0, 0.7);
    margin-top: -32px;
    padding: 80px 0;
}

/* Sticky Overlapping Card Deck Layout (min-width: 992px) */
@media (min-width: 992px) {
    .hero-section {
        position: sticky;
        top: 0;
        height: 100vh;
        justify-content: space-between;
        padding-bottom: 0;
    }
    
    .hero-content-wrapper {
        flex-grow: 1;
        display: flex;
        flex-direction: column;
        align-items: center; /* Center content horizontally */
        text-align: center; /* Center texts */
        justify-content: center;
        padding-top: 0;
    }

    .pricing-section {
        position: sticky;
        top: -35vh; /* Balanced sticking point for laptops */
        height: 135vh; /* Balanced scroll height for laptops */
        display: flex;
        align-items: flex-start;
        padding: 7vh 0;
    }

    .custom-quote-section {
        position: sticky;
        top: -35vh;
        height: 120vh; /* Reduced bottom empty space for Section 2 on laptops */
        display: flex;
        align-items: flex-start;
        padding: 7vh 0;
    }
    
    /* Dynamic Optimization for Large Height Screens (Desktops) */
    @media (min-height: 900px) {
        .pricing-section {
            top: -15vh; /* Balanced sticking point for desktops */
            height: 115vh; /* Balanced scroll height for desktops */
            align-items: flex-start;
            padding: 7vh 0;
        }
        
        .custom-quote-section {
            top: -15vh;
            height: 105vh; /* Reduced bottom empty space for Section 2 on desktops */
            align-items: flex-start;
            padding: 7vh 0;
        }
    }
}

/* ==========================================================================
   HEADER / MARKALAMA (REDMONO x YILKAR)
   ========================================================================== */
.b2b-header {
    padding: 30px 0 40px;
    border-bottom: 1px solid var(--border-color);
    background: transparent;
}

.b2b-header-container {
    display: flex;
    align-items: center;
}

.b2b-partnership-logos {
    display: flex;
    align-items: center;
    gap: 20px;
}

.b2b-logo {
    display: flex;
    align-items: center;
    gap: 10px;
}

.brand-mark {
    width: 1.5rem;
    height: 1.5rem;
    background: var(--red);
    display: inline-block;
    flex-shrink: 0;
}

.brand-rm {
    font-family: var(--font-heading);
    font-weight: 900;
    font-size: 1.35rem;
    letter-spacing: -0.04em;
    color: var(--white);
    text-transform: lowercase;
}

.b2b-link-x {
    font-family: var(--font-heading);
    font-size: 1.35rem;
    font-weight: 900;
    color: rgba(255, 255, 255, 0.3);
    line-height: 1;
}

.y-logo-img {
    display: block;
    opacity: 0.95;
    transition: opacity var(--transition-fast);
}

.y-logo-img:hover {
    opacity: 1;
}

/* ==========================================================================
   HERO / INTRO SECTION CONTENT
   ========================================================================== */
.hero-content-wrapper {
    padding-top: 60px;
    display: flex;
    flex-direction: column;
    align-items: center; /* Center horizontally on mobile */
    text-align: center; /* Center texts on mobile */
}

.badge-new {
    display: inline-block;
    font-family: var(--font-heading);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    color: var(--red);
    border: 1px solid var(--red);
    padding: 6px 14px;
    margin-bottom: 24px;
    text-transform: uppercase;
}

.hero-title {
    font-size: clamp(2.5rem, 5.5vw, 4.2rem);
    line-height: 1.05;
    margin-bottom: 24px;
    color: var(--white);
}

/* B2B Partnership Logos inside main H1 title */
.hero-title.b2b-partnership-logos {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    width: 100%;
    margin-bottom: 30px;
}

.hero-title .brand-mark {
    width: 2.2rem;
    height: 2.2rem;
}

.hero-title .brand-rm {
    font-size: 2.2rem;
}

.hero-title .b2b-link-x {
    font-size: 2rem;
}

.hero-title .y-logo-img {
    height: 38px;
    width: auto;
}

@media (max-width: 768px) {
    .hero-title.b2b-partnership-logos {
        gap: 12px;
    }
    .hero-title .brand-mark {
        width: 1.6rem;
        height: 1.6rem;
    }
    .hero-title .brand-rm {
        font-size: 1.6rem;
    }
    .hero-title .b2b-link-x {
        font-size: 1.4rem;
    }
    .hero-title .y-logo-img {
        height: 26px;
    }
}

.hero-subtitle {
    font-size: clamp(1rem, 1.5vw, 1.2rem);
    color: var(--text-secondary);
    max-width: 800px;
    margin-left: auto; /* Center block horizontally */
    margin-right: auto; /* Center block horizontally */
    margin-bottom: 45px;
    font-weight: 400;
    line-height: 1.6;
}

.intro-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border-color);
    padding: 40px;
    width: 100%;
}

.intro-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 30px;
}

.intro-item {
    display: flex;
    flex-direction: column;
    align-items: center; /* Center item content horizontally */
    text-align: center; /* Center item text */
    gap: 4px;
}

.intro-item strong {
    font-family: var(--font-heading);
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-muted);
}

.intro-item span {
    font-size: 1.05rem;
    color: var(--white);
    font-weight: 500;
}

/* ==========================================================================
   SECTION HEADER
   ========================================================================== */
.section-header {
    margin-bottom: 60px;
}

.section-header.text-center {
    text-align: center;
}

.section-tag {
    font-family: var(--font-heading);
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--red);
    letter-spacing: 0.15em;
    text-transform: uppercase;
    display: block;
    margin-bottom: 12px;
}

.section-title {
    font-size: clamp(2rem, 3.8vw, 3rem);
    margin-bottom: 16px;
    color: var(--white);
}

.section-desc {
    color: var(--text-secondary);
    font-size: 1.05rem;
    max-width: 650px;
    margin: 0 auto;
}

/* ==========================================================================
   PRICING CONTAINER & CARDS (REDMONO SERVICE-CARD HOVER FILL EFFECT)
   ========================================================================== */
.pricing-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 24px;
    align-items: stretch;
}

.pricing-card {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--border-color);
    padding: 50px 40px;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden; /* Crucial for red slide-up fill */
    z-index: 1;
    color: var(--white);
    transition: color var(--transition-normal), 
                box-shadow var(--transition-normal),
                transform var(--transition-normal);
}

/* Slide-up red background panel matching redmono.com/tr */
.pricing-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: var(--red);
    z-index: -1;
    transform: translateY(101%);
    transition: transform var(--transition-normal);
}

/* Card Hover States */
.pricing-card:not(.featured):hover::before {
    transform: translateY(0);
}

.pricing-card:not(.featured):hover {
    color: var(--white);
    transform: translateY(-4px);
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.4), 0 0 0 1px var(--red);
}

.pricing-card:not(.featured):hover .package-name {
    color: rgba(255, 255, 255, 0.6);
}

.pricing-card:not(.featured):hover .features-list li,
.pricing-card:not(.featured):hover .currency,
.pricing-card:not(.featured):hover .price-val,
.pricing-card:not(.featured):hover .period,
.pricing-card:not(.featured):hover .features-list li strong {
    color: var(--white);
}

.pricing-card:not(.featured):hover .icon-wrapper {
    background: rgba(255, 255, 255, 0.15);
    color: var(--white);
    border-color: var(--white);
}

.pricing-card:not(.featured):hover .check-icon {
    color: var(--white);
}

.pricing-card:not(.featured):hover .btn-card-select {
    border-color: var(--white);
    background: var(--white);
    color: var(--red);
}

.card-header {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 30px;
}

.icon-wrapper {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border-color);
    background: transparent;
    color: var(--red);
    transition: all var(--transition-fast);
}

.package-name {
    font-family: var(--font-heading);
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: var(--text-muted);
    transition: color var(--transition-fast);
}

.card-price-area {
    margin-bottom: 35px;
    display: flex;
    align-items: baseline;
}

.currency {
    font-family: var(--font-heading);
    font-size: 1.6rem;
    font-weight: 700;
    margin-right: 4px;
    color: var(--white);
    transition: color var(--transition-fast);
}

.price-val {
    font-size: 3.4rem;
    font-weight: 700;
    font-family: var(--font-heading);
    line-height: 1;
    color: var(--white);
    transition: color var(--transition-fast);
}

.period {
    font-size: 0.85rem;
    color: var(--text-muted);
    margin-left: 8px;
    font-weight: 500;
    transition: color var(--transition-fast);
}

.features-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 40px;
    flex-grow: 1;
}

.features-list li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 0.92rem;
    color: var(--text-secondary);
    transition: color var(--transition-fast);
}

.features-list li strong {
    color: var(--white);
    font-weight: 700;
    transition: color var(--transition-fast);
}

.check-icon {
    flex-shrink: 0;
    margin-top: 4px;
    color: var(--red);
    transition: color var(--transition-fast);
}

.card-footer {
    margin-top: auto;
}

.btn-card-select {
    width: 100%;
    padding: 16px;
    border: 1px solid var(--white);
    background: transparent;
    color: var(--white);
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 0.8rem;
    cursor: pointer;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    transition: all var(--transition-fast);
}

.btn-card-select:hover {
    background: var(--white);
    color: var(--red);
    border-color: var(--white);
}

/* FEATURED CARD (2. PAKET - SOLID WHITE CARD IN DARK GRIDS) */
.pricing-card.featured {
    background: var(--white);
    border-color: var(--white);
    color: var(--red);
}

.pricing-card.featured .icon-wrapper {
    border-color: rgba(255, 0, 0, 0.15);
    color: var(--red);
}

.pricing-card.featured .package-name {
    color: rgba(255, 0, 0, 0.55);
}

.pricing-card.featured .features-list li {
    color: rgba(0, 0, 0, 0.85);
}

.pricing-card.featured .features-list li strong,
.pricing-card.featured .price-val,
.pricing-card.featured .currency {
    color: var(--red);
}

.pricing-card.featured .period {
    color: rgba(255, 0, 0, 0.6);
}

.pricing-card.featured .check-icon {
    color: var(--red);
}

.pricing-card.featured .btn-featured-select {
    background: var(--red);
    border-color: var(--red);
    color: var(--white);
}

.pricing-card.featured .btn-featured-select:hover {
    background: var(--black);
    border-color: var(--black);
    color: var(--white);
}

.pricing-card.featured:hover {
    transform: translateY(-4px);
    box-shadow: 0 15px 40px rgba(255, 255, 255, 0.12);
}

/* Popular Badge Tag */
.popular-tag {
    position: absolute;
    top: 24px;
    right: 24px;
    font-family: var(--font-heading);
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    padding: 6px 12px;
    background: var(--red);
    color: var(--white);
}

/* ==========================================================================
   DYNAMIC CUSTOM QUOTE WIZARD (CONFIGURATOR - DEEP GREY DECK)
   ========================================================================== */
.wizard-grid {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: 40px;
    margin-top: 50px;
}

@media (max-width: 992px) {
    .wizard-grid {
        grid-template-columns: 1fr;
    }
}

.wizard-controls {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 40px;
    display: flex;
    flex-direction: column;
    gap: 35px;
}

.control-group {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

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

.control-label-row label {
    font-size: 1rem;
    font-weight: 500;
    color: var(--white);
}

.control-value {
    font-family: var(--font-heading);
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--red);
}

/* White range slider */
.range-slider {
    -webkit-appearance: none;
    width: 100%;
    height: 2px;
    background: rgba(255, 255, 255, 0.15);
    outline: none;
}

.range-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 18px;
    height: 18px;
    background: var(--white);
    cursor: pointer;
    border: none;
    border-radius: 0px;
    transition: transform var(--transition-fast);
}

.range-slider::-webkit-slider-thumb:hover {
    transform: scale(1.15);
}

.range-slider::-moz-range-thumb {
    width: 18px;
    height: 18px;
    background: var(--white);
    cursor: pointer;
    border: none;
    border-radius: 0px;
    transition: transform var(--transition-fast);
}

.range-slider::-moz-range-thumb:hover {
    transform: scale(1.15);
}

.range-marks {
    display: flex;
    justify-content: space-between;
    font-family: var(--font-heading);
    font-size: 0.7rem;
    color: rgba(255, 255, 255, 0.4);
    font-weight: 500;
}

/* Switches Grid */
.switches-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 20px;
}

.switch-card {
    background: rgba(0, 0, 0, 0.2);
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: border-color var(--transition-fast);
}

.switch-card:hover {
    border-color: rgba(255, 255, 255, 0.25);
}

.switch-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    max-width: 75%;
}

.switch-title {
    font-family: var(--font-heading);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--white);
}

.switch-desc {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.45);
}

.switch {
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px;
    flex-shrink: 0;
}

.switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.slider-switch {
    position: absolute;
    cursor: pointer;
    top: 0; left: 0; right: 0; bottom: 0;
    background-color: transparent;
    border: 1px solid rgba(255, 255, 255, 0.15);
    transition: .3s cubic-bezier(0.16, 1, 0.3, 1);
    border-radius: 0px;
}

.slider-switch:before {
    position: absolute;
    content: "";
    height: 14px;
    width: 14px;
    left: 4px;
    bottom: 4px;
    background-color: var(--white);
    transition: .3s cubic-bezier(0.16, 1, 0.3, 1);
    border-radius: 0px;
}

.switch input:checked + .slider-switch {
    background-color: var(--red);
    border-color: var(--red);
}

.switch input:checked + .slider-switch:before {
    transform: translateX(20px);
}

/* Configurator Live Summary Board */
.wizard-summary-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 50px 40px;
    display: flex;
    flex-direction: column;
    position: sticky;
    top: 40px;
    height: fit-content;
}

.summary-header {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    padding-bottom: 20px;
    margin-bottom: 25px;
}

.summary-title {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--white);
}

.summary-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 30px;
}

.summary-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.92rem;
    color: rgba(255, 255, 255, 0.7);
}

.summary-row strong {
    color: var(--white);
}

.summary-total-area {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 30px;
    margin-bottom: 30px;
}

.total-label {
    font-family: var(--font-heading);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    color: rgba(255, 255, 255, 0.4);
    text-transform: uppercase;
    margin-bottom: 8px;
    display: block;
}

.total-price-box {
    display: flex;
    align-items: baseline;
}

.total-price-box .currency {
    font-size: 2rem;
    color: var(--red);
    margin-right: 4px;
}

.total-price-box .price-val {
    font-size: 3.8rem;
    color: var(--red);
}

.btn-primary {
    width: 100%;
    padding: 18px;
    border: none;
    background: var(--white);
    color: var(--black);
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 0.85rem;
    cursor: pointer;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    transition: all var(--transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.btn-primary:hover {
    background: var(--red);
    color: var(--white);
    transform: translateY(-2px);
}

/* ==========================================================================
   DETAIL SECTIONS (Bölüm 3-6: Hizmet Detayları, Süreç, Neden, CTA)
   ========================================================================== */
.detail-section {
    position: relative;
    z-index: 4;
    padding: 100px 0;
    background: #0d0d0d;
}

.detail-section-dark {
    background: #080808;
}

.detail-section-cta {
    background: linear-gradient(135deg, #111 0%, #1a0505 50%, #0d0d0d 100%);
}

/* 6-column service grid */
.detail-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-top: 60px;
}

@media (max-width: 992px) {
    .detail-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .detail-grid {
        grid-template-columns: 1fr;
    }
}

.detail-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 36px 30px;
    transition: border-color 0.3s ease, transform 0.3s ease;
}

.detail-card:hover {
    border-color: rgba(220, 20, 60, 0.4);
    transform: translateY(-4px);
}

.detail-card-icon {
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}

.detail-card-icon.color-red {
    color: var(--red);
    background: rgba(220, 20, 60, 0.1);
}

.detail-card-icon.color-yellow {
    color: #f5c518;
    background: rgba(245, 197, 24, 0.08);
}

.detail-card-icon.color-pink {
    color: #ff6b9d;
    background: rgba(255, 107, 157, 0.08);
}

.detail-card-title {
    font-family: var(--font-heading);
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--white);
    margin-bottom: 12px;
}

.detail-card-desc {
    font-size: 0.9rem;
    color: var(--text-secondary);
    line-height: 1.6;
    margin-bottom: 20px;
}

.detail-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.detail-list li {
    font-size: 0.88rem;
    color: var(--text-muted);
    padding-left: 16px;
    position: relative;
    line-height: 1.5;
}

.detail-list li::before {
    content: '—';
    position: absolute;
    left: 0;
    color: var(--red);
    font-size: 0.75rem;
}

/* Process Timeline */
.process-timeline {
    margin-top: 60px;
    display: flex;
    flex-direction: column;
    gap: 0;
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
}

.process-step {
    display: flex;
    align-items: flex-start;
    gap: 32px;
    padding: 36px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    transition: background 0.3s ease;
}

.process-step:last-child {
    border-bottom: none;
}

.process-step:hover .process-step-num {
    color: var(--red);
    border-color: var(--red);
}

.process-step-num {
    font-family: var(--font-heading);
    font-size: 2.4rem;
    font-weight: 900;
    color: rgba(255, 255, 255, 0.15);
    border: 1px solid rgba(255, 255, 255, 0.1);
    width: 72px;
    height: 72px;
    min-width: 72px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.3s ease, border-color 0.3s ease;
}

.process-step-content {
    flex: 1;
    padding-top: 8px;
}

.process-step-content h3 {
    font-family: var(--font-heading);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--white);
    margin-bottom: 10px;
}

.process-step-content p {
    font-size: 0.95rem;
    color: var(--text-secondary);
    line-height: 1.7;
    max-width: 640px;
}

.process-step-time {
    display: inline-block;
    margin-top: 12px;
    font-size: 0.75rem;
    font-family: var(--font-heading);
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--red);
    background: rgba(220, 20, 60, 0.1);
    padding: 4px 12px;
}

@media (max-width: 600px) {
    .process-step {
        flex-direction: column;
        gap: 16px;
    }
    .process-step-num {
        width: 52px;
        height: 52px;
        min-width: 52px;
        font-size: 1.6rem;
    }
}

/* Why Grid */
.why-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-top: 60px;
}

@media (max-width: 992px) {
    .why-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .why-grid {
        grid-template-columns: 1fr;
    }
}

.why-card {
    padding: 36px 28px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.02);
    transition: border-color 0.3s, transform 0.3s;
}

.why-card:hover {
    border-color: rgba(220, 20, 60, 0.35);
    transform: translateY(-3px);
}

.why-icon {
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--red);
    background: rgba(220, 20, 60, 0.08);
    margin-bottom: 20px;
}

.why-card h3 {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--white);
    margin-bottom: 10px;
}

.why-card p {
    font-size: 0.9rem;
    color: var(--text-secondary);
    line-height: 1.65;
}

/* CTA Block */
.cta-block {
    text-align: center;
    max-width: 760px;
    margin: 0 auto;
    padding: 20px 0 40px;
}

.cta-title {
    font-family: var(--font-heading);
    font-size: clamp(2.2rem, 5vw, 3.6rem);
    font-weight: 900;
    color: var(--white);
    margin: 20px 0 16px;
    line-height: 1.1;
}

.cta-subtitle {
    font-size: 1.05rem;
    color: var(--text-secondary);
    line-height: 1.65;
    margin-bottom: 50px;
}

.cta-steps-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-bottom: 48px;
    flex-wrap: wrap;
}

.cta-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    max-width: 180px;
}

.cta-step-num {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--red);
    color: var(--white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
}

.cta-step-label {
    font-size: 0.88rem;
    color: var(--text-secondary);
    text-align: center;
    line-height: 1.5;
}

.cta-step-arrow {
    font-size: 1.6rem;
    color: rgba(255,255,255,0.2);
    margin-top: -20px;
}

@media (max-width: 600px) {
    .cta-step-arrow {
        transform: rotate(90deg);
    }
}

.cta-actions {
    display: flex;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 36px;
}

.btn-outline-white {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 16px 32px;
    border: 1px solid rgba(255,255,255,0.25);
    color: var(--white);
    font-family: var(--font-heading);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
    transition: border-color 0.3s, background 0.3s, transform 0.2s;
}

.btn-outline-white:hover {
    border-color: var(--white);
    background: rgba(255,255,255,0.06);
    transform: translateY(-2px);
}

.cta-contact-strip {
    display: flex;
    align-items: center;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    font-size: 0.9rem;
    color: var(--text-muted);
}

.cta-contact-strip a {
    color: var(--text-secondary);
    text-decoration: none;
    transition: color 0.2s;
}

.cta-contact-strip a:hover {
    color: var(--white);
}

.cta-contact-divider {
    color: rgba(255,255,255,0.2);
}

/* ==========================================================================
   FOOTER (PREMIUM REDMONO DESIGN)
   ========================================================================== */

.b2b-footer {
    position: relative;
    z-index: 4; /* Higher than custom-quote-section (z-index: 3) to overlap it */
    padding: 80px 0 50px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    background: #080808; /* Fixed dark footer style */
    color: var(--white);
    margin-top: -32px; /* Overlap border radius of previous card */
    border-top-left-radius: 32px;
    border-top-right-radius: 32px;
    box-shadow: 0 -30px 60px rgba(0, 0, 0, 0.8);
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr;
    gap: 50px;
    margin-bottom: 60px;
}

@media (max-width: 768px) {
    /* Section and Spacing Optimizations */
    .hero-section,
    .pricing-section,
    .custom-quote-section {
        padding: 50px 0;
        min-height: auto;
    }
    
    .section-header {
        margin-bottom: 30px;
    }
    
    .section-title {
        font-size: 1.8rem;
    }
    
    .section-desc {
        font-size: 0.9rem;
        line-height: 1.5;
    }

    /* Pricing Cards Mobile Layout */
    .pricing-card {
        padding: 30px 20px;
    }
    
    .pricing-card .package-name {
        font-size: 1.1rem;
    }
    
    .pricing-card .price-val {
        font-size: 2.6rem;
    }
    
    .pricing-card .features-list {
        margin-bottom: 25px;
        gap: 12px;
    }
    
    .pricing-card .features-list li {
        font-size: 0.85rem;
    }

    /* Wizard (Configurator) Mobile Layout */
    .wizard-controls {
        padding: 24px 16px;
        gap: 25px;
    }
    
    .control-label-row label {
        font-size: 0.9rem;
    }
    
    .control-value {
        font-size: 1.3rem;
    }
    
    .wizard-summary-card {
        padding: 25px 20px;
    }
    
    .summary-total-area {
        padding-top: 20px;
        margin-top: 20px;
    }
    
    .total-price-box .price-val {
        font-size: 2.6rem;
    }

    /* Footer Mobile Layout */
    .footer-grid {
        grid-template-columns: 1fr;
        gap: 35px;
    }
    
    .footer-bottom {
        flex-direction: column;
        text-align: center;
        gap: 15px;
    }
}

.footer-brand-col .brand-pitch {
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1.6;
    max-width: 320px;
    margin-top: 15px;
}

.footer-links-col h4,
.footer-contact-col h4 {
    font-family: var(--font-heading);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--red);
    margin-bottom: 20px;
}

.footer-links-col ul,
.footer-contact-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.footer-links-col ul li a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    font-size: 0.88rem;
    transition: color var(--transition-fast);
    text-transform: lowercase;
}

.footer-links-col ul li a:hover {
    color: var(--white);
}

.footer-contact-col .contact-details li {
    font-size: 0.88rem;
    color: rgba(255, 255, 255, 0.7);
}

.footer-contact-col .contact-details li strong {
    color: var(--white);
    font-weight: 500;
}

.footer-contact-col .contact-details li a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.footer-contact-col .contact-details li a:hover {
    color: var(--white);
}

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 30px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px;
}

.footer-bottom .copyright {
    font-family: var(--font-heading);
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-size: 0.65rem;
    color: rgba(255, 255, 255, 0.4);
}

.footer-bottom .partnership-note {
    font-family: var(--font-heading);
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    color: var(--red);
    text-transform: lowercase;
}
