/**

 * Inner Pages Styles - Dịch Vụ, Giới Thiệu, và các trang con

 * 

 * @package ATH_ATRAHI_DESIGN

 * @version 3.0

 */



/* =================================================================

   BASE STYLES - Inner Pages

   ================================================================= */

.page-main {

    background: var(--ath-dark, #1a1a1a);

    color: #fff;

    padding-top: 0;

}



/* =================================================================

   SERVICES MAIN PAGE

   ================================================================= */

.services-main-page {

    background: linear-gradient(180deg, #1a1a1a 0%, #0f0f0f 100%);

}



/* Hero */

.services-hero {

    padding: 140px 0 80px;

    background: linear-gradient(180deg, rgba(185, 157, 99, 0.08) 0%, transparent 100%);

    position: relative;

}



.services-hero::before {

    content: '';

    position: absolute;

    top: 0;

    left: 0;

    right: 0;

    bottom: 0;

    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23b99d63' fill-opacity='0.03'%3E%3Ccircle cx='30' cy='30' r='1.5'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");

    pointer-events: none;

}



.services-hero .hero-content {

    text-align: center;

    max-width: 800px;

    margin: 0 auto;

    position: relative;

    z-index: 1;

}



.services-hero .hero-badge {

    display: inline-flex;

    align-items: center;

    gap: 8px;

    padding: 8px 16px;

    background: rgba(185, 157, 99, 0.1);

    border: 1px solid rgba(185, 157, 99, 0.3);

    border-radius: 50px;

    font-size: 14px;

    color: var(--ath-gold, #b99d63);

    margin-bottom: 24px;

}



.services-hero .hero-badge .badge-dot {

    width: 8px;

    height: 8px;

    background: var(--ath-gold, #b99d63);

    border-radius: 50%;

    animation: pulse 2s ease-in-out infinite;

}



.services-hero .hero-title {

    font-family: 'Playfair Display', serif;

    font-size: clamp(2.5rem, 5vw, 4rem);

    font-weight: 700;

    line-height: 1.2;

    margin-bottom: 20px;

    color: #fff;

}



.services-hero .hero-desc {

    font-size: 1.125rem;

    color: rgba(255, 255, 255, 0.7);

    line-height: 1.8;

    margin-bottom: 40px;

}



.services-hero .hero-stats {

    display: flex;

    justify-content: center;

    gap: 60px;

    flex-wrap: wrap;

}



.services-hero .stat-item {

    text-align: center;

}



.services-hero .stat-number {

    display: block;

    font-family: 'Playfair Display', serif;

    font-size: 3rem;

    font-weight: 700;

    color: var(--ath-gold, #b99d63);

    line-height: 1;

}



.services-hero .stat-label {

    font-size: 14px;

    color: rgba(255, 255, 255, 0.6);

    text-transform: uppercase;

    letter-spacing: 1px;

    margin-top: 8px;

}



/* Services Grid Section */

.services-grid-section {

    padding: 100px 0;

}



.services-list {

    display: flex;

    flex-direction: column;

    gap: 100px;

}



/* Service Block */

.service-block {

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: 60px;

    align-items: center;

    padding: 40px;

    background: rgba(255, 255, 255, 0.02);

    border: 1px solid rgba(255, 255, 255, 0.06);

    border-radius: 20px;

    transition: all 0.4s ease;

}



.service-block:hover {

    background: rgba(185, 157, 99, 0.05);

    border-color: rgba(185, 157, 99, 0.15);

}



.service-block.reverse {

    direction: rtl;

}



.service-block.reverse > * {

    direction: ltr;

}



/* Service Image */

.service-image {

    position: relative;

    border-radius: 16px;

    overflow: hidden;

}



.service-image img {

    width: 100%;

    height: 400px;

    object-fit: cover;

    transition: transform 0.5s ease;

}



.service-block:hover .service-image img {

    transform: scale(1.05);

}



.service-badge {

    position: absolute;

    bottom: 20px;

    left: 20px;

    padding: 12px 20px;

    background: rgba(26, 26, 26, 0.9);

    backdrop-filter: blur(10px);

    border-radius: 10px;

    border: 1px solid rgba(185, 157, 99, 0.3);

    text-align: center;

}



.service-badge .badge-number {

    display: block;

    font-family: 'Playfair Display', serif;

    font-size: 1.5rem;

    font-weight: 700;

    color: var(--ath-gold, #b99d63);

    line-height: 1;

}



.service-badge .badge-text {

    font-size: 12px;

    color: rgba(255, 255, 255, 0.7);

    text-transform: uppercase;

    letter-spacing: 1px;

}



/* Service Content */

.service-content {

    padding: 20px 0;

}



.service-content .service-icon {

    font-size: 3rem;

    display: block;

    margin-bottom: 16px;

}



.service-content .service-title {

    font-family: 'Playfair Display', serif;

    font-size: 2rem;

    font-weight: 700;

    color: #fff;

    margin-bottom: 16px;

}



.service-content .service-desc {

    font-size: 1rem;

    color: rgba(255, 255, 255, 0.7);

    line-height: 1.8;

    margin-bottom: 24px;

}



.service-features {

    list-style: none;

    padding: 0;

    margin: 0 0 30px;

    display: grid;

    gap: 12px;

}



.service-features li {

    display: flex;

    align-items: center;

    gap: 12px;

    color: rgba(255, 255, 255, 0.8);

    font-size: 15px;

}



.service-features li svg {

    width: 18px;

    height: 18px;

    color: var(--ath-gold, #b99d63);

    flex-shrink: 0;

}



.service-buttons {

    display: flex;

    gap: 16px;

    flex-wrap: wrap;

}



/* Process Section */

.services-process {

    padding: 100px 0;

    background: rgba(185, 157, 99, 0.03);

}



.process-timeline {

    display: flex;

    justify-content: center;

    gap: 20px;

    flex-wrap: wrap;

    margin-top: 60px;

}



.process-step {

    flex: 1;

    min-width: 180px;

    max-width: 220px;

    padding: 30px 20px;

    background: rgba(255, 255, 255, 0.02);

    border: 1px solid rgba(255, 255, 255, 0.06);

    border-radius: 16px;

    text-align: center;

    position: relative;

    transition: all 0.3s ease;

}



.process-step:hover {

    background: rgba(185, 157, 99, 0.08);

    border-color: rgba(185, 157, 99, 0.2);

    transform: translateY(-5px);

}



.process-step .step-icon {

    font-size: 2.5rem;

    margin-bottom: 10px;

}



.process-step .step-number {

    display: inline-block;

    width: 40px;

    height: 40px;

    line-height: 40px;

    background: linear-gradient(135deg, var(--ath-gold, #b99d63), #d4b87a);

    color: #1a1a1a;

    border-radius: 50%;

    font-weight: 700;

    font-size: 14px;

    margin-bottom: 16px;

}



.process-step .step-title {

    font-family: 'Playfair Display', serif;

    font-size: 1.25rem;

    font-weight: 600;

    color: #fff;

    margin-bottom: 8px;

}



.process-step .step-desc {

    font-size: 14px;

    color: rgba(255, 255, 255, 0.6);

}



/* Why Section */

.services-why {

    padding: 100px 0;

}



.why-grid {

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: 60px;

    align-items: center;

}



.why-content .section-title {

    margin-bottom: 16px;

}



.why-content .section-desc {

    color: rgba(255, 255, 255, 0.7);

    margin-bottom: 40px;

}



.why-features {

    display: grid;

    gap: 24px;

}



.why-item {

    display: flex;

    gap: 16px;

    padding: 20px;

    background: rgba(255, 255, 255, 0.02);

    border: 1px solid rgba(255, 255, 255, 0.06);

    border-radius: 12px;

    transition: all 0.3s ease;

}



.why-item:hover {

    background: rgba(185, 157, 99, 0.08);

    border-color: rgba(185, 157, 99, 0.2);

}



.why-item .why-icon {

    font-size: 2rem;

    flex-shrink: 0;

}



.why-item h4 {

    font-size: 1.1rem;

    font-weight: 600;

    color: #fff;

    margin-bottom: 6px;

}



.why-item p {

    font-size: 14px;

    color: rgba(255, 255, 255, 0.6);

    margin: 0;

}



/* Stats Image */

.why-stats-image {

    position: relative;

}



.why-stats-image img {

    width: 100%;

    border-radius: 16px;

}



.floating-stats {

    position: absolute;

    bottom: -30px;

    left: 50%;

    transform: translateX(-50%);

    display: flex;

    gap: 20px;

    padding: 20px;

    background: rgba(26, 26, 26, 0.95);

    backdrop-filter: blur(20px);

    border-radius: 16px;

    border: 1px solid rgba(185, 157, 99, 0.3);

}



.floating-stat {

    text-align: center;

    padding: 10px 20px;

}



.floating-stat .stat-number {

    display: block;

    font-family: 'Playfair Display', serif;

    font-size: 2rem;

    font-weight: 700;

    color: var(--ath-gold, #b99d63);

    line-height: 1;

}



.floating-stat .stat-label {

    font-size: 12px;

    color: rgba(255, 255, 255, 0.6);

}



/* CTA Section */

.services-cta {

    padding: 100px 0;

    background: linear-gradient(135deg, rgba(185, 157, 99, 0.1) 0%, rgba(185, 157, 99, 0.05) 100%);

}



.cta-box {

    display: flex;

    align-items: center;

    justify-content: space-between;

    gap: 40px;

    padding: 60px 80px;

    background: linear-gradient(135deg, var(--ath-gold, #b99d63), #d4b87a);

    border-radius: 24px;

    position: relative;

    overflow: hidden;

}



.cta-box::before {

    content: '';

    position: absolute;

    top: 0;

    right: 0;

    width: 300px;

    height: 300px;

    background: rgba(255, 255, 255, 0.1);

    border-radius: 50%;

    transform: translate(50%, -50%);

}



.cta-content h2 {

    font-family: 'Playfair Display', serif;

    font-size: 2.5rem;

    font-weight: 700;

    color: #1a1a1a;

    margin-bottom: 10px;

}



.cta-content p {

    font-size: 1.1rem;

    color: rgba(26, 26, 26, 0.8);

    margin: 0;

}



.cta-buttons {

    display: flex;

    gap: 16px;

    flex-shrink: 0;

    position: relative;

    z-index: 1;

}



.cta-buttons .btn-dark {

    background: #1a1a1a;

    color: #fff;

    padding: 16px 32px;

    border-radius: 12px;

    font-weight: 600;

    text-decoration: none;

    transition: all 0.3s ease;

    display: inline-flex;

    align-items: center;

    gap: 10px;

}



.cta-buttons .btn-dark:hover {

    background: #2a2a2a;

    transform: translateY(-2px);

}



.cta-buttons .btn-white {

    background: #fff;

    color: #1a1a1a;

    padding: 16px 32px;

    border-radius: 12px;

    font-weight: 600;

    text-decoration: none;

    transition: all 0.3s ease;

}



.cta-buttons .btn-white:hover {

    background: rgba(255, 255, 255, 0.9);

    transform: translateY(-2px);

}



/* =================================================================

   ABOUT PAGE / GIỚI THIỆU

   ================================================================= */

.about-page {

    background: linear-gradient(180deg, #1a1a1a 0%, #0f0f0f 100%);

}



/* Page Hero */

.page-hero {

    padding: 140px 0 80px;

    position: relative;

    overflow: hidden;

}



.page-hero-bg {

    position: absolute;

    top: 0;

    left: 0;

    right: 0;

    bottom: 0;

    background: linear-gradient(180deg, rgba(185, 157, 99, 0.08) 0%, transparent 50%);

    pointer-events: none;

}



.page-hero-grid {

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: 60px;

    align-items: center;

    position: relative;

    z-index: 1;

}



.page-hero-content {

    max-width: 600px;

}



.page-badge {

    display: inline-flex;

    align-items: center;

    gap: 10px;

    padding: 10px 20px;

    background: rgba(185, 157, 99, 0.1);

    border: 1px solid rgba(185, 157, 99, 0.3);

    border-radius: 50px;

    font-size: 14px;

    color: var(--ath-gold, #b99d63);

    margin-bottom: 24px;

}



.page-badge .badge-dot {

    width: 8px;

    height: 8px;

    background: var(--ath-gold, #b99d63);

    border-radius: 50%;

    animation: pulse 2s ease-in-out infinite;

}



.page-hero-title {

    font-family: 'Playfair Display', serif;

    font-size: clamp(2.5rem, 5vw, 4rem);

    font-weight: 700;

    line-height: 1.1;

    color: #fff;

    margin-bottom: 16px;

}



.page-hero-tagline {

    font-size: 1.25rem;

    color: var(--ath-gold, #b99d63);

    font-style: italic;

    margin-bottom: 20px;

}



.page-hero-desc {

    font-size: 1.125rem;

    color: rgba(255, 255, 255, 0.7);

    line-height: 1.8;

    margin-bottom: 30px;

}



.page-hero-cta {

    display: flex;

    gap: 16px;

    flex-wrap: wrap;

}



/* Hero Visual */

.page-hero-visual {

    position: relative;

}



.hero-image-wrapper {

    position: relative;

    border-radius: 20px;

    overflow: hidden;

}



.hero-main-img {

    width: 100%;

    height: auto;

    border-radius: 20px;

}



.hero-floating-card {

    position: absolute;

    bottom: 30px;

    left: 30px;

    padding: 20px 30px;

    background: rgba(26, 26, 26, 0.95);

    backdrop-filter: blur(20px);

    border-radius: 16px;

    border: 1px solid rgba(185, 157, 99, 0.3);

}



.hero-floating-card .floating-stat {

    text-align: center;

}



.hero-floating-card .stat-number {

    font-family: 'Playfair Display', serif;

    font-size: 2.5rem;

    font-weight: 700;

    color: var(--ath-gold, #b99d63);

    line-height: 1;

}



.hero-floating-card .stat-label {

    font-size: 12px;

    color: rgba(255, 255, 255, 0.6);

    text-transform: uppercase;

    letter-spacing: 1px;

}



/* About Sections */

.about-story,

.about-mission,

.about-values,

.about-team,

.about-stats,

.about-cta {

    padding: 100px 0;

}



.about-story {

    background: rgba(185, 157, 99, 0.03);

}



.about-grid {

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: 60px;

    align-items: center;

}



/* Stats Grid */

.stats-grid {

    display: grid;

    grid-template-columns: repeat(4, 1fr);

    gap: 30px;

}



.stat-card {

    text-align: center;

    padding: 40px 20px;

    background: #ffffff;

    border: 1px solid #e5e7eb;

    border-radius: 16px;

    transition: all 0.3s ease;

}



.stat-card:hover {

    background: rgba(185, 157, 99, 0.05);

    border-color: rgba(185, 157, 99, 0.3);

    transform: translateY(-5px);

}



.stat-card .stat-icon {

    font-size: 2.5rem;

    margin-bottom: 16px;

}



.stat-card .stat-number {

    font-family: 'Playfair Display', serif;

    font-size: 3rem;

    font-weight: 700;

    color: var(--ath-gold, #b99d63);

    line-height: 1;

    margin-bottom: 8px;

}



.stat-card .stat-label {

    font-size: 14px;

    color: #6b7280;

}



/* Values Grid */

.values-grid {

    display: grid;

    grid-template-columns: repeat(3, 1fr);

    gap: 30px;

    margin-top: 60px;

}



.value-card {

    padding: 40px 30px;

    background: rgba(255, 255, 255, 0.02);

    border: 1px solid rgba(255, 255, 255, 0.06);

    border-radius: 16px;

    text-align: center;

    transition: all 0.3s ease;

}



.value-card:hover {

    background: rgba(185, 157, 99, 0.08);

    border-color: rgba(185, 157, 99, 0.2);

    transform: translateY(-5px);

}



.value-card .value-icon {

    font-size: 3rem;

    margin-bottom: 20px;

}



.value-card h3 {

    font-family: 'Playfair Display', serif;

    font-size: 1.5rem;

    font-weight: 600;

    color: #fff;

    margin-bottom: 12px;

}



.value-card p {

    font-size: 15px;

    color: rgba(255, 255, 255, 0.6);

    line-height: 1.7;

}



/* =================================================================

   SERVICE DETAIL PAGES

   ================================================================= */

.service-detail-page {

    background: linear-gradient(180deg, #1a1a1a 0%, #0f0f0f 100%);

}



.service-hero {

    padding: 140px 0 80px;

    background: linear-gradient(180deg, rgba(185, 157, 99, 0.08) 0%, transparent 100%);

}



.service-hero .hero-grid {

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: 60px;

    align-items: center;

}



.service-hero .hero-content {

    max-width: 600px;

}



.service-hero .hero-badge {

    display: inline-flex;

    align-items: center;

    gap: 10px;

    padding: 10px 20px;

    background: rgba(185, 157, 99, 0.1);

    border: 1px solid rgba(185, 157, 99, 0.3);

    border-radius: 50px;

    font-size: 14px;

    color: var(--ath-gold, #b99d63);

    margin-bottom: 24px;

}



.service-hero .hero-title {

    font-family: 'Playfair Display', serif;

    font-size: clamp(2rem, 4vw, 3.5rem);

    font-weight: 700;

    line-height: 1.2;

    color: #fff;

    margin-bottom: 20px;

}



.service-hero .hero-desc {

    font-size: 1.1rem;

    color: rgba(255, 255, 255, 0.7);

    line-height: 1.8;

    margin-bottom: 24px;

}



.service-hero .hero-highlights {

    display: flex;

    gap: 20px;

    flex-wrap: wrap;

    margin-bottom: 30px;

}



.service-hero .highlight-item {

    display: flex;

    align-items: center;

    gap: 8px;

    padding: 10px 16px;

    background: rgba(255, 255, 255, 0.05);

    border-radius: 50px;

    font-size: 14px;

    color: rgba(255, 255, 255, 0.9);

}



.service-hero .hero-buttons {

    display: flex;

    gap: 16px;

    flex-wrap: wrap;

}



.service-hero .hero-image {

    position: relative;

    border-radius: 20px;

    overflow: hidden;

}



.service-hero .hero-image img {

    width: 100%;

    height: auto;

    border-radius: 20px;

}



.service-hero .hero-badge-box {

    position: absolute;

    bottom: 20px;

    left: 20px;

    padding: 16px 24px;

    background: rgba(26, 26, 26, 0.95);

    backdrop-filter: blur(20px);

    border-radius: 12px;

    border: 1px solid rgba(185, 157, 99, 0.3);

    text-align: center;

}



.service-hero .badge-number {

    display: block;

    font-family: 'Playfair Display', serif;

    font-size: 2rem;

    font-weight: 700;

    color: var(--ath-gold, #b99d63);

    line-height: 1;

}



.service-hero .badge-text {

    font-size: 12px;

    color: rgba(255, 255, 255, 0.6);

    text-transform: uppercase;

    letter-spacing: 1px;

}



/* Service Types */

.service-types {

    padding: 100px 0;

}



.types-grid {

    display: grid;

    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));

    gap: 24px;

    margin-top: 50px;

}



.type-card {

    padding: 30px 24px;

    background: rgba(255, 255, 255, 0.02);

    border: 1px solid rgba(255, 255, 255, 0.06);

    border-radius: 16px;

    text-align: center;

    transition: all 0.3s ease;

}



.type-card:hover {

    background: rgba(185, 157, 99, 0.08);

    border-color: rgba(185, 157, 99, 0.2);

    transform: translateY(-5px);

}



.type-card .type-icon {

    font-size: 2.5rem;

    display: block;

    margin-bottom: 16px;

}



.type-card h3 {

    font-size: 1.1rem;

    font-weight: 600;

    color: #fff;

    margin-bottom: 8px;

}



.type-card p {

    font-size: 14px;

    color: rgba(255, 255, 255, 0.6);

    margin: 0;

}



/* Service Features */

.service-features {

    padding: 100px 0;

    background: rgba(185, 157, 99, 0.03);

}



.features-grid {

    display: grid;

    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));

    gap: 30px;

    margin-top: 50px;

}



.feature-card {

    display: flex;

    gap: 16px;

    padding: 24px;

    background: rgba(255, 255, 255, 0.02);

    border: 1px solid rgba(255, 255, 255, 0.06);

    border-radius: 12px;

    transition: all 0.3s ease;

}



.feature-card:hover {

    background: rgba(185, 157, 99, 0.08);

    border-color: rgba(185, 157, 99, 0.2);

}



.feature-card .feature-icon {

    font-size: 2rem;

    flex-shrink: 0;

}



.feature-card h4 {

    font-size: 1.1rem;

    font-weight: 600;

    color: #fff;

    margin-bottom: 8px;

}



.feature-card p {

    font-size: 14px;

    color: rgba(255, 255, 255, 0.6);

    margin: 0;

}



/* Service CTA */

.service-cta {

    padding: 100px 0;

    background: linear-gradient(135deg, rgba(185, 157, 99, 0.1) 0%, rgba(185, 157, 99, 0.05) 100%);

}



.cta-grid {

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: 60px;

    align-items: start;

}



.cta-content .section-desc {

    color: rgba(255, 255, 255, 0.7);

    margin-bottom: 30px;

}



.contact-info {

    display: flex;

    flex-direction: column;

    gap: 20px;

}



.contact-item {

    display: flex;

    align-items: center;

    gap: 16px;

    padding: 16px 20px;

    background: rgba(255, 255, 255, 0.02);

    border: 1px solid rgba(255, 255, 255, 0.06);

    border-radius: 12px;

}



.contact-item .contact-icon {

    font-size: 1.5rem;

}



.contact-item .contact-label {

    display: block;

    font-size: 12px;

    color: rgba(255, 255, 255, 0.5);

    text-transform: uppercase;

    letter-spacing: 1px;

}



.contact-item .contact-value {

    color: #fff;

    font-weight: 600;

    text-decoration: none;

}



.contact-item .contact-value:hover {

    color: var(--ath-gold, #b99d63);

}



/* Quote Form */

.cta-form {

    padding: 40px;

    background: rgba(255, 255, 255, 0.02);

    border: 1px solid rgba(255, 255, 255, 0.06);

    border-radius: 20px;

}



.cta-form h3 {

    font-family: 'Playfair Display', serif;

    font-size: 1.5rem;

    font-weight: 600;

    color: #fff;

    margin-bottom: 24px;

}



.quote-form .form-group {

    margin-bottom: 16px;

}



.quote-form input,

.quote-form select,

.quote-form textarea {

    width: 100%;

    padding: 14px 18px;

    background: rgba(255, 255, 255, 0.05);

    border: 1px solid rgba(255, 255, 255, 0.1);

    border-radius: 10px;

    color: #fff;

    font-size: 15px;

    transition: all 0.3s ease;

}



.quote-form input::placeholder,

.quote-form textarea::placeholder {

    color: rgba(255, 255, 255, 0.4);

}



.quote-form input:focus,

.quote-form select:focus,

.quote-form textarea:focus {

    outline: none;

    border-color: var(--ath-gold, #b99d63);

    background: rgba(185, 157, 99, 0.05);

}



.quote-form select {

    cursor: pointer;

}



.quote-form select option {

    background: #1a1a1a;

    color: #fff;

}



.quote-form .btn {

    width: 100%;

    justify-content: center;

}



/* =================================================================

   RESPONSIVE

   ================================================================= */

@media (max-width: 1024px) {

    .service-block,

    .hero-grid,

    .page-hero-grid,

    .about-grid,

    .cta-grid,

    .why-grid {

        grid-template-columns: 1fr;

    }

    

    .service-block.reverse {

        direction: ltr;

    }

    

    .stats-grid {

        grid-template-columns: repeat(2, 1fr);

    }

    

    .values-grid {

        grid-template-columns: repeat(2, 1fr);

    }

    

    .process-timeline {

        flex-wrap: wrap;

    }

    

    .process-step {

        min-width: calc(50% - 20px);

    }

    

    .floating-stats {

        flex-wrap: wrap;

    }

}



@media (max-width: 768px) {

    .services-hero,

    .page-hero,

    .service-hero {

        padding: 120px 0 60px;

    }

    

    .services-hero .hero-stats {

        gap: 30px;

    }

    

    .services-hero .stat-number {

        font-size: 2.5rem;

    }

    

    .services-list {

        gap: 60px;

    }

    

    .service-block {

        padding: 24px;

    }

    

    .service-image img {

        height: 280px;

    }

    

    .stats-grid,

    .values-grid {

        grid-template-columns: 1fr;

    }

    

    .cta-box {

        flex-direction: column;

        text-align: center;

        padding: 40px 24px;

    }

    

    .cta-buttons {

        flex-direction: column;

        width: 100%;

    }

    

    .types-grid {

        grid-template-columns: repeat(2, 1fr);

    }

}



@media (max-width: 480px) {

    .process-step {

        min-width: 100%;

    }

    

    .types-grid {

        grid-template-columns: 1fr;

    }

    

    .hero-floating-card {

        left: 15px;

        right: 15px;

        bottom: 15px;

    }

    

    .service-buttons,

    .page-hero-cta,

    .hero-buttons {

        flex-direction: column;

    }

    

    .service-buttons .btn,

    .page-hero-cta .btn,

    .hero-buttons .btn {

        width: 100%;

        justify-content: center;

    }

}



/* =================================================================

   ANIMATIONS

   ================================================================= */

@keyframes pulse {

    0%, 100% { opacity: 1; }

    50% { opacity: 0.5; }

}



.animate-fade-in {

    animation: fadeIn 0.6s ease forwards;

}



.animate-fade-in-up {

    animation: fadeInUp 0.6s ease forwards;

}



@keyframes fadeIn {

    from { opacity: 0; }

    to { opacity: 1; }

}



@keyframes fadeInUp {

    from {

        opacity: 0;

        transform: translateY(30px);

    }

    to {

        opacity: 1;

        transform: translateY(0);

    }

}

