/* ===== Kidza-Inspired Design System ===== */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Quicksand:wght@400;500;600;700;800&display=swap');

:root {
    --orange: #E8824C;
    --orange-dark: #C4562A;
    --purple: #7B2D8E;
    --purple-dark: #4B1076;
    --purple-light: #F0E4F5;
    --navy: #0A0A2E;
    --yellow: #FFD93D;
    --yellow-bg: #FFF8E1;
    --green: #4CAF50;
    --pink: #E91E63;
    --teal: #26C6DA;
    --pastel-pink: #FFF0ED;
    --pastel-green: #E8F8E8;
    --pastel-blue: #EAF2FF;
    --pastel-yellow: #FFF9E6;
    --pastel-purple: #F5ECFA;
    --white: #FFFFFF;
    --light: #F8F9FA;
    --light-2: #F0F4F8;
    --gray: #6B7280;
    --gray-light: #9CA3AF;
    --dark: #1F2937;
    --dark-2: #111827;
    --gradient-brand: linear-gradient(90deg, #0A0A2E, #4B1076, #7B2D8E, #C4562A, #E8824C);
    --gradient-purple: linear-gradient(135deg, #7B2D8E, #4B1076);
    --gradient-warm: linear-gradient(135deg, #4B1076, #7B2D8E, #C4562A);
    --radius: 24px;
    --radius-sm: 14px;
    --radius-lg: 32px;
    --shadow: 0 4px 24px rgba(0,0,0,0.06);
    --shadow-lg: 0 12px 40px rgba(0,0,0,0.1);
    --shadow-card: 0 8px 30px rgba(123,45,142,0.08);
    --transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    --font-heading: 'Nunito', sans-serif;
    --font-body: 'Quicksand', sans-serif;
}

/* ===== Reset ===== */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; scroll-padding-top:90px; }
body { font-family:var(--font-body); color:var(--dark); line-height:1.7; overflow-x:hidden; background:var(--white); }
a { text-decoration:none; color:inherit; transition:var(--transition); }
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
.container { max-width:1200px; margin:0 auto; padding:0 24px; }

/* ===== Top Bar ===== */
.top-bar { background:var(--white); border-bottom:1px solid #eee; padding:8px 0; font-size:0.85rem; }
.top-bar-inner { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.top-bar-left { display:flex; align-items:center; gap:20px; }
.top-link { display:inline-flex; align-items:center; gap:6px; color:var(--gray); font-weight:500; }
.top-link svg { color:var(--orange); }
.top-link:hover { color:var(--orange); }
.top-bar-right { display:flex; align-items:center; gap:14px; }
.social-links { display:flex; gap:8px; }
.social-links a { display:flex; align-items:center; justify-content:center; width:30px; height:30px; border-radius:50%; background:var(--light); color:var(--gray); transition:var(--transition); }
.social-links a:hover { background:var(--orange); color:#fff; transform:scale(1.1); }

/* Lang Switcher */
.lang-switcher { display:flex; align-items:center; gap:6px; margin-right:8px; padding-right:12px; border-right:2px solid var(--light); }
.lang-btn { background:none; border:none; font-family:var(--font-heading); font-size:0.9rem; font-weight:700; color:var(--gray); cursor:pointer; padding:4px 6px; border-radius:4px; transition:var(--transition); }
.lang-btn:hover { color:var(--dark); background:var(--light); }
.lang-btn.active { color:var(--orange); background:rgba(232,130,76,0.1); }
.lang-switcher span { color:var(--gray); opacity:0.5; font-size:0.8rem; }

/* Search Toggle */
.search-toggle {
    display:flex; align-items:center; justify-content:center;
    width:30px; height:30px; border-radius:50%;
    background:var(--light); color:var(--gray);
    border:none; cursor:pointer; transition:var(--transition);
}
.search-toggle:hover { background:var(--orange); color:#fff; transform:scale(1.1); }

/* Search Overlay */
.search-overlay {
    position:fixed; inset:0; z-index:10000;
    background:rgba(0,0,0,0.6); backdrop-filter:blur(8px);
    display:none; align-items:flex-start; justify-content:center;
    padding-top:120px;
    animation:fadeIn 0.3s ease;
}
.search-overlay.active { display:flex; }
.search-overlay-inner {
    background:#fff; border-radius:20px; padding:40px;
    width:92%; max-width:600px; position:relative;
    box-shadow:0 20px 60px rgba(0,0,0,0.2);
    animation:popupSlideIn 0.4s ease;
}
.search-close {
    position:absolute; top:14px; right:14px;
    width:36px; height:36px; border-radius:50%;
    border:none; background:var(--light); color:var(--gray);
    font-size:1.4rem; cursor:pointer; display:flex;
    align-items:center; justify-content:center; transition:var(--transition);
}
.search-close:hover { background:var(--purple-light); color:var(--purple); }
.search-overlay-inner h3 {
    font-family:var(--font-heading); font-size:1.4rem;
    color:var(--dark); margin-bottom:20px; text-align:center;
}
.search-input-wrap {
    display:flex; align-items:center; gap:12px;
    background:var(--light); border-radius:14px;
    padding:14px 18px; border:2px solid transparent;
    transition:var(--transition);
}
.search-input-wrap:focus-within { border-color:var(--purple); background:#fff; }
.search-input-wrap input {
    flex:1; border:none; background:transparent; outline:none;
    font-family:var(--font-body); font-size:1rem; color:var(--dark);
}
.search-results { margin-top:20px; max-height:300px; overflow-y:auto; }
.search-result-item {
    display:flex; align-items:center; gap:14px;
    padding:14px; border-radius:12px; cursor:pointer;
    transition:var(--transition); text-decoration:none; color:inherit;
}
.search-result-item:hover { background:var(--light); }
.search-result-icon {
    width:42px; height:42px; border-radius:12px;
    background:var(--pastel-purple); display:flex;
    align-items:center; justify-content:center; flex-shrink:0;
    font-size:1.2rem;
}
.search-result-item h4 { font-size:0.95rem; color:var(--dark); margin-bottom:2px; }
.search-result-item p { font-size:0.8rem; color:var(--gray); margin:0; }
.search-no-result { text-align:center; padding:30px; color:var(--gray); font-size:0.95rem; }

/* ===== Header ===== */
.header { background:var(--white); position:sticky; top:0; z-index:1000; box-shadow:0 2px 12px rgba(0,0,0,0.05); }
.header-inner { display:flex; justify-content:space-between; align-items:center; padding:14px 24px; }
.logo { display:flex; align-items:center; }
.logo img { height:55px; max-width:260px; width:auto; object-fit:contain; }
.nav-list { display:flex; gap:4px; align-items:center; }
.nav-link { padding:10px 18px; border-radius:var(--radius-lg); font-weight:700; font-size:0.95rem; color:var(--dark); }
.nav-link:hover, .nav-link.active { color:var(--orange); }
.nav-cta { background:var(--orange); color:#fff !important; padding:12px 24px; border-radius:var(--radius-lg); font-weight:700; font-size:0.92rem; margin-left:8px; box-shadow:0 4px 16px rgba(240,103,51,0.3); }
.nav-cta:hover { background:var(--orange-dark); transform:translateY(-2px); box-shadow:0 6px 20px rgba(240,103,51,0.4); }
.mobile-nav-extras { display:none; }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; z-index:1001; }
.hamburger span { width:28px; height:3px; background:var(--dark); border-radius:3px; transition:var(--transition); }
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,6px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-6px)}

/* ===== Buttons ===== */
.btn { display:inline-flex; align-items:center; gap:8px; padding:14px 30px; border-radius:var(--radius-lg); font-weight:700; font-size:0.95rem; font-family:var(--font-body); cursor:pointer; border:none; transition:var(--transition); }
.btn-primary { background:var(--orange); color:#fff; box-shadow:0 4px 18px rgba(240,103,51,0.3); }
.btn-primary:hover { background:var(--orange-dark); transform:translateY(-3px); box-shadow:0 8px 25px rgba(240,103,51,0.4); }
.btn-outline { background:transparent; color:var(--dark); border:2px solid #ddd; }
.btn-outline:hover { border-color:var(--orange); color:var(--orange); }
.btn-purple { background:var(--purple); color:#fff; box-shadow:0 4px 18px rgba(112,89,226,0.3); }
.btn-purple:hover { background:var(--purple-dark); transform:translateY(-3px); }
.btn-white { background:#fff; color:var(--orange); box-shadow:var(--shadow); }
.btn-white:hover { transform:translateY(-3px); box-shadow:var(--shadow-lg); }
.btn-sm { padding:10px 20px; font-size:0.88rem; }

/* ===== Section Utilities ===== */
.section-badge { display:inline-block; background:var(--pastel-purple); color:var(--purple); padding:6px 20px; border-radius:20px; font-size:0.82rem; font-weight:700; margin-bottom:14px; letter-spacing:0.5px; text-transform:uppercase; }
.badge-orange { background:var(--pastel-pink); color:var(--orange); }
.badge-light { background:rgba(255,255,255,0.2); color:#fff; border:1px solid rgba(255,255,255,0.3); }
.section-header { text-align:center; margin-bottom:50px; }
.section-header h2 { font-family:var(--font-heading); font-size:clamp(1.8rem,4vw,2.8rem); color:var(--dark); margin-bottom:10px; }
.section-desc { font-size:1.05rem; color:var(--gray); max-width:550px; margin:0 auto; }

/* ===== Page Banner (Inner Pages) ===== */
.page-banner { background:var(--gradient-warm); padding:80px 0 60px; text-align:center; color:#fff; position:relative; overflow:hidden; }
.page-banner::before { content:''; position:absolute; top:-50px; right:-50px; width:200px; height:200px; background:rgba(255,255,255,0.05); border-radius:50%; }
.page-banner::after { content:''; position:absolute; bottom:-30px; left:-30px; width:150px; height:150px; background:rgba(255,255,255,0.04); border-radius:50%; }
.page-banner h1 { font-family:var(--font-heading); font-size:clamp(2rem,5vw,3rem); margin-bottom:12px; }
.breadcrumb { display:flex; justify-content:center; gap:8px; font-size:0.9rem; font-weight:600; opacity:0.9; }
.breadcrumb a { color:var(--yellow); }
.breadcrumb span { opacity:0.7; }
.page-banner .wave-bottom { position:absolute; bottom:0; left:0; width:100%; line-height:0; }
.page-banner .wave-bottom svg { width:100%; height:70px; }
.page-banner + section, .page-banner + div { background:#fff; margin-top:-2px; position:relative; z-index:1; }

/* ===== Hero Slider ===== */
.hero { position:relative; background:linear-gradient(135deg, #F5F0FF 0%, #FFF5F0 50%, #FFFFF0 100%); padding:0; overflow:hidden; min-height:680px; }
.hero-slider-track { position:relative; width:100%; min-height:680px; }
.hero-slide { position:absolute; top:0; left:0; width:100%; height:100%; opacity:0; visibility:hidden; transition:opacity 0.7s ease, transform 0.7s ease; transform:translateX(40px); padding:80px 0 100px; display:flex; align-items:center; }
.hero-slide.active { opacity:1; visibility:visible; transform:translateX(0); z-index:2; }
.hero-slide.prev { opacity:0; transform:translateX(-40px); }
.hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.hero-text h1 { font-family:var(--font-heading); font-size:clamp(2.2rem,5vw,3.5rem); line-height:1.2; margin-bottom:18px; color:var(--dark); }
.hero-text h1 .highlight { color:var(--orange); }
.hero-text p { font-size:1.1rem; color:var(--gray); margin-bottom:28px; max-width:480px; }
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; }
.hero-image { position:relative; text-align:center; }
.hero-image img { border-radius:var(--radius-lg); max-height:500px; width:auto; margin:0 auto; box-shadow:var(--shadow-lg); }
.hero-doodle { position:absolute; opacity:0.6; }
.hero-doodle-1 { top:-20px; right:20px; font-size:3rem; animation:float 3s ease-in-out infinite; }
.hero-doodle-2 { bottom:20px; left:-10px; font-size:2.5rem; animation:float 4s ease-in-out infinite 1s; }
.hero-doodle-3 { top:40%; right:-20px; font-size:2rem; animation:float 3.5s ease-in-out infinite 0.5s; }
.hero-badge-float { position:absolute; bottom:40px; left:-20px; background:var(--orange); color:#fff; padding:16px 22px; border-radius:var(--radius); text-align:center; box-shadow:0 8px 25px rgba(240,103,51,0.3); animation:float 4s ease-in-out infinite; }
.hero-badge-float .num { font-size:2rem; font-weight:800; display:block; }
.hero-badge-float .txt { font-size:0.8rem; font-weight:600; }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }

/* Hero Slide Animations */
.hero-slide.active .hero-text { animation:slideUp 0.7s ease 0.15s both; }
.hero-slide.active .hero-image { animation:slideUp 0.7s ease 0.3s both; }
@keyframes slideUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }

/* Hero Test Badges */
.hero-test-badges { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:24px; }
.hero-test-tag { display:inline-block; padding:8px 22px; border-radius:var(--radius-lg); font-weight:800; font-size:0.95rem; letter-spacing:0.5px; box-shadow:0 4px 14px rgba(0,0,0,0.1); transform:rotate(-2deg); transition:var(--transition); }
.hero-test-tag:nth-child(2) { transform:rotate(1deg); }
.hero-test-tag:nth-child(3) { transform:rotate(-1deg); }
.hero-test-tag:hover { transform:rotate(0) scale(1.08); }

/* Hero Slider Arrows */
.hero-slider-arrow { position:absolute; top:50%; z-index:10; background:rgba(255,255,255,0.9); border:none; border-radius:50%; width:48px; height:48px; display:flex; align-items:center; justify-content:center; cursor:pointer; color:var(--dark); box-shadow:0 4px 20px rgba(0,0,0,0.1); transition:var(--transition); backdrop-filter:blur(8px); }
.hero-slider-arrow:hover { background:#fff; transform:translateY(-50%) scale(1.1); box-shadow:0 6px 24px rgba(0,0,0,0.15); }
.hero-arrow-prev { left:24px; transform:translateY(-50%); }
.hero-arrow-next { right:24px; transform:translateY(-50%); }

/* Hero Slider Dots */
.hero-slider-dots { position:absolute; bottom:70px; left:50%; transform:translateX(-50%); z-index:10; display:flex; gap:10px; }
.hero-dot { width:12px; height:12px; border-radius:50%; border:2px solid var(--purple); background:transparent; cursor:pointer; transition:var(--transition); padding:0; }
.hero-dot.active { background:var(--purple); width:36px; border-radius:8px; }
.hero-dot:hover { background:var(--purple); opacity:0.7; }

.hero .wave-bottom { position:absolute; bottom:0; left:0; width:100%; line-height:0; z-index:5; }
.hero .wave-bottom svg { width:100%; height:60px; }

/* ===== About Preview ===== */
.about-preview { padding:100px 0 80px; }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.about-img-wrap { position:relative; }
.about-img-wrap img { border-radius:var(--radius); box-shadow:var(--shadow-lg); }
.about-img-badge { position:absolute; bottom:24px; right:-20px; background:var(--orange); color:#fff; padding:18px 24px; border-radius:var(--radius); text-align:center; box-shadow:0 8px 25px rgba(240,103,51,0.3); }
.about-img-badge .num { font-family:var(--font-heading); font-size:2.2rem; display:block; }
.about-img-badge .txt { font-size:0.85rem; font-weight:600; }
.about-text h2 { font-family:var(--font-heading); font-size:2.2rem; margin-bottom:18px; }
.about-text p { color:var(--gray); margin-bottom:14px; }
.about-checks { display:flex; flex-wrap:wrap; gap:12px; margin:20px 0 28px; }
.about-check { display:flex; align-items:center; gap:8px; background:var(--pastel-purple); padding:8px 16px; border-radius:12px; font-weight:600; font-size:0.9rem; color:var(--purple); }
.about-check svg { flex-shrink:0; }

/* ===== Services Cards ===== */
.services-section { padding:80px 0 100px; background:var(--light); position:relative; }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.service-card {
    background:var(--white); border-radius:var(--radius); padding:36px 28px;
    transition:var(--transition); position:relative; overflow:visible;
    border:none; z-index:1;
}
.service-card::before {
    content:''; position:absolute; top:-3px; left:-3px; right:-3px; bottom:-3px;
    border-radius:calc(var(--radius) + 3px);
    background:conic-gradient(from var(--border-angle,0deg), #E8824C, #7B2D8E, #26C6DA, #4CAF50, #FF9800, #E91E63, #E8824C);
    z-index:-1; opacity:0; transition:opacity 0.4s ease;
    animation:borderSpin 3s linear infinite;
}
.service-card::after {
    content:''; position:absolute; top:0; left:0; right:0; bottom:0;
    border-radius:var(--radius); background:var(--white); z-index:-1;
}
.service-card:hover::before { opacity:1; }
.service-card:hover { transform:translateY(-8px); box-shadow:0 12px 40px rgba(123,45,142,0.12); }
@property --border-angle { syntax:'<angle>'; initial-value:0deg; inherits:false; }
@keyframes borderSpin { to { --border-angle:360deg; } }
.service-card .card-top { width:60px; height:60px; border-radius:16px; display:flex; align-items:center; justify-content:center; font-size:1.8rem; margin-bottom:20px; background:var(--card-bg,var(--pastel-pink)); }
.service-card h3 { font-family:var(--font-heading); font-size:1.35rem; margin-bottom:6px; }
.service-card .age { color:var(--card-accent,var(--orange)); font-weight:700; font-size:0.82rem; margin-bottom:10px; text-transform:uppercase; letter-spacing:0.5px; }
.service-card p { color:var(--gray); font-size:0.92rem; margin-bottom:16px; line-height:1.6; }
.service-card .card-link { color:var(--card-accent,var(--orange)); font-weight:700; font-size:0.9rem; display:inline-flex; align-items:center; gap:6px; }
.service-card .card-link:hover { gap:10px; }

/* ===== Why Choose Us ===== */
.why-section { padding:100px 0; }
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.why-img img { border-radius:var(--radius); box-shadow:var(--shadow-lg); }
.why-content h2 { font-family:var(--font-heading); font-size:2.2rem; margin-bottom:14px; }
.why-content>p { color:var(--gray); margin-bottom:24px; }
.progress-item { margin-bottom:18px; }
.progress-label { display:flex; justify-content:space-between; font-weight:700; font-size:0.9rem; margin-bottom:6px; }
.progress-bar { height:10px; background:#eee; border-radius:10px; overflow:hidden; }
.progress-fill { height:100%; border-radius:10px; transition:width 1.5s ease; width:0; }
.progress-fill.orange { background:linear-gradient(90deg,var(--orange),#FF8F6B); }
.progress-fill.purple { background:linear-gradient(90deg,var(--purple),#9B8AFF); }
.progress-fill.green { background:linear-gradient(90deg,#4CAF50,#66BB6A); }

/* ===== Team ===== */
.team-section { padding:100px 0; background:var(--white); }
.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:40px; }
.team-card { text-align:center; transition:var(--transition); }
.team-card:hover { transform:translateY(-6px); }
.team-photo { position:relative; width:200px; height:200px; margin:0 auto 20px; }
.team-photo img { width:100%; height:100%; object-fit:cover; border-radius:50%; position:relative; z-index:2; border:4px solid var(--white); box-shadow:var(--shadow); }
.team-photo::before { content:''; position:absolute; inset:-6px; border-radius:50%; background:conic-gradient(var(--purple),var(--yellow),var(--orange),var(--purple)); z-index:1; animation:spin-slow 10s linear infinite; }
@keyframes spin-slow { from{transform:rotate(0)} to{transform:rotate(360deg)} }
.team-card h3 { font-family:var(--font-heading); font-size:1.2rem; }
.team-card .role { color:var(--purple); font-weight:600; font-size:0.9rem; }

/* ===== Stats ===== */
.stats-section { background:linear-gradient(135deg,var(--purple),#5B3FD9); padding:80px 0; color:#fff; }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:30px; text-align:center; }
.stat-item .stat-icon { margin-bottom:12px; }
.stat-number { font-family:var(--font-heading); font-size:3.2rem; display:inline; }
.stat-plus { font-family:var(--font-heading); font-size:2rem; color:var(--yellow); }
.stat-item p { font-size:0.95rem; font-weight:600; opacity:0.9; margin-top:2px; }

/* ===== Schedule ===== */
.schedule-section { background:linear-gradient(135deg,var(--yellow),#FFC107); padding:80px 0; position:relative; }
.schedule-grid { display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; }
.schedule-info h2 { font-family:var(--font-heading); font-size:2.2rem; color:var(--dark); margin-bottom:14px; }
.schedule-info p { color:var(--dark); opacity:0.8; margin-bottom:24px; }
.schedule-table { background:var(--white); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lg); }
.schedule-row { display:flex; justify-content:space-between; align-items:center; padding:18px 28px; border-bottom:1px solid var(--light); font-weight:600; }
.schedule-row:last-child { border-bottom:none; }
.schedule-time { color:var(--purple); font-weight:700; }
.schedule-time.closed { color:var(--orange); }

/* ===== Testimonials ===== */
.testimonials-section { padding:100px 0; background:var(--light); }
.section-desc { font-size:1rem; color:var(--gray); margin-top:8px; }
.google-rating-badge { display:inline-flex; align-items:center; gap:8px; background:#fff; padding:10px 22px; border-radius:var(--radius-lg); box-shadow:var(--shadow-card); margin-top:16px; flex-wrap:wrap; justify-content:center; }
.google-score { font-weight:800; font-size:1.3rem; color:var(--dark); }
.google-stars { font-size:0.9rem; letter-spacing:2px; }
.google-count { font-size:0.85rem; color:var(--gray); font-weight:600; }

.testimonials-carousel { position:relative; margin-top:40px; }
.testimonials-track { display:flex; gap:24px; overflow-x:auto; scroll-behavior:smooth; scroll-snap-type:x mandatory; padding:10px 5px 20px; -ms-overflow-style:none; scrollbar-width:none; }
.testimonials-track::-webkit-scrollbar { display:none; }

.testimonial-card { background:var(--white); border-radius:var(--radius); padding:32px 28px; position:relative; box-shadow:var(--shadow-card); min-width:340px; max-width:400px; flex-shrink:0; scroll-snap-align:start; transition:var(--transition); border-top:3px solid transparent; }
.testimonial-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-top-color:var(--purple); }
.testimonial-stars { font-size:0.8rem; letter-spacing:2px; margin-bottom:8px; }
.testimonial-card .quote-icon { font-size:3rem; color:var(--purple); opacity:0.15; position:absolute; top:12px; right:20px; font-family:serif; line-height:1; }
.testimonial-card p { font-size:0.92rem; color:var(--gray); margin-bottom:18px; line-height:1.7; font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:12px; border-top:1px solid rgba(0,0,0,0.06); padding-top:16px; }
.testimonial-avatar { width:42px; height:42px; border-radius:50%; background:var(--purple); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:1.1rem; flex-shrink:0; }
.testimonial-author .name { font-weight:700; font-size:0.92rem; }
.testimonial-author .title { font-size:0.8rem; color:var(--gray); }

.testimonial-arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:5; background:rgba(255,255,255,0.95); border:none; border-radius:50%; width:44px; height:44px; display:flex; align-items:center; justify-content:center; cursor:pointer; color:var(--dark); box-shadow:0 4px 16px rgba(0,0,0,0.1); transition:var(--transition); }
.testimonial-arrow:hover { background:#fff; box-shadow:0 6px 24px rgba(0,0,0,0.15); transform:translateY(-50%) scale(1.1); }
.testimonial-prev { left:-20px; }
.testimonial-next { right:-20px; }

/* ===== Blog Cards ===== */
.blog-section { padding:100px 0; }
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.blog-card { border-radius:var(--radius); overflow:hidden; background:var(--white); box-shadow:var(--shadow-card); transition:var(--transition); }
.blog-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.blog-card img { width:100%; height:200px; object-fit:cover; }
.blog-card-body { padding:24px; }
.blog-card .blog-cat { display:inline-block; background:var(--pastel-pink); color:var(--orange); padding:4px 12px; border-radius:20px; font-size:0.78rem; font-weight:700; margin-bottom:10px; text-transform:uppercase; }
.blog-card h3 { font-family:var(--font-heading); font-size:1.15rem; margin-bottom:8px; line-height:1.3; }
.blog-card p { color:var(--gray); font-size:0.88rem; }

/* ===== Newsletter ===== */
.newsletter-section { background:var(--pastel-purple); padding:60px 0; }
.newsletter-inner { display:flex; justify-content:space-between; align-items:center; gap:30px; flex-wrap:wrap; }
.newsletter-inner h3 { font-family:var(--font-heading); font-size:1.6rem; }
.newsletter-form { display:flex; gap:0; }
.newsletter-form input { padding:14px 20px; border:2px solid #ddd; border-right:none; border-radius:var(--radius-lg) 0 0 var(--radius-lg); font-size:0.95rem; font-family:var(--font-body); width:300px; outline:none; }
.newsletter-form input:focus { border-color:var(--purple); }
.newsletter-form button { padding:14px 28px; background:var(--orange); color:#fff; border:none; border-radius:0 var(--radius-lg) var(--radius-lg) 0; cursor:pointer; font-weight:700; font-family:var(--font-body); transition:var(--transition); }
.newsletter-form button:hover { background:var(--orange-dark); }

/* ===== Article Detail Page ===== */
.article-layout { display:flex; gap:36px; margin-top:-60px; position:relative; z-index:2; }
.article-main { flex:1; min-width:0; background:#fff; border-radius:20px; padding:40px; box-shadow:0 10px 50px rgba(0,0,0,0.06); }
.article-sidebar { width:340px; flex-shrink:0; display:flex; flex-direction:column; gap:24px; }

/* Article Meta */
.article-meta { display:flex; flex-wrap:wrap; align-items:center; gap:16px; margin-bottom:24px; padding-bottom:20px; border-bottom:1px solid #f0f0f0; }
.article-meta-item { display:flex; align-items:center; gap:6px; font-size:0.9rem; color:var(--gray); }
.article-meta-item svg { width:16px; height:16px; opacity:0.6; }
.article-date-badge { background:linear-gradient(135deg, rgba(123,45,142,0.08), rgba(196,86,42,0.08)); color:var(--purple); padding:6px 16px; border-radius:30px; font-weight:600; font-size:0.85rem; }

/* Article Image */
.article-hero-img { width:100%; max-height:450px; object-fit:cover; border-radius:16px; margin-bottom:28px; }

/* Article Body */
.article-body { font-size:1.08rem; line-height:1.9; color:#3a3a3a; }
.article-body h2 { font-family:var(--font-heading); font-size:1.5rem; color:var(--dark); margin:36px 0 16px; padding-bottom:10px; border-bottom:2px solid var(--pastel-purple); }
.article-body h3 { font-family:var(--font-heading); font-size:1.2rem; color:var(--dark); margin:28px 0 12px; }
.article-body p { margin-bottom:16px; }
.article-body ul, .article-body ol { margin:12px 0 20px 20px; }
.article-body li { margin-bottom:8px; }
.article-body img { max-width:100%; border-radius:12px; margin:20px 0; }

/* Callout Boxes */
.callout-box { padding:20px 24px; border-radius:14px; margin:24px 0; position:relative; padding-left:54px; }
.callout-box::before { position:absolute; left:18px; top:20px; font-size:1.4rem; }
.callout-box h4 { font-family:var(--font-heading); font-size:1rem; margin-bottom:6px; }
.callout-box p { font-size:0.95rem; margin:0; line-height:1.6; }
.callout-note { background:#EDE7F6; border-left:4px solid var(--purple); }
.callout-note::before { content:'📝'; }
.callout-note h4 { color:var(--purple); }
.callout-tip { background:#E8F5E9; border-left:4px solid #4CAF50; }
.callout-tip::before { content:'💡'; }
.callout-tip h4 { color:#2E7D32; }
.callout-expert { background:#FFF3E0; border-left:4px solid var(--orange); }
.callout-expert::before { content:'🎓'; }
.callout-expert h4 { color:var(--orange); }
.callout-parent { background:#E3F2FD; border-left:4px solid #1976D2; }
.callout-parent::before { content:'👨‍👩‍👧'; }
.callout-parent h4 { color:#1565C0; }

/* Share Buttons */
.article-share { display:flex; align-items:center; gap:12px; padding:20px 0; border-top:1px solid #f0f0f0; margin-top:32px; flex-wrap:wrap; }
.article-share-label { font-weight:600; font-size:0.9rem; color:var(--gray); }
.share-btn { display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:50%; border:none; cursor:pointer; transition:0.3s; }
.share-btn:hover { transform:scale(1.1); }
.share-btn.whatsapp { background:#25D366; color:#fff; }
.share-btn.facebook { background:#1877F2; color:#fff; }
.share-btn.twitter { background:#1DA1F2; color:#fff; }
.share-btn.copy-link { background:#f0f0f0; color:#555; }
.share-btn.copy-link:hover { background:#e0e0e0; }
.share-btn svg { width:20px; height:20px; fill:currentColor; }

/* Article CTA */
.article-cta { background:linear-gradient(135deg, #4B1076, #7B2D8E, #C4562A); border-radius:20px; padding:36px; text-align:center; margin-top:36px; color:#fff; }
.article-cta h3 { font-family:var(--font-heading); font-size:1.5rem; margin-bottom:10px; color:#fff; }
.article-cta p { opacity:0.9; margin-bottom:20px; font-size:0.95rem; }
.article-cta .cta-buttons { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }
.article-cta .btn-cta-white { background:#fff; color:var(--purple); padding:12px 28px; border-radius:30px; font-weight:700; border:none; cursor:pointer; transition:0.3s; text-decoration:none; font-size:0.95rem; }
.article-cta .btn-cta-white:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,0.2); }
.article-cta .btn-cta-outline { background:transparent; color:#fff; padding:12px 28px; border-radius:30px; font-weight:700; border:2px solid rgba(255,255,255,0.5); cursor:pointer; transition:0.3s; text-decoration:none; font-size:0.95rem; }
.article-cta .btn-cta-outline:hover { border-color:#fff; background:rgba(255,255,255,0.1); }

/* Inline Newsletter */
.article-newsletter { background:var(--pastel-purple); border-radius:16px; padding:28px; margin-top:28px; text-align:center; }
.article-newsletter h4 { font-family:var(--font-heading); font-size:1.15rem; margin-bottom:6px; }
.article-newsletter p { color:var(--gray); font-size:0.88rem; margin-bottom:16px; }
.article-newsletter .nl-form { display:flex; gap:0; max-width:400px; margin:0 auto; }
.article-newsletter .nl-form input { flex:1; padding:12px 16px; border:2px solid #ddd; border-right:none; border-radius:10px 0 0 10px; font-size:0.9rem; outline:none; font-family:var(--font-body); }
.article-newsletter .nl-form input:focus { border-color:var(--purple); }
.article-newsletter .nl-form button { padding:12px 20px; background:var(--purple); color:#fff; border:none; border-radius:0 10px 10px 0; cursor:pointer; font-weight:700; font-size:0.85rem; transition:0.3s; }
.article-newsletter .nl-form button:hover { background:var(--purple-dark,#4B1076); }

/* Sidebar Cards */
.sidebar-card { background:#fff; border-radius:16px; padding:24px; box-shadow:0 6px 30px rgba(0,0,0,0.04); }
.sidebar-card h3 { font-family:var(--font-heading); font-size:1.15rem; color:var(--purple); margin-bottom:16px; padding-bottom:10px; border-bottom:2px solid rgba(123,45,142,0.1); }
.sidebar-card.sticky { position:sticky; top:100px; }

/* Sidebar News Items */
.sidebar-news-item { display:flex; gap:12px; align-items:center; text-decoration:none; color:inherit; padding:10px 0; border-bottom:1px solid #f5f5f5; transition:0.3s; }
.sidebar-news-item:last-child { border-bottom:none; }
.sidebar-news-item:hover { transform:translateX(4px); }
.sidebar-news-item img { width:68px; height:68px; object-fit:cover; border-radius:10px; flex-shrink:0; }
.sidebar-news-item h4 { font-size:0.9rem; line-height:1.35; color:var(--dark); margin-bottom:4px; }
.sidebar-news-item .sn-date { font-size:0.78rem; color:#aaa; }

/* Sidebar Appointment Card */
.sidebar-appointment { background:linear-gradient(135deg,#7B2D8E,#C4562A); border-radius:16px; padding:28px; text-align:center; color:#fff; }
.sidebar-appointment h3 { color:#fff; border:none; padding-bottom:0; margin-bottom:8px; font-size:1.1rem; }
.sidebar-appointment p { opacity:0.9; font-size:0.88rem; margin-bottom:16px; }
.sidebar-appointment .sidebar-appt-btn { display:inline-block; background:#fff; color:var(--purple); padding:12px 24px; border-radius:30px; font-weight:700; font-size:0.9rem; text-decoration:none; transition:0.3s; }
.sidebar-appointment .sidebar-appt-btn:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,0.2); }

/* Sidebar Tests */
.sidebar-tests a { display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:10px; text-decoration:none; color:var(--dark); font-weight:500; font-size:0.9rem; transition:0.2s; margin-bottom:4px; }
.sidebar-tests a:hover { background:var(--pastel-purple); color:var(--purple); }
.sidebar-tests .test-icon { width:34px; height:34px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; }

/* Table of Contents */
.article-toc { background:#FAFBFE; border:1px solid #E8E8F0; border-radius:14px; padding:20px 24px; margin-bottom:28px; }
.article-toc h4 { font-family:var(--font-heading); font-size:1rem; color:var(--purple); margin-bottom:12px; display:flex; align-items:center; gap:8px; }
.article-toc ol { list-style:none; counter-reset:toc; padding:0; margin:0; }
.article-toc li { counter-increment:toc; }
.article-toc li a { display:flex; align-items:center; gap:8px; padding:8px 10px; color:var(--dark); text-decoration:none; font-size:0.9rem; border-radius:8px; transition:0.2s; }
.article-toc li a::before { content:counter(toc); width:24px; height:24px; border-radius:6px; background:var(--pastel-purple); color:var(--purple); font-size:0.75rem; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.article-toc li a:hover { background:var(--pastel-purple); color:var(--purple); }
.article-toc li a.active { background:var(--pastel-purple); color:var(--purple); font-weight:600; }

/* News page cards */
.news-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.news-card { border-radius:var(--radius); overflow:hidden; background:var(--white); box-shadow:var(--shadow-card); transition:var(--transition); position:relative; }
.news-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.news-image { width:100%; height:220px; object-fit:cover; }
.news-content { padding:24px; }
.news-date { display:inline-block; background:rgba(123,45,142,0.08); color:var(--purple); padding:4px 12px; border-radius:20px; font-size:0.78rem; font-weight:600; margin-bottom:10px; }
.news-title { font-family:var(--font-heading); font-size:1.15rem; margin-bottom:10px; line-height:1.35; }
.news-summary { color:var(--gray); font-size:0.88rem; line-height:1.6; margin-bottom:16px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.news-read-more { display:inline-flex; align-items:center; gap:6px; color:var(--purple); font-weight:700; font-size:0.9rem; text-decoration:none; transition:0.3s; }
.news-read-more:hover { gap:10px; color:var(--orange); }
.news-reading-time { position:absolute; top:12px; right:12px; background:rgba(0,0,0,0.6); color:#fff; padding:4px 10px; border-radius:20px; font-size:0.75rem; font-weight:600; backdrop-filter:blur(4px); }

/* Article detail mobile */
@media (max-width:900px) {
    .article-layout { flex-direction:column; }
    .article-sidebar { width:100%; }
    .article-main { padding:24px; }
    .news-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px) {
    .news-grid { grid-template-columns:1fr; }
    .article-newsletter .nl-form { flex-direction:column; gap:8px; }
    .article-newsletter .nl-form input { border-right:2px solid #ddd; border-radius:10px; }
    .article-newsletter .nl-form button { border-radius:10px; }
}

/* ===== Contact Page ===== */
.contact-section { padding:20px 0 100px; background:#fff; margin-top:-2px; }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px; }
.contact-form { background:var(--white); border-radius:var(--radius); padding:40px; box-shadow:var(--shadow-card); }
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-weight:700; font-size:0.9rem; margin-bottom:6px; }
.form-group input, .form-group textarea, .form-group select { width:100%; padding:14px 18px; border:2px solid #eee; border-radius:var(--radius-sm); font-family:var(--font-body); font-size:0.95rem; outline:none; transition:var(--transition); }
.form-group input:focus, .form-group textarea:focus { border-color:var(--purple); }
.form-group textarea { resize:vertical; min-height:120px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.contact-info-side { display:flex; flex-direction:column; gap:20px; }
.contact-info-card { background:var(--white); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-card); display:flex; gap:16px; align-items:flex-start; }
.contact-info-card .info-icon { width:48px; height:48px; border-radius:14px; background:var(--pastel-purple); display:flex; align-items:center; justify-content:center; font-size:1.3rem; flex-shrink:0; }
.contact-info-card h4 { font-weight:700; font-size:0.95rem; margin-bottom:4px; }
.contact-info-card p { color:var(--gray); font-size:0.9rem; }
.contact-info-card a { color:var(--orange); font-weight:600; }
.contact-map { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-card); margin-top:30px; }

/* ===== About Page ===== */
.about-full { padding:100px 0; }
.about-full-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; margin-bottom:60px; }
.about-full-text h2 { font-family:var(--font-heading); font-size:2rem; margin-bottom:16px; }
.about-full-text p { color:var(--gray); margin-bottom:14px; line-height:1.7; }
.mission-cards { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:40px; }
.mission-card { background:var(--white); border-radius:var(--radius); padding:32px 24px; box-shadow:var(--shadow-card); text-align:center; transition:var(--transition); }
.mission-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.mission-card .m-icon { font-size:2.5rem; margin-bottom:14px; }
.mission-card h3 { font-family:var(--font-heading); font-size:1.2rem; margin-bottom:8px; }
.mission-card p { color:var(--gray); font-size:0.9rem; }

/* ===== Test Cards ===== */
.tests-section { padding:100px 0; }
.tests-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.test-card { display:flex; align-items:center; justify-content:center; text-align:center; padding:28px 20px; background:var(--white); border-radius:var(--radius-sm); font-weight:600; font-size:0.9rem; color:var(--dark); transition:var(--transition); border:2px solid var(--light); min-height:100px; box-shadow:var(--shadow-card); }
.test-card:hover { border-color:var(--purple); background:var(--pastel-purple); color:var(--purple); transform:translateY(-5px); box-shadow:var(--shadow-lg); }

/* ===== Ekip Page ===== */
.team-full-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.team-full-card {
    background:var(--white); border-radius:var(--radius); padding:30px; text-align:center;
    box-shadow:var(--shadow-card); transition:var(--transition);
    position:relative; overflow:visible; border:none; z-index:1;
}
.team-full-card::before {
    content:''; position:absolute; top:-3px; left:-3px; right:-3px; bottom:-3px;
    border-radius:calc(var(--radius) + 3px);
    background:conic-gradient(from var(--border-angle,0deg), #E8824C, #7B2D8E, #26C6DA, #4CAF50, #FF9800, #E91E63, #E8824C);
    z-index:-1; opacity:0; transition:opacity 0.4s ease;
    animation:borderSpin 3s linear infinite;
}
.team-full-card::after {
    content:''; position:absolute; top:0; left:0; right:0; bottom:0;
    border-radius:var(--radius); background:var(--white); z-index:-1;
}
.team-full-card:hover::before { opacity:1; }
.team-full-card:hover { transform:translateY(-8px); box-shadow:0 12px 40px rgba(123,45,142,0.12); }
.team-full-card .photo { width:140px; height:140px; border-radius:50%; object-fit:cover; margin:0 auto 16px; border:4px solid var(--pastel-purple); }
.team-full-card h3 { font-family:var(--font-heading); font-size:1.15rem; margin-bottom:4px; }
.team-full-card .role { color:var(--purple); font-weight:600; font-size:0.88rem; margin-bottom:10px; }
.team-full-card p { color:var(--gray); font-size:0.88rem; line-height:1.6; }

/* ===== Footer ===== */
.footer { background:var(--dark-2); color:rgba(255,255,255,0.8); padding:60px 0 0; position:relative; overflow:hidden; }
.footer::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:var(--gradient-brand); }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,0.08); }
.footer-logo { height:55px; max-width:260px; width:auto; margin-bottom:14px; filter:brightness(2) contrast(1.1); object-fit:contain; }
.footer-col p { font-size:0.9rem; line-height:1.6; opacity:0.8; }
.footer-col h4 { color:#fff; font-family:var(--font-heading); font-size:1.15rem; margin-bottom:18px; }
.footer-col ul li { margin-bottom:8px; font-size:0.9rem; }
.footer-col ul li a:hover { color:var(--orange); padding-left:4px; }
.footer-col .footer-contact-item { display:flex; gap:10px; margin-bottom:12px; font-size:0.88rem; }
.footer-col .footer-contact-item .fc-icon { color:var(--yellow); font-size:1rem; flex-shrink:0; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding:18px 0; font-size:0.82rem; opacity:0.6; }
.footer-links { display:flex; gap:18px; }
.footer-links a:hover { color:var(--orange); }

/* ===== Floating Elements ===== */
.whatsapp-float { position:fixed; bottom:24px; left:24px; width:56px; height:56px; border-radius:50%; background:#25D366; display:flex; align-items:center; justify-content:center; box-shadow:0 6px 20px rgba(37,211,102,0.35); z-index:999; animation:pulse-wp 2s infinite; }
.whatsapp-float:hover { transform:scale(1.1); }
@keyframes pulse-wp { 0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,0.4)} 50%{box-shadow:0 0 0 14px rgba(37,211,102,0)} }
.whatsapp-float svg { fill:#fff; }

/* Randevu Float Button */
.randevu-float {
    position:fixed; bottom:90px; left:24px; height:46px;
    padding:0 18px; border-radius:23px;
    background:linear-gradient(135deg, var(--purple), #7B2D8E);
    display:flex; align-items:center; gap:8px;
    box-shadow:0 6px 20px rgba(123,45,142,0.35);
    z-index:999; text-decoration:none; color:#fff;
    font-size:0.85rem; font-weight:700;
    transition:all 0.3s ease;
    animation:pulse-randevu 2s infinite;
}
.randevu-float:hover { transform:scale(1.05); background:linear-gradient(135deg, #5a1c6c, #9b3db0); }
@keyframes pulse-randevu { 0%,100%{box-shadow:0 0 0 0 rgba(123,45,142,0.4)} 50%{box-shadow:0 0 0 12px rgba(123,45,142,0)} }

/* ===== DoktorTakvimi Section ===== */
.doktortakvimi-section { padding:60px 0; background:#fff; }
.dt-card {
    max-width:700px; margin:0 auto;
    background:var(--light); border-radius:20px;
    padding:32px; display:flex; gap:32px;
    align-items:center; justify-content:space-between;
    box-shadow:0 4px 24px rgba(0,0,0,0.06);
    border:1px solid #eee;
}
.dt-doctor { display:flex; align-items:center; gap:20px; }
.dt-avatar {
    width:80px; height:80px; border-radius:50%; overflow:hidden;
    border:3px solid var(--purple); flex-shrink:0;
    background:var(--purple-light);
}
.dt-avatar img { width:100%; height:100%; object-fit:cover; }
.dt-info h3 { font-family:var(--font-heading); font-size:1.15rem; color:var(--navy); margin-bottom:2px; }
.dt-specialty { color:var(--gray); font-size:0.85rem; margin-bottom:6px; }
.dt-stars { display:flex; align-items:center; gap:2px; margin-bottom:6px; }
.dt-rating { font-size:0.8rem; color:var(--gray); margin-left:6px; }
.dt-address { font-size:0.8rem; color:var(--gray); }
.dt-actions { display:flex; flex-direction:column; gap:10px; align-items:center; flex-shrink:0; }
.dt-btn { font-size:0.85rem; padding:10px 22px; min-width:180px; text-align:center; }
.btn-outline {
    background:transparent; border:2px solid var(--purple);
    color:var(--purple); border-radius:30px; font-weight:600;
    text-decoration:none; transition:var(--transition);
}
.btn-outline:hover { background:var(--purple); color:#fff; }
.dt-powered { font-size:0.7rem; color:#aaa; margin-top:4px; }

@media (max-width:700px) {
    .dt-card { flex-direction:column; text-align:center; padding:24px; }
    .dt-doctor { flex-direction:column; }
    .dt-actions { width:100%; }
    .dt-btn { width:100%; }
    .randevu-float span { display:none; }
    .randevu-float { width:46px; height:46px; padding:0; border-radius:50%; justify-content:center; }
}

.scroll-top { position:fixed; bottom:24px; right:24px; width:46px; height:46px; border-radius:50%; background:var(--orange); color:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; border:none; box-shadow:0 4px 16px rgba(240,103,51,0.3); z-index:999; opacity:0; visibility:hidden; transform:translateY(20px); transition:var(--transition); }
.scroll-top.visible { opacity:1; visibility:visible; transform:translateY(0); }
.scroll-top:hover { background:var(--orange-dark); transform:translateY(-4px); }

/* ===== Wave Dividers ===== */
.wave-divider { position:relative; line-height:0; }
.wave-divider svg { width:100%; height:50px; display:block; }

/* ===== Reveal ===== */
.reveal { opacity:0; transform:translateY(28px); transition:opacity 0.6s ease, transform 0.6s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ===== Nav Overlay ===== */
.nav-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:998; opacity:0; visibility:hidden; transition:var(--transition); }
.nav-overlay.active { opacity:1; visibility:visible; }

/* ===== Program Category Tabs ===== */
.program-tabs { display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin-bottom:50px; }
.program-tab { padding:12px 24px; border-radius:var(--radius-lg); font-weight:700; font-size:0.88rem; cursor:pointer; border:2px solid var(--light-2); background:var(--white); color:var(--gray); transition:var(--transition); text-transform:uppercase; letter-spacing:0.5px; }
.program-tab:hover { border-color:var(--purple); color:var(--purple); }
.program-tab.active { background:var(--purple); color:#fff; border-color:var(--purple); box-shadow:0 4px 16px rgba(112,89,226,0.3); }
.program-tab[data-color="orange"].active { background:var(--orange); border-color:var(--orange); box-shadow:0 4px 16px rgba(240,103,51,0.3); }
.program-tab[data-color="green"].active { background:var(--green); border-color:var(--green); box-shadow:0 4px 16px rgba(76,175,80,0.3); }
.program-tab[data-color="pink"].active { background:var(--pink); border-color:var(--pink); box-shadow:0 4px 16px rgba(233,30,99,0.3); }
.program-tab[data-color="teal"].active { background:var(--teal); border-color:var(--teal); box-shadow:0 4px 16px rgba(38,198,218,0.3); }

/* ===== Program Content Panels ===== */
.program-panel { display:none; animation:fadeInPanel 0.5s ease; }
.program-panel.active { display:block; }
@keyframes fadeInPanel { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }

/* ===== Program Detail Cards ===== */
.program-detail-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:28px; margin-bottom:40px; }
.program-detail-card { background:var(--white); border-radius:var(--radius); padding:32px 28px; box-shadow:var(--shadow-card); transition:var(--transition); border-left:4px solid var(--purple); position:relative; overflow:hidden; }
.program-detail-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.program-detail-card::after { content:''; position:absolute; top:0; right:0; width:80px; height:80px; background:var(--pastel-purple); border-radius:0 0 0 80px; opacity:0.5; }
.program-detail-card[data-accent="orange"] { border-left-color:var(--orange); }
.program-detail-card[data-accent="orange"]::after { background:var(--pastel-pink); }
.program-detail-card[data-accent="green"] { border-left-color:var(--green); }
.program-detail-card[data-accent="green"]::after { background:var(--pastel-green); }
.program-detail-card[data-accent="pink"] { border-left-color:var(--pink); }
.program-detail-card[data-accent="teal"] { border-left-color:var(--teal); }
.program-detail-card[data-accent="teal"]::after { background:#E0F7FA; }
.program-detail-card .card-emoji { font-size:2.2rem; margin-bottom:12px; position:relative; z-index:1; }
.program-detail-card h3 { font-family:var(--font-heading); font-size:1.3rem; margin-bottom:8px; position:relative; z-index:1; }
.program-detail-card .card-age { display:inline-block; padding:4px 14px; border-radius:20px; font-size:0.78rem; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; margin-bottom:12px; }
.program-detail-card p { color:var(--gray); font-size:0.9rem; line-height:1.7; position:relative; z-index:1; }

/* ===== Full Width Program Section ===== */
.program-full { background:var(--white); border-radius:var(--radius); padding:40px 36px; margin-bottom:30px; box-shadow:var(--shadow-card); }
.program-full h3 { font-family:var(--font-heading); font-size:1.6rem; margin-bottom:8px; color:var(--dark); }
.program-full .program-subtitle { color:var(--purple); font-weight:700; font-size:0.85rem; text-transform:uppercase; letter-spacing:0.5px; margin-bottom:18px; display:block; }
.program-full p { color:var(--gray); font-size:0.95rem; line-height:1.8; margin-bottom:14px; }
.program-full .feature-list { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin:20px 0; }
.program-full .feature-list li { display:flex; align-items:flex-start; gap:10px; font-size:0.9rem; color:var(--dark); font-weight:500; padding:8px 0; }
.program-full .feature-list li::before { content:'✓'; display:flex; align-items:center; justify-content:center; width:22px; height:22px; border-radius:50%; background:var(--pastel-green); color:var(--green); font-size:0.75rem; font-weight:800; flex-shrink:0; margin-top:2px; }

/* ===== Accordion ===== */
.accordion { margin-bottom:20px; }
.accordion-item { background:var(--white); border-radius:var(--radius-sm); margin-bottom:12px; box-shadow:var(--shadow-card); overflow:hidden; border:2px solid transparent; transition:var(--transition); }
.accordion-item.open { border-color:var(--purple); }
.accordion-header { display:flex; justify-content:space-between; align-items:center; padding:20px 24px; cursor:pointer; gap:16px; }
.accordion-header h4 { font-family:var(--font-heading); font-size:1.1rem; color:var(--dark); margin:0; }
.accordion-header .acc-icon { width:32px; height:32px; border-radius:50%; background:var(--pastel-purple); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:var(--transition); }
.accordion-item.open .accordion-header .acc-icon { background:var(--purple); color:#fff; transform:rotate(180deg); }
.accordion-body { padding:0 24px; max-height:0; overflow:hidden; transition:max-height 0.4s ease, padding 0.4s ease; }
.accordion-item.open .accordion-body { padding:0 24px 24px; max-height:2000px; }
.accordion-body p { color:var(--gray); font-size:0.92rem; line-height:1.7; margin-bottom:12px; }
.accordion-body .feature-list { list-style:none; padding:0; margin:12px 0; }
.accordion-body .feature-list li { display:flex; align-items:flex-start; gap:10px; font-size:0.9rem; color:var(--dark); font-weight:500; padding:6px 0; }
.accordion-body .feature-list li::before { content:'•'; color:var(--purple); font-size:1.2rem; font-weight:800; flex-shrink:0; line-height:1.4; }

/* ===== Test Detail Section ===== */
.test-category { margin-bottom:50px; }
.test-category-header { display:flex; align-items:center; gap:14px; margin-bottom:24px; padding-bottom:14px; border-bottom:3px solid var(--pastel-purple); }
.test-category-header .cat-icon { width:48px; height:48px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:1.5rem; flex-shrink:0; }
.test-category-header h3 { font-family:var(--font-heading); font-size:1.5rem; color:var(--dark); margin:0; }
.test-detail-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.test-detail-card { background:var(--white); border-radius:var(--radius); padding:28px 24px; box-shadow:var(--shadow-card); transition:var(--transition); border-top:3px solid var(--purple); }
.test-detail-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.test-detail-card h4 { font-family:var(--font-heading); font-size:1.15rem; margin-bottom:4px; color:var(--dark); }
.test-detail-card .test-abbr { color:var(--purple); font-weight:700; font-size:0.8rem; text-transform:uppercase; letter-spacing:0.5px; margin-bottom:10px; display:block; }
.test-detail-card p { color:var(--gray); font-size:0.88rem; line-height:1.7; }
.test-detail-card[data-accent="orange"] { border-top-color:var(--orange); }
.test-detail-card[data-accent="orange"] .test-abbr { color:var(--orange); }
.test-detail-card[data-accent="green"] { border-top-color:var(--green); }
.test-detail-card[data-accent="green"] .test-abbr { color:var(--green); }
.test-detail-card[data-accent="teal"] { border-top-color:var(--teal); }
.test-detail-card[data-accent="teal"] .test-abbr { color:var(--teal); }

/* ===== CTA Banner Inline ===== */
.cta-inline { background:var(--gradient-warm); border-radius:var(--radius); padding:40px; text-align:center; color:#fff; margin:40px 0; }
.cta-inline h3 { font-family:var(--font-heading); font-size:1.6rem; margin-bottom:10px; }
.cta-inline p { opacity:0.9; margin-bottom:20px; font-size:0.95rem; }

/* ===== Stagger Animations ===== */
.reveal-stagger > .reveal:nth-child(1) { transition-delay:0.05s; }
.reveal-stagger > .reveal:nth-child(2) { transition-delay:0.1s; }
.reveal-stagger > .reveal:nth-child(3) { transition-delay:0.15s; }
.reveal-stagger > .reveal:nth-child(4) { transition-delay:0.2s; }
.reveal-stagger > .reveal:nth-child(5) { transition-delay:0.25s; }
.reveal-stagger > .reveal:nth-child(6) { transition-delay:0.3s; }

/* ===== Responsive ===== */
@media(max-width:1024px) {
    .services-grid,.blog-grid { grid-template-columns:repeat(2,1fr); }
    .tests-grid { grid-template-columns:repeat(3,1fr); }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
    .footer-grid { grid-template-columns:repeat(2,1fr); }
    .team-full-grid { grid-template-columns:repeat(2,1fr); }
}

@media(max-width:768px) {
    .top-bar-left { display:none; }
    .hamburger { display:flex; }
    .nav { position:fixed; top:0; right:-100%; width:280px; height:100vh; background:#fff; box-shadow:-4px 0 20px rgba(0,0,0,0.1); padding:80px 24px 40px; transition:right 0.4s ease; z-index:999; overflow-y:auto; }
    .nav.open { right:0; }
    .nav-list { flex-direction:column; gap:4px; }
    .nav-link { display:block; padding:14px 18px; border-radius:12px; font-size:1.05rem; }
    .nav-cta { margin-left:0; margin-top:10px; text-align:center; display:block; }
    .mobile-nav-extras { display:flex; justify-content:center; align-items:center; gap:12px; margin-top:24px; padding-top:24px; border-top:1px solid #eee; }
    .mobile-nav-extras .social-links a { width:38px; height:38px; }
    .mobile-nav-extras .search-toggle { width:38px; height:38px; background:var(--light); color:var(--gray); }
    .mobile-nav-extras .search-toggle:hover { background:var(--orange); color:#fff; }
    .hero-grid,.about-grid,.about-full-grid,.why-grid,.schedule-grid,.contact-grid { grid-template-columns:1fr; }
    .hero-image { order:-1; }
    .hero-slider-arrow { display:none; }
    .hero, .hero-slider-track { min-height:auto; }
    .hero-slide { position:relative; padding:60px 0 80px; }
    .hero-slide:not(.active) { position:absolute; }
    .hero-slider-dots { bottom:30px; }
    .services-grid,.team-grid,.blog-grid,.team-full-grid { grid-template-columns:1fr; }
    .tests-grid { grid-template-columns:repeat(2,1fr); }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
    .testimonial-arrow { display:none; }
    .testimonial-card { min-width:280px; }
    .footer-grid { grid-template-columns:1fr; }
    .program-detail-grid,.test-detail-grid { grid-template-columns:1fr; }
    .program-full .feature-list { grid-template-columns:1fr; }
    .program-tab { padding:10px 16px; font-size:0.78rem; }
    .footer-bottom { flex-direction:column; gap:10px; text-align:center; }
    .newsletter-inner { flex-direction:column; text-align:center; }
    .newsletter-form input { width:220px; }
    .form-row { grid-template-columns:1fr; }
    .mission-cards { grid-template-columns:1fr; }
    .page-banner { padding:60px 0 50px; }
}

@media(max-width:480px) {
    .hero-slide { padding:40px 0 70px; }
    .hero-text h1 { font-size:1.8rem; }
    .hero-btns { flex-direction:column; }
    .btn { width:100%; justify-content:center; }
    .hero-test-badges { gap:6px; }
    .hero-test-tag { padding:6px 14px; font-size:0.82rem; }
    .tests-grid { grid-template-columns:1fr; }
    .stats-grid { grid-template-columns:1fr; }
    .program-tabs { gap:6px; }
    .program-tab { padding:8px 12px; font-size:0.72rem; }
    .program-full { padding:24px 18px; }
}

/* ===== Company Selection Popup ===== */
.company-popup-overlay {
    position:fixed; top:0; left:0; width:100%; height:100%;
    background:rgba(10,10,46,0.88); backdrop-filter:blur(12px);
    z-index:99999; display:flex; align-items:center; justify-content:center;
    opacity:1; transition:opacity 0.4s ease;
}
.company-popup-overlay.hidden {
    opacity:0; pointer-events:none;
}
.company-popup {
    background:#fff; border-radius:28px; padding:50px 48px 44px;
    max-width:680px; width:92%; text-align:center;
    box-shadow:0 30px 90px rgba(0,0,0,0.35);
    animation:popupSlideIn 0.5s cubic-bezier(0.16,1,0.3,1);
    position:relative;
}
.company-popup-close {
    position:absolute; top:16px; right:16px;
    width:36px; height:36px; border-radius:50%;
    border:none; background:var(--light); color:var(--gray);
    font-size:1.4rem; cursor:pointer; display:flex;
    align-items:center; justify-content:center;
    transition:all 0.2s ease; line-height:1;
}
.company-popup-close:hover {
    background:var(--purple-light); color:var(--purple);
    transform:scale(1.1);
}
@keyframes popupSlideIn {
    from { opacity:0; transform:translateY(30px) scale(0.95); }
    to   { opacity:1; transform:translateY(0) scale(1); }
}
.company-popup-title {
    font-family:'Quicksand', sans-serif; font-size:1.7rem;
    font-weight:800; color:var(--navy); margin-bottom:8px;
}
.company-popup-subtitle {
    font-family:'Quicksand', sans-serif;
    color:var(--gray); font-size:0.95rem; margin-bottom:36px; font-weight:500;
}
.company-popup-grid {
    display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
.company-popup-card {
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    padding:30px 12px 28px; border-radius:18px;
    background:var(--light); border:2px solid #eee;
    text-decoration:none; color:var(--navy);
    transition:all 0.3s ease; cursor:pointer;
    min-height:180px;
}
.company-popup-card:hover {
    border-color:var(--purple); background:var(--purple-light);
    transform:translateY(-6px);
    box-shadow:0 12px 32px rgba(123,45,142,0.18);
}
.company-popup-icon {
    width:72px; height:72px; border-radius:18px;
    background:linear-gradient(135deg, var(--purple), var(--orange));
    display:flex; align-items:center; justify-content:center;
    margin-bottom:18px; font-size:2.2rem;
    transition:transform 0.3s ease;
    box-shadow:0 6px 20px rgba(123,45,142,0.25);
}
.company-popup-card:hover .company-popup-icon {
    transform:scale(1.08);
}
.company-popup-card h3 {
    font-family:'Quicksand', sans-serif; font-size:0.95rem;
    font-weight:700; line-height:1.5; margin:0; color:var(--navy);
}

@media (max-width:600px) {
    .company-popup { padding:36px 24px 28px; border-radius:22px; }
    .company-popup-title { font-size:1.4rem; }
    .company-popup-grid { grid-template-columns:1fr; gap:12px; }
    .company-popup-card { min-height:auto; padding:20px 20px; flex-direction:row; gap:18px; }
    .company-popup-icon { width:56px; height:56px; border-radius:14px; margin-bottom:0; flex-shrink:0; font-size:1.6rem; }
    .company-popup-card h3 { text-align:left; font-size:0.9rem; }
}


/* News/Blog Grid */
.news-section { padding: 80px 0; background: var(--bg-color); }
.news-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 30px; }
.news-card { background: #fff; border-radius: 20px; overflow: hidden; box-shadow: var(--shadow-sm); transition: var(--transition); display: flex; flex-direction: column; border: 1px solid rgba(0,0,0,0.05); }
.news-card:hover { box-shadow: var(--shadow-md); transform: translateY(-5px); }
.news-image { width: 100%; height: 220px; object-fit: cover; }
.news-content { padding: 25px; display: flex; flex-direction: column; flex-grow: 1; }
.news-date { font-size: 0.85rem; color: var(--text-light); margin-bottom: 10px; display: inline-block; font-weight: 500; }
.news-title { font-size: 1.25rem; color: var(--text-color); margin-bottom: 15px; line-height: 1.4; }
.news-summary { color: var(--text-muted); font-size: 0.95rem; line-height: 1.6; margin-bottom: 25px; flex-grow: 1; }
.news-read-more { display: inline-flex; align-items: center; gap: 8px; color: var(--primary-color); font-weight: 600; font-size: 0.95rem; transition: var(--transition); text-decoration: none; margin-top: auto; cursor: pointer; background: transparent; border: none; padding: 0; outline: none; }
.news-read-more:hover { color: var(--secondary-color); gap: 12px; }

/* Modal for Reading Full Article */
.article-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.6); z-index: 9999; display: none; align-items: center; justify-content: center; padding: 20px; backdrop-filter: blur(5px); }
.article-modal.active { display: flex; }
.article-modal-content { background: #fff; width: 100%; max-width: 800px; max-height: 90vh; border-radius: 24px; overflow-y: auto; position: relative; box-shadow: var(--shadow-lg); }
.article-close { position: absolute; top: 20px; right: 20px; background: #f0f0f0; border: none; width: 40px; height: 40px; border-radius: 50%; font-size: 24px; cursor: pointer; display: flex; align-items: center; justify-content: center; z-index: 10; transition: var(--transition); }
.article-close:hover { background: #e0e0e0; color: var(--accent-color); }
.article-header-img { width: 100%; height: 300px; object-fit: cover; }
.article-body { padding: 40px; }
.article-body h2 { color: var(--text-color); margin-bottom: 15px; font-size: 1.8rem; }
.article-body .article-meta { color: var(--text-light); font-size: 0.9rem; margin-bottom: 30px; display: inline-block; }
.article-body .article-text { color: var(--text-muted); line-height: 1.8; font-size: 1.05rem; white-space: pre-wrap; }

