/* ========== IMPORTS ========== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Source+Sans+3:wght@300;400;500;600;700&display=swap');

/* ========== CSS VARIABLES ========== */
:root {
    --red: #D42027;
    --red-dark: #A8191E;
    --red-light: #F8E0E1;
    --black: #1A1A1A;
    --white: #FFFFFF;
    --cream: #F9F7F4;
    --gray-100: #F0EDEA;
    --gray-200: #E0DCDA;
    --gray-400: #999;
    --gray-600: #555;
    --font-heading: 'Inter', sans-serif;
    --font-body: 'Source Sans 3', sans-serif;
    --shadow-sm: 0 2px 8px rgba(0,0,0,.06);
    --shadow-md: 0 4px 20px rgba(0,0,0,.08);
    --shadow-lg: 0 8px 40px rgba(0,0,0,.12);
    --radius: 12px;
    --transition: .3s cubic-bezier(.4,0,.2,1);
    --header-h: 110px;
}

/* ========== RESET ========== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-h)}
body{font-family:var(--font-body);color:var(--black);background:var(--white);line-height:1.6;overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
img{max-width:100%;display:block}
button,input,textarea,select{font-family:inherit;font-size:inherit;border:none;outline:none}
button{cursor:pointer}

/* ========== UTILITIES ========== */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:100px 0}
.section-header{text-align:center;margin-bottom:60px}
.section-header h2{font-family:var(--font-heading);font-size:2.5rem;font-weight:700;margin-bottom:12px;color:var(--black)}
.section-header p{font-size:1.1rem;color:var(--gray-600);max-width:600px;margin:0 auto}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:50px;font-weight:600;font-size:1rem;transition:var(--transition)}
.btn-primary{background:var(--red);color:var(--white)}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 6px 20px rgba(212,32,39,.3)}
.btn-outline{border:2px solid var(--red);color:var(--red);background:transparent}
.btn-outline:hover{background:var(--red);color:var(--white);transform:translateY(-2px)}
.btn-whatsapp{background:#25D366;color:#fff}
.btn-whatsapp:hover{background:#1DA851;transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,211,102,.3)}

/* ========== TOPBAR ========== */
.topbar { background: var(--black); color: var(--white); padding: 8px 0; font-size: 0.85rem; font-family: var(--font-heading); font-weight: 500; }
.topbar-inner { display: flex; justify-content: space-between; align-items: center; max-width: 1440px; margin: 0 auto; padding: 0 5%; }
.topbar-contact { display: flex; gap: 24px; align-items: center; }
.topbar-contact p, .topbar-contact a { display: inline-flex; align-items: center; gap: 6px; transition: var(--transition); opacity: 0.9; color: var(--white); margin: 0; }
.topbar-contact a:hover { color: var(--red); opacity: 1; }
.topbar-social { display: flex; gap: 16px; align-items: center; }
.topbar-social a { display: inline-flex; align-items: center; opacity: 0.8; transition: var(--transition); color: var(--white); }
.topbar-social a:hover { color: var(--red); opacity: 1; transform: translateY(-2px); }
@media(max-width: 768px) {
    .topbar { font-size: 0.75rem; padding: 6px 0; }
    .topbar-inner { display: grid; grid-template-columns: auto auto; gap: 6px 12px; justify-content: center; align-items: center; }
    .topbar-contact { display: contents; }
    .topbar-contact > p:first-child { grid-column: 1; grid-row: 1; justify-self: end; margin: 0; }
    .topbar-contact > a { grid-column: 2; grid-row: 1; justify-self: start; margin: 0; }
    .topbar-contact > p:last-child { grid-column: 1; grid-row: 2; justify-self: end; margin: 0; }
    .topbar-social { grid-column: 2; grid-row: 2; justify-self: start; display: flex; gap: 12px; }
}

/* ========== HEADER ========== */
.header{position:sticky;top:0;left:0;right:0;height:var(--header-h);z-index:1000;transition:var(--transition);background:rgba(255,255,255,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.header.scrolled{box-shadow:var(--shadow-sm)}
.header .container{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:1440px}
.header-logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.header-logo .logo-img{max-height:85px;width:auto;object-fit:contain}
.header-logo .logo-text{font-family:var(--font-heading);font-weight:700;font-size:1.05rem;line-height:1.2}
.header-logo .logo-text span{display:block;font-size:.75rem;font-weight:400;color:var(--gray-600)}
.nav-links{display:flex;align-items:center;gap:16px}
.nav-links a{font-size:.9rem;font-weight:500;position:relative;transition:var(--transition);white-space:nowrap}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--red);transition:var(--transition)}
.nav-links a:hover{color:var(--red)}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:16px}
.lang-switch{display:flex;background:var(--gray-100);border-radius:50px;overflow:hidden}
.lang-switch button{padding:6px 14px;font-size:.8rem;font-weight:600;background:transparent;transition:var(--transition)}
.lang-switch button.active{background:var(--red);color:var(--white);border-radius:50px}
.nav-cta{padding:10px 24px;font-size:.9rem}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;padding:4px}
.hamburger span{width:24px;height:2px;background:var(--black);transition:var(--transition)}

/* ========== MOBILE NAV ========== */
.mobile-nav{position:fixed;top:var(--header-h);left:0;right:0;bottom:0;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;opacity:0;pointer-events:none;transition:var(--transition)}
.mobile-nav.open{opacity:1;pointer-events:all}
.mobile-nav a{font-size:1.3rem;font-weight:600}

/* ========== HERO ========== */
.hero{min-height:calc(100vh - 140px);display:flex;align-items:center;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--white) 0%,var(--cream) 50%,var(--red-light) 100%)}
.hero .container{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:60px;position:relative;z-index:2}
.hero-content h1{font-family:var(--font-heading);font-size:2.8rem;font-weight:300;line-height:1.15;margin-bottom:8px;color:var(--black);white-space:nowrap}
.hero-content h1 .highlight{color:inherit}
.hero-content .subtitle{font-size:1.3rem;color:var(--red);font-weight:600;margin-bottom:16px}
.hero-content .description{font-size:1.15rem;color:var(--gray-600);margin-bottom:36px;max-width:480px}
.hero-buttons{display:flex;gap:16px;flex-wrap:wrap}
.hero-image{display:flex;justify-content:center;align-items:center;position:relative}
.hero-image .doctor-photo{width:420px;height:420px;border-radius:50%;object-fit:cover;border:6px solid var(--white);box-shadow:var(--shadow-lg)}
.hero-image .pulse-ring{position:absolute;width:460px;height:460px;border-radius:50%;border:2px solid var(--red);opacity:.3;animation:pulseRing 2.5s ease-out infinite}
.hero-image .pulse-ring:nth-child(2){animation-delay:.8s;width:500px;height:500px}

/* EKG Line */
.ekg-line{position:absolute;bottom:80px;left:0;width:100%;height:60px;z-index:1;opacity:.08}
.ekg-line svg{width:100%;height:100%}
.ekg-path{stroke:var(--red);stroke-width:2;fill:none;stroke-dasharray:1000;stroke-dashoffset:1000;animation:ekgDraw 4s linear infinite}

@keyframes pulseRing{0%{transform:scale(1);opacity:.3}100%{transform:scale(1.15);opacity:0}}
@keyframes ekgDraw{0%{stroke-dashoffset:1000}100%{stroke-dashoffset:0}}

/* ========== ABOUT ========== */
.about{background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-photo img{width:100%;max-width:400px;border-radius:var(--radius);box-shadow:var(--shadow-md)}
.about-text h3{font-family:var(--font-heading);font-size:1.6rem;font-weight:700;margin-bottom:20px}
.about-text p{color:var(--gray-600);margin-bottom:24px;font-size:1.05rem}
.about-lists{display:grid;grid-template-columns:1fr;gap:24px;margin-top:24px}
.about-list h4{font-family:var(--font-heading);font-weight:700;margin-bottom:16px;color:var(--red);display:flex;align-items:center;gap:8px}
.about-list li{padding:4px 0;color:var(--gray-600);position:relative;padding-left:16px;break-inside:avoid-column}
.about-list li::before{content:'';position:absolute;left:0;top:12px;width:6px;height:6px;border-radius:50%;background:var(--red)}
#specialtiesList{columns:3;column-gap:32px}
@media (max-width:768px){#specialtiesList{columns:1}}

/* Stats */
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:60px}
.stat-card{text-align:center;padding:32px 16px;background:var(--cream);border-radius:var(--radius);transition:var(--transition)}
.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.stat-card .stat-number{font-family:var(--font-heading);font-size:2.8rem;font-weight:800;color:var(--red)}
.stat-card .stat-number span{font-size:1.8rem}
.stat-card .stat-label{font-size:.95rem;color:var(--gray-600);margin-top:4px}

/* ========== SERVICES ========== */
.services{background:var(--white)}
.services-title{display:flex;align-items:center;justify-content:center;gap:15px;text-transform:uppercase}
.services-title::before,.services-title::after{content:"";height:2px;width:50px;background-color:var(--red)}
.services-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:24px}
.service-card{width:calc(33.333% - 16px);background:var(--cream);border-radius:16px;text-align:left;transition:var(--transition);overflow:hidden;box-shadow:0 4px 15px rgba(0,0,0,0.03);display:flex;flex-direction:column}
.service-card:hover{transform:translateY(-6px);box-shadow:0 10px 25px rgba(0,0,0,0.08)}
.service-img{height:180px;background-size:cover;background-position:center;width:100%}
.service-content{padding:24px;flex:1}
.service-card h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;margin-bottom:10px;color:var(--black)}
.service-card p{color:var(--gray-600);font-size:.9rem;line-height:1.6}

/* ========== TESTIMONIALS ========== */
.testimonials {
    background: var(--white);
}

/* ========== RATING BADGES ========== */
.rating-badges-container {
    display: flex;
    justify-content: center;
    gap: 30px;
    margin-bottom: 50px;
    flex-wrap: wrap;
    margin-top: 40px;
}
.rating-badge-card {
    background: var(--white);
    border: 1px solid #eef2f5;
    border-radius: 16px;
    padding: 24px 40px;
    text-align: center;
    text-decoration: none;
    box-shadow: 0 4px 20px rgba(0,0,0,0.02);
    transition: all 0.3s ease;
    min-width: 280px;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.rating-badge-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
    border-color: rgba(212, 32, 39, 0.1);
}
.badge-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}
.badge-source {
    font-size: 1.1rem;
    font-weight: 700;
    color: #1a2b49;
}
.dt-logo-icon {
    width: 24px;
    height: 24px;
    border-radius: 6px;
    background: #00b2a9;
    color: white;
    font-size: 0.75rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
}
.badge-rating {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}
.rating-score {
    font-size: 1.6rem;
    font-weight: 800;
    color: #1a2b49;
}
.rating-stars {
    color: #FFB800;
    font-size: 1.1rem;
    letter-spacing: 2px;
}
.badge-count {
    font-size: 0.95rem;
    color: #5a6b89;
    font-weight: 600;
    margin: 0 0 16px 0;
}
.badge-link {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--red);
    transition: all 0.2s ease;
}
.rating-badge-card:hover .badge-link {
    letter-spacing: 1px;
}

/* ========== TESTIMONIALS SLIDER ========== */
.testimonials-slider {
    position: relative;
    overflow: hidden;
    width: 100%;
    margin-top: 40px;
    --card-width: 380px;
    padding-bottom: 45px;
}
.testimonials-track {
    display: flex;
    gap: 30px;
    width: max-content;
    will-change: transform;
    padding: 10px 5px;
}
.testimonial-card {
    width: var(--card-width);
    flex: 0 0 var(--card-width);
    height: 320px;
    background: var(--white);
    border-radius: 16px;
    padding: 30px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.03);
    border: 1px solid #f0f4f8;
    position: relative;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    box-sizing: border-box;
}
.testimonial-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 35px rgba(0,0,0,0.06);
    border-color: rgba(212, 32, 39, 0.08);
}
.testimonial-quote {
    position: absolute;
    top: 15px;
    right: 24px;
    font-size: 5rem;
    color: rgba(212, 32, 39, 0.05);
    font-family: Georgia, serif;
    line-height: 1;
    pointer-events: none;
    user-select: none;
}
.testimonial-text {
    font-size: 1.02rem;
    color: #5a6b89;
    line-height: 1.7;
    margin: 15px 0 15px 0;
    position: relative;
    z-index: 1;
    font-style: italic;
    flex: 1;
    overflow-y: auto;
    padding-right: 8px;
}
/* Scrollbar styling for long comments */
.testimonial-text::-webkit-scrollbar {
    width: 4px;
}
.testimonial-text::-webkit-scrollbar-track {
    background: transparent;
}
.testimonial-text::-webkit-scrollbar-thumb {
    background: var(--gray-200);
    border-radius: 4px;
}
.testimonial-text::-webkit-scrollbar-thumb:hover {
    background: var(--red-light);
}
.testimonial-author {
    border-top: 1px solid #f0f4f8;
    padding-top: 15px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0;
}
.author-info h4 {
    font-size: 1.1rem;
    color: #1a2b49;
    font-weight: 700;
    margin-bottom: 4px;
}
.testimonial-stars {
    color: #FFB800;
    font-size: 0.9rem;
    letter-spacing: 1px;
}
.card-source-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    flex-shrink: 0;
}
.card-source-icon.dt {
    background: #00b2a9;
    color: white;
    font-size: 0.7rem;
    font-weight: 800;
    border-radius: 4px;
    width: 24px;
    height: 24px;
}

/* Dots */
.slider-dots {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 25px;
    padding: 5px 0;
}
.slider-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #e2e8f0;
    cursor: pointer;
    transition: all 0.3s ease;
}
.slider-dot.active {
    background: var(--red);
    transform: scale(1.2);
}

@media (max-width: 1200px) {
    .testimonials-slider {
        --card-width: calc((100vw - 48px - 60px) / 3);
    }
}
@media (max-width: 992px) {
    .testimonials-slider {
        --card-width: calc((100vw - 48px - 30px) / 2);
    }
}
@media (max-width: 768px) {
    .testimonials-slider {
        --card-width: calc(100vw - 48px);
    }
}

/* ========== FAQ ========== */
.faq-section{background:var(--cream)}
.faq-list{max-width:800px;margin:0 auto}
.faq-item{background:var(--white);border-radius:var(--radius);margin-bottom:12px;overflow:hidden;border:1px solid var(--gray-200);transition:var(--transition)}
.faq-item.open{border-color:var(--red-light);box-shadow:var(--shadow-sm)}
.faq-question{padding:20px 24px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600;font-size:1.05rem;transition:var(--transition)}
.faq-question:hover{color:var(--red)}
.faq-question .faq-toggle{width:28px;height:28px;border-radius:50%;background:var(--gray-100);display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0}
.faq-item.open .faq-toggle{background:var(--red);color:var(--white);transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-answer p{padding:0 24px 20px;color:var(--gray-600);line-height:1.7}

/* ========== BLOG ========== */
.blog{background:var(--white)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-card{background:var(--cream);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.blog-card .blog-img{height:200px;background:linear-gradient(135deg,var(--red-light),var(--gray-100));display:flex;align-items:center;justify-content:center;overflow:hidden}
.blog-card .blog-img img{width:100%;height:100%;object-fit:cover}
.blog-card .blog-body{padding:24px}
.blog-card .blog-date{font-size:.85rem;color:var(--gray-400);margin-bottom:8px}
.blog-card h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;margin-bottom:10px;line-height:1.4}
.blog-card p{color:var(--gray-600);font-size:.95rem;margin-bottom:16px;line-height:1.5}
.blog-card .read-more{color:var(--red);font-weight:600;display:inline-flex;align-items:center;gap:4px;transition:var(--transition)}
.blog-card .read-more:hover{gap:8px}

/* Blog Modal */
.blog-modal{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:var(--transition)}
.blog-modal.open{opacity:1;pointer-events:all}
.blog-modal-content{background:var(--white);border-radius:var(--radius);max-width:700px;width:90%;max-height:80vh;overflow-y:auto;padding:40px;position:relative}
.blog-modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:var(--gray-100);display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:var(--transition)}
.blog-modal-close:hover{background:var(--red);color:var(--white)}
.blog-modal-content h2{font-family:var(--font-heading);font-size:1.6rem;margin-bottom:8px}
.blog-modal-content .modal-date{color:var(--gray-400);margin-bottom:20px;font-size:.9rem}
.blog-modal-content .modal-body{color:var(--gray-600);line-height:1.8;font-size:1.05rem}

/* ========== APPOINTMENT ========== */
.appointment{background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);color:var(--white)}
.appointment .section-header h2,.appointment .section-header p{color:var(--white)}
.appointment .section-header p{opacity:.85}
.appointment-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.appointment-form{background:var(--white);padding:40px;border-radius:var(--radius);color:var(--black)}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-weight:600;margin-bottom:6px;font-size:.9rem}
.form-group input,.form-group textarea{width:100%;padding:14px 16px;border:2px solid var(--gray-200);border-radius:10px;transition:var(--transition);background:var(--cream);font-size:1rem}
.form-group input:focus,.form-group textarea:focus{border-color:var(--red);background:var(--white)}
.form-group textarea{resize:vertical;min-height:100px}
.form-submit{width:100%}
.form-success{display:none;text-align:center;padding:24px;background:var(--cream);border-radius:10px;color:var(--black)}
.form-success.show{display:block}
.form-success .check-icon{font-size:3rem;margin-bottom:12px}
.appointment-info{display:flex;flex-direction:column;gap:24px}
.appointment-info .whatsapp-box{background:rgba(255,255,255,.15);padding:32px;border-radius:var(--radius);text-align:center}
.appointment-info .whatsapp-box p{margin-bottom:20px;opacity:.9;font-size:1.05rem}
.appointment-info .contact-cards{display:flex;flex-direction:column;gap:12px}
.appointment-info .contact-card{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,.1);padding:16px 20px;border-radius:10px;transition:var(--transition)}
.appointment-info .contact-card:hover{background:rgba(255,255,255,.2)}
.appointment-info .contact-card .icon{width:44px;height:44px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ========== CONTACT ========== */
.contact{background:var(--white)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.contact-info{display:flex;flex-direction:column;gap:12px}
.contact-item{display:flex;align-items:flex-start;gap:12px;padding:16px;background:var(--cream);border-radius:var(--radius);transition:var(--transition)}
.contact-item:hover{box-shadow:var(--shadow-sm)}
.contact-item .icon{width:48px;height:48px;background:var(--red-light);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-item .icon svg{width:22px;height:22px;stroke:var(--red);fill:none;stroke-width:2}
.contact-item h4{font-family:var(--font-heading);font-weight:700;margin-bottom:2px}
.contact-item p,.contact-item a{color:var(--gray-600);font-size:.9rem}
.contact-item a:hover{color:var(--red)}
.contact-map{border-radius:var(--radius);overflow:hidden;min-height:350px}
.contact-map iframe{width:100%;height:100%;min-height:350px;border:none}

/* Working Hours */
.working-hours{margin-top:12px;background:var(--cream);border-radius:var(--radius);padding:16px}
.working-hours h4{font-family:var(--font-heading);font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px;font-size:1rem}
.hours-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--gray-200);font-size:.9rem}
.hours-row:last-child{border:none}
.hours-row .day{font-weight:500}
.hours-row .time{color:var(--gray-600)}
.hours-row.closed .time{color:var(--red)}

/* ========== FOOTER ========== */
.footer{background:#1A1A1A;color:#fff;padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1.5fr 1.5fr;gap:40px;margin-bottom:40px}
.footer-brand .footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.footer-brand .footer-logo img{max-width:220px;max-height:80px;width:auto;height:auto;object-fit:contain}
.footer-brand .footer-logo span{font-family:var(--font-heading);font-weight:700;font-size:1.1rem;color:#fff}
.footer-brand p{color:rgba(255,255,255,.6);font-size:.95rem;line-height:1.6}
.footer h4{font-family:var(--font-heading);font-weight:700;margin-bottom:16px;font-size:1rem;color:#fff}
.footer-links a{display:block;color:rgba(255,255,255,.6);padding:4px 0;transition:var(--transition);font-size:.95rem}
.footer-links a:hover{color:var(--red);padding-left:4px}
.footer-contact p,.footer-contact a{color:rgba(255,255,255,.6);font-size:.9rem;display:flex;align-items:center;gap:8px;padding:3px 0}
.footer-contact a:hover{color:var(--white)}
.footer-social{display:flex;gap:12px;margin-top:16px}
.footer-social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;transition:var(--transition)}
.footer-social a:hover{background:var(--red);transform:translateY(-2px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;margin-top:20px;text-align:center;font-size:.9rem;color:rgba(255,255,255,.5)}

/* ========== FLOATING ACTIONS ========== */
.floating-actions {
    position: fixed;
    left: 20px;
    bottom: 40px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    z-index: 1000;
    transform: translateX(-100px);
    opacity: 0;
    visibility: hidden;
    transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.floating-actions.show {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
}
.float-btn {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--white);
    box-shadow: 0 4px 15px rgba(0,0,0,0.18);
    position: relative;
    transition: all 0.3s ease;
    animation: float-breath 3s ease-in-out infinite;
}
.float-wa { 
    background: #25D366; 
    animation-delay: 0s;
}
.float-wa::before { 
    background: #25D366; 
    animation-delay: 0s;
}
.float-phone { 
    background: var(--red); 
    animation-delay: 1.5s;
}
.float-phone::before { 
    background: var(--red); 
    animation-delay: 1s;
}
.float-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    z-index: -1;
    transition: all 0.3s ease;
    animation: float-pulse-wave 2s cubic-bezier(0.24, 0, 0.38, 1) infinite;
}
.float-btn:hover { 
    animation: none;
    transform: scale(1.1) translateY(-4px) !important; 
    color: var(--white); 
    box-shadow: 0 8px 25px rgba(0,0,0,0.25);
}
.float-btn:hover::before {
    animation: none;
    opacity: 0;
}

@keyframes float-breath {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.06); }
}

@keyframes float-pulse-wave {
    0% {
        transform: scale(1);
        opacity: 0.6;
    }
    100% {
        transform: scale(1.45);
        opacity: 0;
    }
}

/* ========== ANIMATIONS ========== */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.fade-in-left{opacity:0;transform:translateX(-30px);transition:opacity .6s ease,transform .6s ease}
.fade-in-left.visible{opacity:1;transform:translateX(0)}
.fade-in-right{opacity:0;transform:translateX(30px);transition:opacity .6s ease,transform .6s ease}
.fade-in-right.visible{opacity:1;transform:translateX(0)}

/* ========== RESPONSIVE ========== */
@media(max-width:1024px){
    .hero .container{grid-template-columns:1fr;text-align:center}
    .hero-content h1{font-size:2.8rem;white-space:normal}
    .hero-content .description{margin:0 auto 36px}
    .hero-buttons{justify-content:center}
    .hero-image .doctor-photo{width:300px;height:300px}
    .hero-image .pulse-ring{width:340px;height:340px}
    .hero-image .pulse-ring:nth-child(2){width:380px;height:380px}
    .about-grid{grid-template-columns:1fr}
    .about-photo{text-align:center}
    .service-card{width:calc(50% - 12px)}
    .blog-grid{grid-template-columns:repeat(2,1fr)}
    .appointment-grid{grid-template-columns:1fr}
    .contact-grid{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
    .nav-links,.nav-cta{display:none}
    .hamburger{display:flex}
    .section{padding:60px 0}
    .section-header h2{font-size:2rem}
    .hero-content h1{font-size:2.2rem;white-space:normal}
    .service-card{width:100%}
    .blog-grid{grid-template-columns:1fr}
    .stats-row{grid-template-columns:1fr}
    .about-lists{grid-template-columns:1fr}
    .floating-actions { left: auto; right: 16px; bottom: 20px; gap: 12px; transform: translateX(100px); }
    .floating-actions.show { transform: translateX(0); }
    .float-btn { width: 50px; height: 50px; }
    .float-btn svg { width: 22px; height: 22px; }
    .float-btn::before { inset: 0; }
    .topbar-contact { flex-direction: column; gap: 8px; }
    .faq-list { padding-bottom: 80px; }
}
@media(max-width:480px){
    .hero-buttons { flex-direction: row; flex-wrap: nowrap; width: 100%; gap: 10px; }
    .hero-buttons .btn { width: 100% !important; padding: 12px 4px; font-size: 0.85rem; justify-content: center; gap: 6px; }
    .hero-buttons .btn svg { width: 18px; height: 18px; }
    .header-logo .logo-img { max-height: 55px; }
    .header .container { padding: 0 16px; }
    .contact-list { gap: 16px; }
}

/* ========== GOOGLE TRANSLATE OVERRIDES ========== */
.goog-te-banner-frame{display:none!important}
body{top:0!important}
.skiptranslate{display:none!important}
.goog-te-gadget{display:none!important}

/* ========== SKELETON & SMOOTH IMAGE LOADING ========== */
.img-loading {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: skeletonPulse 1.5s infinite linear;
    color: transparent !important;
}
@keyframes skeletonPulse {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}
img.smooth-load {
    opacity: 0;
    transition: opacity 0.4s ease;
}
img.loaded {
    opacity: 1;
}

/* ========== BLOG MODAL COVER IMAGE ========== */
.blog-modal-img {
    width: calc(100% + 80px);
    height: 320px;
    background-size: cover;
    background-position: center;
    border-radius: var(--radius) var(--radius) 0 0;
    margin: -40px -40px 24px -40px;
    display: none;
}
@media (max-width: 768px) {
    .blog-modal-img {
        width: calc(100% + 80px);
        margin: -40px -40px 20px -40px;
        height: 200px;
    }
}
