/* Eurobridge Language Institute - Main Styles - v2.0 */

/* 
  COLOR PALETTE REFERENCE
  =======================
  
  PRIMARY COLORS:
  - Primary Blue: #0047AB (var(--blue)) - Headers, banners, buttons, dominant color
  - Rich Gold: #D4AF37 (var(--gold)) - Highlights, CTAs, icons
  
  BLUE SHADES:
  - Dark Navy: #002D70 (var(--blue-dark)) - Backgrounds, footer, text on gold
  - Medium Blue: #3366CC (var(--blue-medium)) - Buttons, hover states, graphics
  - Light Blue: #6699FF (var(--blue-light)) - Subtle backgrounds, overlays
  
  GOLD/YELLOW VARIATIONS:
  - Bright Gold: #FFD700 (var(--gold-bright)) - CTA, highlights
  - Muted Gold: #C9A34D (var(--gold-muted)) - Subtle icons, secondary buttons
  - Pale Gold: #F5E1A4 (var(--gold-pale)) - Background accents, subtle gradients
  
  NEUTRAL COLORS:
  - White: #FFFFFF (var(--white)) - Background, text contrast
  - Light Gray: #F2F2F2 (var(--gray-light)) - Sections, secondary background
  - Medium Gray: #A0A0A0 (var(--gray-medium)) - Subtext, captions
  - Dark Gray: #333333 (var(--gray-dark)) - Text on light background
  
  OPTIONAL ACCENTS:
  - Coral/Orange: #FF6F3C (var(--coral)) - Subtle highlights, buttons
  - Teal/Cyan: #00B4CC (var(--teal)) - Minimal icons, accents
  - Deep Burgundy: #800020 (var(--burgundy)) - Small decorative elements, text
*/

:root{
  /* Primary Colors */
  --blue: #0047AB;
  --gold: #D4AF37;
  
  /* Blue Shades */
  --blue-dark: #002D70;
  --blue-medium: #3366CC;
  --blue-light: #6699FF;
  
  /* Gold Shades */
  --gold-bright: #FFD700;
  --gold-muted: #C9A34D;
  --gold-pale: #F5E1A4;
  --gold-soft: #f4d99b;
  
  /* Neutral Colors */
  --white: #FFFFFF;
  --gray-light: #F2F2F2;
  --gray-medium: #A0A0A0;
  --gray-dark: #333333;
  
  /* Accent Colors (Optional) */
  --coral: #FF6F3C;
  --teal: #00B4CC;
  --burgundy: #800020;
  
  /* Legacy/Alias */
  --bg: #ffffff;
  --muted: #666666;
  
  /* Layout Variables */
  --max-width: 1100px;
  --space-sm: 12px;
  --space-md: 24px;
  --space-lg: 48px;
  --radius-md: 10px;
  --card-shadow: 0 8px 24px rgba(0,71,171,0.06);
}
*{box-sizing:border-box}
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600&family=Poppins:wght@600;700&display=swap');
body{font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;margin:0;color:var(--gray-dark);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}

/* Drop-in Animations */
@keyframes dropIn{0%{opacity:0;transform:translateY(-30px)}100%{opacity:1;transform:translateY(0)}}
@keyframes dropInFade{0%{opacity:0;transform:translateY(-20px)}100%{opacity:1;transform:translateY(0)}}
@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}100%{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{0%{opacity:0}100%{opacity:1}}

/* Animated elements */
header{animation:dropIn 0.6s ease-out}
main section{animation:dropInFade 0.8s ease-out;animation-fill-mode:both}
main section:nth-child(1){animation-delay:0.1s}
main section:nth-child(2){animation-delay:0.2s}
main section:nth-child(3){animation-delay:0.3s}
main section:nth-child(4){animation-delay:0.4s}
main section:nth-child(5){animation-delay:0.5s}
main section:nth-child(6){animation-delay:0.6s}
main section:nth-child(7){animation-delay:0.7s}
main section:nth-child(8){animation-delay:0.8s}
main section:nth-child(9){animation-delay:0.9s}
main section:nth-child(10){animation-delay:1s}
/* Disable animations for carousel elements */
.testimonials-carousel,.testimonials-carousel *{animation:none !important;animation-delay:0s !important}
.hero-fullwidth{animation:slideUp 0.8s ease-out}
footer{animation:dropInFade 0.8s ease-out 1.1s;animation-fill-mode:both}

/* Card animations */
.benefit-card,.program-card,.audience-card,.step,.event-card,.team-member,.partner-item,.faq-item,.course-card,.blog-card{animation:slideUp 0.6s ease-out;animation-fill-mode:both;opacity:0}
.benefit-card:nth-child(1),.program-card:nth-child(1),.audience-card:nth-child(1),.step:nth-child(1),.event-card:nth-child(1),.team-member:nth-child(1),.course-card:nth-child(1),.blog-card:nth-child(1){animation-delay:0.2s}
.benefit-card:nth-child(2),.program-card:nth-child(2),.audience-card:nth-child(2),.step:nth-child(2),.event-card:nth-child(2),.team-member:nth-child(2),.course-card:nth-child(2),.blog-card:nth-child(2){animation-delay:0.3s}
.benefit-card:nth-child(3),.program-card:nth-child(3),.audience-card:nth-child(3),.step:nth-child(3),.event-card:nth-child(3),.team-member:nth-child(3),.course-card:nth-child(3),.blog-card:nth-child(3){animation-delay:0.4s}
.benefit-card:nth-child(4),.program-card:nth-child(4),.audience-card:nth-child(4),.step:nth-child(4),.event-card:nth-child(4),.team-member:nth-child(4),.course-card:nth-child(4),.blog-card:nth-child(4){animation-delay:0.5s}
.benefit-card:nth-child(5),.program-card:nth-child(5),.step:nth-child(5){animation-delay:0.6s}
.benefit-card:nth-child(6),.program-card:nth-child(6){animation-delay:0.7s}
.partner-item{animation-delay:0.1s}
.faq-item:nth-child(1){animation-delay:0.15s}
.faq-item:nth-child(2){animation-delay:0.25s}
.faq-item:nth-child(3){animation-delay:0.35s}
.faq-item:nth-child(4){animation-delay:0.45s}
.faq-item:nth-child(5){animation-delay:0.55s}
.container{max-width:var(--max-width);margin:0 auto;padding:var(--space-md)}
.full-width{max-width:100%;padding:0}
/* Topline */
/* Header topline removed */
header{border-bottom:1px solid var(--gray-light);background:linear-gradient(90deg,rgba(0,71,171,0.04),transparent)}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}
.brand img{height:44px;width:44px}
.brand h1{font-size:18px;margin:0;color:var(--blue);font-weight:700}
/* Headings */
h1,h2,h3,h4{font-family:Poppins,Inter,Segoe UI,Roboto,Arial,sans-serif;color:var(--blue-dark);margin:0 0 12px}
h2{font-size:36px;letter-spacing:-0.02em}
h3{font-size:20px}
h4{font-size:16px}
nav ul{list-style:none;display:flex;gap:18px;margin:0;padding:0}
nav a{color:var(--muted);text-decoration:none;font-weight:600}
nav a.active,nav a:hover{color:var(--blue)}
.lang-select{border:1px solid var(--gray-light);padding:6px;border-radius:6px}
/* Full-width hero at page top */
.hero-fullwidth{width:100%;margin:0;padding:0;position:relative;background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 50%,#001a3d 100%)}
.hero-fullwidth .hero-media{border-radius:0;margin:0;width:100%;max-width:100%;min-height:70vh;display:flex;align-items:center;position:relative;background:linear-gradient(135deg,rgba(0,71,171,0.95) 0%,rgba(0,49,102,0.9) 100%)}
.hero-fullwidth .hero-video{border-radius:0;max-height:75vh;width:100%;object-fit:cover;display:block;position:absolute;top:0;left:0;height:100%;z-index:0}
.hero{display:flex;align-items:center;gap:24px;padding:48px 0}
.hero.full-width{padding:0;display:block}
.hero h2{font-size:44px;margin:0 0 16px;color:var(--blue);text-shadow:0 6px 20px rgba(0,71,171,0.06)}
.hero p{font-size:18px;color:var(--muted);margin:0 0 18px}
.cta{display:inline-block;background:linear-gradient(90deg,var(--gold),var(--gold-bright));color:var(--gray-dark);padding:14px 22px;border-radius:12px;text-decoration:none;font-weight:800;box-shadow:0 10px 28px rgba(0,71,171,0.08);transition:transform .18s ease,box-shadow .18s ease}
.cta:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(4,71,171,0.12)}
.cta{background-size:200% 100%;transition:background-position .6s ease, transform .18s ease}
.cta:hover{background-position:100% 0}
.cta-register{background:var(--blue);color:var(--white);margin-left:12px;border-radius:12px;padding:12px 18px;box-shadow:0 8px 26px rgba(0,71,171,0.12);font-weight:700;transition:transform .18s ease,box-shadow .18s}
.cta-register:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(2,18,70,0.16)}

/* Make all CTAs change color on hover (consistent) */
.cta, .cta-register, .back-to-top{transition:background .18s ease,color .18s ease,transform .18s ease}
.cta:hover{background:linear-gradient(90deg,var(--gold-muted),var(--gold-pale));color:var(--gray-dark)}
.back-to-top:hover{background:rgba(255,255,255,0.06)}

/* Header improvements */
header{position:sticky;top:0;z-index:120;backdrop-filter:blur(6px);transition:box-shadow .18s ease,background .18s ease}
header .topbar{padding:14px 0;transition:padding .18s ease}
header.scrolled{box-shadow:0 6px 28px rgba(0,71,171,0.08);background:rgba(255,255,255,0.96)}
header.scrolled .brand img{height:40px}
.brand h1{font-size:18px}

/* Nav underline hover */
nav a{position:relative;padding:6px 2px}
nav a::after{content:'';position:absolute;left:0;right:0;bottom:-6px;height:2px;background:transparent;transition:background .18s ease,transform .18s ease;transform:scaleX(0)}
nav a:hover::after, nav a.active::after{background:var(--blue);transform:scaleX(1)}

@media (max-width:800px){
  header .topbar{padding:10px 0}
  .brand img{height:36px}
}
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-top:24px}
.card{border:1px solid var(--gray-light);padding:18px;border-radius:8px;background:var(--white)}
.card{transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-6px);box-shadow:var(--card-shadow)}
/* Course thumbnails */
.course-thumb{width:100%;height:160px;object-fit:cover;border-radius:8px;margin-bottom:12px;display:block}
.course-thumb.small{height:120px}

/* Section headers */
.section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.section-header h3{margin:0}
.callout{background:linear-gradient(90deg,var(--blue-light)10%,var(--gray-light));border-left:6px solid var(--gold-bright);padding:18px;border-radius:10px;box-shadow:var(--card-shadow);margin-bottom:24px}

/* Courses grid */
.courses-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:12px}
.course-card{background:var(--white);padding:18px;border-radius:10px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;gap:10px}
.course-card h4{margin:0}
.course-card p{margin:0;color:var(--muted)}
.course-card .cta{margin-top:auto;align-self:flex-start}

/* Accreditation */
.accreditation{margin-top:28px;padding:18px;border-radius:12px;background:var(--white);display:flex;align-items:center;gap:18px;box-shadow:var(--card-shadow)}
.accreditation h4{margin:0}
.accreditation-logos{display:flex;gap:12px;align-items:center}
.accreditation-logos img{height:44px;width:auto;opacity:.95}

/* WhatsApp FAB */
.whatsapp-fab{position:fixed;right:18px;bottom:18px;background:#25D366;color:var(--white);padding:12px 14px;border-radius:999px;box-shadow:0 14px 36px rgba(0,0,0,0.18);z-index:160;text-decoration:none;display:flex;gap:10px;align-items:center}
.whatsapp-fab svg{width:18px;height:18px}
.whatsapp-fab.pulse{animation:fabPulse 2.2s ease-in-out}
@keyframes fabPulse{0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}}

/* Testimonials */
.testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-top:12px}
.testimonial{background:var(--white);padding:18px;border-radius:12px;box-shadow:var(--card-shadow);display:flex;gap:12px;align-items:flex-start}
.testimonial img{height:64px;width:64px;border-radius:10px;flex-shrink:0}
.testimonial blockquote{margin:0;font-style:normal;color:var(--gray-dark)}
.testimonial cite{display:block;margin-top:8px;color:var(--muted);font-size:13px}

/* Team grid */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-top:18px}
.team-card{background:var(--white);padding:16px;border-radius:10px;box-shadow:var(--card-shadow);text-align:center}
.team-card img{height:86px;width:86px;border-radius:50%;margin-bottom:8px}

/* FAQ */
.faq{margin-top:18px}
.faq-item{border:1px solid var(--gray-light);border-radius:10px;margin-bottom:12px;overflow:hidden;background:var(--white)}
.faq-question{padding:14px 16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-answer{padding:0 16px 16px 16px;display:none;color:var(--muted)}
.faq-item.open .faq-answer{display:block}

footer{border-top:1px solid var(--gray-light);padding:24px 0;margin-top:48px;color:var(--muted)}
.muted{color:var(--muted)}

/* Stylish footer */
.site-footer{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 60%);color:var(--white);padding:48px 0;margin-top:64px;border-top:none}
.full-width-footer{width:100%;max-width:100%;margin:0;padding:48px 0}
.full-width-footer .container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-md)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;align-items:start}
.footer-brand{grid-column:1 / 2;grid-row:1 / 3}
.footer-contact{grid-column:1 / 2;grid-row:2 / 3;margin-top:12px}
.footer-social{grid-column:2 / 3;align-self:center}
.footer-brand .brand{align-items:center}
.footer-brand .brand img{height:56px;width:auto}
.footer-brand h3{color:var(--gold-bright);margin:8px 0 6px}
.footer-contact h4,.footer-social h4{margin:0 0 8px;color:var(--white)}
.footer-contact p{margin:6px 0;color:rgba(255,255,255,0.9)}
.footer-contact a{color:rgba(255,255,255,0.95);text-decoration:none}
.footer-contact a:hover{text-decoration:underline}
.social-links{display:flex;gap:15px;margin-top:12px;flex-wrap:wrap}
.social{display:inline-flex;width:50px;height:50px;align-items:center;justify-content:center;border-radius:12px;background:rgba(255,255,255,0.08);transition:transform .3s ease,background .3s ease,box-shadow .3s ease;border:1px solid rgba(255,255,255,0.1);text-decoration:none}
.social svg{width:24px;height:24px;fill:var(--white);transition:fill .3s ease}
.social:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,0.3)}
.social.whatsapp:hover{background:linear-gradient(135deg,#25D366,#128C7E);border-color:#25D366}
.social.facebook:hover{background:linear-gradient(135deg,#1877F2,#0d5dbf);border-color:#1877F2}
.social.instagram:hover{background:linear-gradient(135deg,#E1306C,#FD1D1D,#F77737,#FCAF45);border-color:#E1306C}
.social.tiktok:hover{background:linear-gradient(135deg,#000000,#00f2ea);border-color:#00f2ea}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:28px;border-top:1px solid rgba(255,255,255,0.06);padding-top:18px;font-size:14px;color:rgba(255,255,255,0.9)}
.back-to-top{color:var(--gold-bright);text-decoration:none;padding:8px 10px;border-radius:6px;background:rgba(255,255,255,0.03)}

@media (max-width:800px){
  .footer-grid{grid-template-columns:1fr;gap:18px;text-align:center}
  .footer-brand{grid-row:auto}
  .footer-contact{grid-row:auto;margin-top:0}
  .footer-social{grid-column:auto}
  .footer-bottom{flex-direction:column;gap:8px}
}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s cubic-bezier(.2,.9,.2,1)}
.reveal.active{opacity:1;transform:translateY(0)}

/* Subtle entrance for hero */
.hero-left .reveal{transition-duration:.7s}
.hero .hero-media{opacity:0;transform:scale(.98) translateY(8px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.9,.2,1)}
.hero .hero-media.active{opacity:1;transform:scale(1) translateY(0)}

/* Hero video styles */
.hero-video{width:100%;aspect-ratio:16/9;height:auto;max-height:520px;border-radius:12px;box-shadow:0 18px 50px rgba(2,18,70,0.12);object-fit:cover}
.hero-video::-webkit-media-controls{display:none !important}

/* Hero video container */
.hero-media{position:relative;overflow:hidden;border-radius:12px;margin-bottom:18px}
.hero-media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.0),rgba(0,0,0,0.06));pointer-events:none}
.video-toggle{position:absolute;right:18px;bottom:18px;background:rgba(0,71,171,0.95);color:var(--white);border:none;padding:10px 12px;border-radius:999px;cursor:pointer;box-shadow:0 6px 20px rgba(0,0,0,0.2);font-size:16px}
.video-toggle:active{transform:scale(.98)}
/* Hero overlay */
.hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.25);display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;z-index:2}
.hero-overlay .overlay-inner{max-width:720px;color:var(--white)}
.hero-overlay .overlay-inner h2{margin:0 0 16px;font-size:38px;color:var(--white);text-shadow:0 4px 12px rgba(0,0,0,0.4)}
.hero-overlay .overlay-inner p{margin:0 0 24px;color:var(--white);font-size:18px;text-shadow:0 2px 8px rgba(0,0,0,0.3);line-height:1.6}
.overlay-ctas{display:flex;gap:10px;align-items:center}
.overlay-ctas{justify-content:center}
.cta-primary{background:var(--gold-bright);color:var(--gray-dark);padding:16px 32px;font-size:16px;border-radius:8px;font-weight:700;text-decoration:none;box-shadow:0 8px 24px rgba(212,175,55,0.3)}
.cta-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(212,175,55,0.4)}
.cta-secondary{background:rgba(255,255,255,0.15);color:var(--white);padding:16px 32px;font-size:16px;border-radius:8px;font-weight:700;text-decoration:none;border:2px solid rgba(255,255,255,0.5);backdrop-filter:blur(8px)}
.cta-secondary:hover{background:rgba(255,255,255,0.25);border-color:rgba(255,255,255,0.8)}

/* Stats Banner */
.stats-banner{display:flex;justify-content:space-around;align-items:center;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:var(--white);padding:32px 24px;margin:0;width:100%;max-width:100%}
.stat-item{text-align:center}
.stat-number{font-size:42px;font-weight:700;margin-bottom:8px;color:var(--gold-bright)}
.stat-label{font-size:14px;color:rgba(255,255,255,0.9)}

/* Courses intro section */
.courses-intro{max-width:var(--max-width);margin:48px auto;padding:var(--space-md);text-align:center}
.courses-intro h2{font-size:32px;margin-bottom:16px}
.courses-intro p{font-size:18px;color:var(--muted);margin-bottom:18px}
.course-features{list-style:none;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:18px;margin:24px 0}
.course-features li{background:var(--gray-light);padding:12px 18px;border-radius:8px;font-weight:600;color:var(--blue)}

/* Category grid */
#course-categories{max-width:var(--max-width);margin:48px auto;padding:var(--space-md)}
#course-categories h2{text-align:center;font-size:32px;margin-bottom:24px}
.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}

/* Popular courses */
#popular-courses{max-width:var(--max-width);margin:48px auto;padding:var(--space-md)}
#popular-courses h2{text-align:center;margin-bottom:20px}
.popular-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.popular-card{background:var(--white);border:1px solid var(--gray-light);border-radius:12px;padding:18px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;gap:10px}
.popular-card .meta{color:var(--muted);font-size:13px}

/* Locations */
.locations{max-width:var(--max-width);margin:32px auto;padding:var(--space-md);text-align:center}
.location-grid{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
.chip{padding:10px 14px;border-radius:999px;background:var(--blue-light);color:var(--white);font-weight:600}

/* About courses */
.about-courses{max-width:var(--max-width);margin:40px auto;padding:var(--space-md)}
.about-courses h2{text-align:center;margin-bottom:16px}
.about-list{list-style:disc;padding-left:24px;color:var(--gray-dark);line-height:1.6}

/* Blog preview */
.blog-preview{max-width:var(--max-width);margin:48px auto;padding:var(--space-md)}
.blog-preview h2{text-align:center;margin-bottom:20px}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.blog-card{background:var(--white);border:1px solid var(--gray-light);border-radius:12px;padding:18px;box-shadow:var(--card-shadow)}

/* CTA strip */
.cta-strip{max-width:var(--max-width);margin:48px auto;padding:0 var(--space-md)}
.cta-strip-inner{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:var(--white);border-radius:14px;padding:20px 24px;box-shadow:var(--card-shadow)}
.cta-strip-inner h3{margin:0;color:var(--white)}
.cta-strip-inner p{margin:4px 0 0;color:rgba(255,255,255,0.9)}

@media (max-width:800px){
  .cta-strip-inner{flex-direction:column;align-items:flex-start;gap:10px}
}

/* Scroll indicator */
.scroll-down{position:absolute;left:50%;transform:translateX(-50%);bottom:6px;text-decoration:none;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:6px;font-weight:700;opacity:0.95}
.scroll-down .arrow{display:inline-block;font-size:22px;animation:bounce 1.6s infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* Decorative blob */
.hero-media::before{content:'';position:absolute;right:-8%;top:-8%;width:420px;height:420px;background:url('/assets/images/shape-blob.svg') no-repeat center/cover;opacity:0.9;pointer-events:none}

/* Sticky register CTA for small screens */
.sticky-register{display:none}
@media (max-width:800px){
  .hero-overlay{position:relative;left:auto;bottom:auto;margin-bottom:12px;padding:14px}
  .hero-media::before{display:none}
  .scroll-down{position:relative;transform:none;bottom:auto;margin-top:8px}
  .sticky-register{display:block;position:fixed;right:16px;bottom:16px;background:var(--blue);color:var(--white);padding:12px 14px;border-radius:12px;box-shadow:0 12px 30px rgba(0,71,171,0.16);z-index:140}
}

/* prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
  .reveal, .scroll-down .arrow, .cta-register:hover{animation:none !important;transition:none !important}
}

/* Mobile responsive hero video height */
@media (max-width:800px){
  .hero-fullwidth .hero-video{max-height:50vh}
  .hero-fullwidth .hero-media{min-height:50vh}
  .hero{flex-direction:column;text-align:center;padding:28px 0}
  .hero.full-width{padding:0}
  .hero-media{width:100%;margin-bottom:12px}
  .hero-video{max-height:260px;aspect-ratio:16/9}
  .hero-overlay .overlay-inner h2{font-size:24px}
  .hero-overlay .overlay-inner p{font-size:15px}
  .overlay-ctas{flex-direction:column;width:100%}
  .overlay-ctas .cta{width:100%;text-align:center}
  .stats-banner{flex-direction:column;gap:24px;padding:24px}
  .category-grid{grid-template-columns:1fr}
}

/* Mobile nav toggle */
.nav-toggle{display:none;background:transparent;border:0;color:var(--blue);font-size:20px;cursor:pointer}
@media (max-width:800px){
  .nav-toggle{display:inline-flex;align-items:center;gap:8px}
  nav{display:none;position:fixed;right:12px;top:64px;background:var(--white);padding:18px;border-radius:10px;box-shadow:0 12px 34px rgba(0,71,171,0.12)}
  nav.open{display:block}
  nav ul{flex-direction:column;gap:8px}
}

/* Simple keyframes for creative entrance */
@keyframes popIn {0%{opacity:0;transform:scale(.98) translateY(12px)}100%{opacity:1;transform:scale(1) translateY(0)}}
.reveal.active{animation:popIn .64s cubic-bezier(.2,.9,.2,1) both}

/* Card hover polish */
.card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 18px 42px rgba(2,18,70,0.12)}

/* Subtle float animation for CTA */
@keyframes floatY {0%{transform:translateY(0)}50%{transform:translateY(-4px)}100%{transform:translateY(0)}}
.cta-register:hover{animation:floatY .9s ease-in-out;box-shadow:0 22px 48px rgba(2,18,70,0.18)}

/* Hero video active polish */
.hero-video.active{transform:scale(1.01);filter:contrast(1.02) saturate(1.03)}

/* Stagger utilities */
[data-reveal-delay]{transition-delay: var(--reveal-delay-ms, 0ms)}

/* Simple fade-in on load for images */
.img-soft{opacity:0;transform:translateY(8px);transition:opacity .6s ease,transform .6s ease}
.img-soft.active{opacity:1;transform:translateY(0)}

/* Responsive */
@media (max-width:800px){.hero{flex-direction:column;text-align:center}.brand h1{font-size:16px}}

/* Hide language selector on very small screens to reduce clutter */
@media (max-width:480px){
  .lang-select{display:none}
  .brand h1{font-size:15px}
  h2{font-size:28px}
  .cta{padding:12px 16px}
}

/* NEW HOMEPAGE SECTIONS */

/* Why Eurobridge */
.why-section{margin:64px auto 48px;padding:var(--space-md);text-align:center}
.why-section h2{font-size:36px;margin-bottom:32px}
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:32px}
.benefit-card{
  background:var(--white);
  padding:40px 28px;
  border-radius:16px;
  box-shadow:0 8px 32px rgba(0,0,0,0.12);
  transition:all .4s cubic-bezier(0.4, 0, 0.2, 1);
  position:relative;
  overflow:hidden;
  min-height:280px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  color:var(--white);
  border:2px solid rgba(255,255,255,0.1);
}
.benefit-card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:linear-gradient(135deg, rgba(0,119,182,0.3), rgba(0,53,102,0.5));
  opacity:0;
  transition:opacity .4s ease;
  z-index:1;
}
.benefit-card:hover{
  transform:translateY(-8px) scale(1.02);
  box-shadow:0 16px 48px rgba(0,0,0,0.2);
  border-color:rgba(255,255,255,0.3);
}
.benefit-card:hover::before{
  opacity:1;
}
.benefit-icon{font-size:48px;margin-bottom:16px}
.benefit-card h3{
  font-size:22px;
  margin-bottom:12px;
  color:var(--white);
  font-weight:700;
  position:relative;
  z-index:2;
  text-shadow:0 2px 8px rgba(0,0,0,0.3);
}
.benefit-card p{
  color:rgba(255,255,255,0.95);
  font-size:15px;
  line-height:1.6;
  position:relative;
  z-index:2;
  text-shadow:0 1px 4px rgba(0,0,0,0.2);
}

/* Programs Section */
.programs-section{margin:64px auto;padding:var(--space-md)}
.programs-section h2{font-size:36px;margin-bottom:32px;text-align:center}
.programs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.program-card{background:var(--white);padding:24px;border-radius:12px;border:1px solid var(--gray-light);box-shadow:var(--card-shadow);display:flex;flex-direction:column;gap:12px}
.program-card h3{margin:0;color:var(--blue-dark);font-size:20px}
.level-badge{display:inline-block;background:linear-gradient(90deg,var(--gold),var(--gold-bright));color:var(--gray-dark);padding:6px 12px;border-radius:6px;font-size:13px;font-weight:700;margin:0}
.program-card p{color:var(--muted);line-height:1.6;margin:0}
.program-card .cta{margin-top:auto;align-self:flex-start}

/* Audience Section */
.audience-section{margin:64px auto;padding:var(--space-md);background:linear-gradient(135deg,var(--gray-light),var(--white))}
.audience-section h2{font-size:36px;margin-bottom:32px;text-align:center}
.audience-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}
.audience-card{background:var(--white);padding:24px;border-radius:12px;box-shadow:var(--card-shadow);border-left:4px solid var(--gold-bright)}
.audience-card h3{margin:0 0 12px;color:var(--blue-dark);font-size:18px}
.audience-card p{color:var(--muted);margin:0;line-height:1.6}

/* Process / How It Works */
.process-section{margin:64px auto;padding:var(--space-md)}
.process-section h2{font-size:36px;margin-bottom:32px;text-align:center}
.process-steps{display:flex;flex-wrap:wrap;gap:24px;justify-content:center}
.step{flex:1;min-width:180px;max-width:220px;text-align:center;padding:20px;background:var(--white);border-radius:12px;box-shadow:var(--card-shadow)}
.step-number{width:56px;height:56px;margin:0 auto 16px;background:linear-gradient(135deg,var(--blue),var(--blue-medium));color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700}
.step h3{font-size:16px;margin:0 0 8px;color:var(--blue-dark)}
.step p{font-size:14px;color:var(--muted);margin:0;line-height:1.5}

/* Events Section */
.events-section{margin:64px auto;padding:var(--space-md)}
.events-section h2{font-size:36px;margin-bottom:32px;text-align:center}
.events-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.event-card{background:linear-gradient(135deg,var(--white),var(--gray-light));padding:24px;border-radius:12px;box-shadow:var(--card-shadow);border-top:4px solid var(--gold-bright)}
.event-date{background:var(--blue-medium);color:var(--white);display:inline-block;padding:6px 12px;border-radius:6px;font-size:14px;font-weight:700;margin-bottom:12px}
.event-card h3{margin:0 0 12px;color:var(--blue-dark);font-size:20px}
.event-card p{color:var(--muted);margin:0 0 16px;line-height:1.6}

/* Testimonials Section */
.testimonials-section{margin:64px auto;padding:var(--space-md);background:linear-gradient(135deg,var(--gray-light),var(--white))}
.testimonials-section h2{font-size:36px;margin-bottom:32px;text-align:center}
.testimonials-carousel{position:relative;max-width:800px;margin:0 auto;min-height:400px;display:flex;flex-direction:column;gap:20px}
.testimonials-grid{position:relative;flex:1;width:100%;min-height:300px}
.testimonial-card{background:var(--white);padding:32px;border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,0.1);display:flex;flex-direction:column;gap:16px;position:absolute;top:0;left:0;right:0;opacity:0;visibility:hidden;transition:opacity 0.6s ease;z-index:1}
.testimonial-card.active{opacity:1;visibility:visible;z-index:2}
.testimonial-photo{width:80px;height:80px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;margin:0 auto 16px}
.testimonial-card blockquote{margin:0;font-style:italic;color:var(--gray-dark);line-height:1.8;font-size:18px;text-align:center}
.testimonial-card cite{font-style:normal;color:var(--muted);font-size:15px;font-weight:600;display:flex;flex-direction:column;gap:4px;text-align:center;align-items:center}
.status{font-size:14px;color:var(--blue);font-weight:400}
.carousel-dots{display:flex !important;justify-content:center;align-items:center;gap:12px;padding:20px 0;z-index:10;position:relative}
.carousel-dot{width:12px;height:12px;border-radius:50%;background:#ccc;cursor:pointer;transition:all 0.3s ease;border:2px solid transparent;padding:0;outline:none}
.carousel-dot:hover{background:#999}
.carousel-dot.active{background:var(--blue);transform:scale(1.3)}

/* Team Section */
.team-section{margin:64px auto;padding:var(--space-md)}
.team-section h2{font-size:36px;margin-bottom:32px;text-align:center}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}
.team-member{background:var(--white);padding:24px;border-radius:12px;box-shadow:var(--card-shadow);text-align:center}
.team-photo{width:96px;height:96px;margin:0 auto 16px;background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:var(--gray-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700}
.team-member h3{margin:0 0 4px;color:var(--blue-dark);font-size:18px}
.team-role{color:var(--blue);font-weight:600;font-size:14px;margin:0 0 12px}
.team-member p{color:var(--muted);font-size:14px;line-height:1.6;margin:0}

/* Partners Section */
.partners-section{margin:64px auto;padding:var(--space-md);text-align:center;background:var(--gray-light)}
.partners-section h2{font-size:36px;margin-bottom:40px}
.partners-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px;max-width:900px;margin:0 auto}
.partner-logo{background:var(--white);padding:24px;border-radius:12px;box-shadow:0 4px 12px rgba(0,71,171,0.08);display:flex;flex-direction:column;align-items:center;gap:16px;transition:transform 0.3s ease,box-shadow 0.3s ease;min-height:180px;justify-content:center}
.partner-logo:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,71,171,0.15)}
.partner-img{max-width:120px;max-height:80px;width:auto;height:auto;object-fit:contain}
.partner-icon{font-size:48px;line-height:1}
.partner-logo span{font-weight:600;color:var(--blue-dark);font-size:13px;text-align:center;line-height:1.4}

/* FAQ Section */
.faq-section{margin:64px auto;padding:var(--space-md)}
.faq-section h2{font-size:36px;margin-bottom:32px;text-align:center}

/* Final CTA Section */
.final-cta-section{margin:64px auto 80px;padding:var(--space-md)}
.cta-box{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:var(--white);padding:48px 32px;border-radius:16px;text-align:center;box-shadow:0 12px 40px rgba(0,71,171,0.16)}
.cta-box h2{color:var(--white);font-size:40px;margin:0 0 16px}
.cta-box p{color:rgba(255,255,255,0.95);font-size:18px;margin:0 0 32px;max-width:720px;margin-left:auto;margin-right:auto;line-height:1.7}
.cta-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.cta-buttons .cta{font-size:16px;padding:16px 28px}

@media (max-width:800px){
  /* Container and spacing */
  .container{padding:16px}
  
  /* Header */
  .topbar{flex-direction:column;gap:16px;padding:12px 0}
  .brand img{width:40px;height:40px}
  .brand h1{font-size:18px}
  nav ul{flex-direction:column;gap:8px;text-align:center}
  nav ul li{margin:0}
  nav ul li a{padding:8px 16px;font-size:14px}
  .lang-select{width:100%;max-width:200px}
  
  /* Hero */
  .hero-fullwidth{min-height:400px}
  .hero-overlay .overlay-inner{padding:24px 16px}
  .hero-overlay h2{font-size:24px;line-height:1.3}
  .hero-overlay p{font-size:15px}
  .overlay-ctas{flex-direction:column;gap:12px}
  .overlay-ctas .cta{width:100%;text-align:center}
  
  /* Section headings */
  h2{font-size:28px !important}
  h3{font-size:18px !important}
  
  /* Grids */
  .benefits-grid,.programs-grid,.audience-grid,.events-grid,.testimonials-grid,.team-grid,.partners-grid{grid-template-columns:1fr;gap:16px}
  
  /* Cards */
  .benefit-card,.program-card,.audience-card,.event-card,.team-member,.partner-logo{padding:20px}
  .benefit-icon{font-size:36px}
  .level-badge{font-size:12px;padding:6px 12px}
  
  /* Process steps */
  .process-steps{flex-direction:column;align-items:center}
  .step{max-width:100%;padding:20px}
  .step-number{width:50px;height:50px;font-size:22px}
  
  /* Testimonials carousel */
  .testimonials-carousel{min-height:350px;padding:0 8px}
  .testimonials-grid{min-height:280px}
  .testimonial-card{padding:24px 16px}
  .testimonial-photo{width:60px;height:60px;font-size:20px}
  .testimonial-card blockquote{font-size:16px;line-height:1.6}
  .testimonial-card cite{font-size:14px}
  .carousel-dots{gap:8px;padding:16px 0}
  .carousel-dot{width:10px;height:10px}
  
  /* Partners */
  .partner-logo{min-height:120px;padding:16px}
  .partner-icon{font-size:36px}
  .partner-logo span{font-size:12px}
  
  /* FAQ */
  .faq-item{padding:16px}
  .faq-question{font-size:15px}
  .faq-answer{font-size:14px;padding:12px 0 0}
  
  /* CTA */
  .cta-box{padding:32px 20px}
  .cta-box h2{font-size:26px !important}
  .cta-box p{font-size:16px}
  .cta-buttons{flex-direction:column;gap:12px}
  .cta-buttons .cta{width:100%;text-align:center;padding:14px 24px}
  
  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:32px;text-align:center}
  .footer-brand,.footer-contact,.footer-social{text-align:center}
  .social-links{justify-content:center}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  
  /* Buttons */
  .cta{font-size:14px;padding:12px 24px}
}

/* Tablet adjustments */
@media (min-width:601px) and (max-width:800px){
  .benefits-grid,.programs-grid,.audience-grid,.events-grid,.team-grid,.partners-grid{grid-template-columns:repeat(2,1fr)}
}

/* Small mobile phones */
@media (max-width:400px){
  .hero-overlay h2{font-size:20px}
  .hero-overlay p{font-size:14px}
  h2{font-size:24px !important}
  .cta-box h2{font-size:22px !important}
  .testimonial-card blockquote{font-size:15px}
  .benefit-icon{font-size:32px}
  .partner-icon{font-size:32px}
}

/* Desktop: overlay hero text on video for a more creative layout */
@media (min-width:1100px){
  .hero{padding:32px 0}
  .hero-media{display:block;position:relative}
  .hero-left{position:relative;margin-top: -120px;background:linear-gradient(90deg, rgba(255,255,255,0.85), rgba(255,255,255,0.75));padding:24px;border-radius:12px;box-shadow:var(--card-shadow);max-width:520px}
}

/* Cache bust: 20260107162851 */

/* Form Styles */
input[type="text"],
input[type="email"],
textarea {
  width: 100%;
  padding: 8px;
  margin: 6px 0;
  border: 1px solid var(--gray-light);
  border-radius: 6px;
  font-family: inherit;
  font-size: 14px;
  transition: border-color 0.2s ease;
}

input[type="text"]:focus,
input[type="email"]:focus,
textarea:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(0, 71, 171, 0.1);
}

label {
  display: block;
  margin-top: 12px;
  font-weight: 600;
  color: var(--blue-dark);
}
