
:root {
  --blue: #1A8FC4;
  --blue-light: #4DB8E0;
  --blue-bright: #22A8E0;
  --blue-dark: #0A6E9A;
  --blue-deep: #084B6A;
  --cyan: #3CB8D4;
  --cyan-pale: #D2EEF6;

  /* Stronger background with more contrast */
  --bg: #E4EBF0;
  --bg-alt: #D6E0E8;
  --bg-card: #FFFFFF;
  --bg-warm: #DCE5EC;
  --white: #FFFFFF;

  /* High contrast text colors */
  --dark: #091820;
  --text-primary: #091820;
  --text-secondary: #2E4A5C;
  --text-muted: #3D6070;
  --text-on-card: #1A3040;

  --border: rgba(10,110,154,0.18);
  --border-hover: rgba(26,143,196,0.4);
  --shadow-sm: 0 2px 16px rgba(9,24,32,0.08);
  --shadow: 0 8px 40px rgba(9,24,32,0.1);
  --shadow-hover: 0 16px 60px rgba(26,143,196,0.15);

  --font: 'Sora', sans-serif;
  --font-guj: 'Noto Sans Gujarati', sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text-primary);overflow-x:hidden}

/* PRELOADER */
.preloader{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px;animation:fadeOut .6s ease 2s forwards}
.preloader img{width:250px;animation:lp .8s ease infinite alternate}
.preloader-text{font-size:12px;color:var(--blue-dark);letter-spacing:5px;text-transform:uppercase;font-weight:600}
@keyframes lp{from{opacity:.5;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
@keyframes fadeOut{to{opacity:0;pointer-events:none}}

/* GRAIN */
body::after{content:'';position:fixed;inset:0;opacity:.02;pointer-events:none;z-index:999;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 60px;display:flex;align-items:center;justify-content:space-between;transition:all .4s;background:transparent}
nav.scrolled{background:rgba(228,235,240,.94);backdrop-filter:blur(24px);padding:12px 60px;box-shadow:0 1px 30px rgba(9,24,32,.08)}
.logo{display:flex;align-items:center;text-decoration:none}
.logo img{height:44px;width:auto;transition:height .3s}
nav.scrolled .logo img{height:36px}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none}
.nav-links a{color:var(--text-secondary);text-decoration:none;font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--blue);transition:width .3s;border-radius:2px}
.nav-links a:hover{color:var(--blue-dark)}
.nav-links a:hover::after{width:100%}
.nav-cta{padding:10px 26px!important;background:var(--blue)!important;border:none!important;color:var(--white)!important;border-radius:6px;cursor:pointer;transition:all .3s;font-weight:600!important}
.nav-cta:hover{background:var(--blue-bright)!important;box-shadow:0 6px 24px rgba(26,143,196,.35);transform:translateY(-1px)}
.nav-cta::after{display:none!important}
.hamburger{display:none;flex-direction:column;gap:6px;cursor:pointer;z-index:200}
.hamburger span{width:26px;height:2px;background:var(--blue-dark);transition:.3s}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--bg)}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 65% 30%,rgba(60,184,212,.16) 0%,transparent 55%),radial-gradient(ellipse at 15% 70%,rgba(26,143,196,.1) 0%,transparent 50%)}
.hero-swoosh{position:absolute;top:8%;right:6%;width:420px;height:420px;opacity:.07}
.hero-swoosh .arc{position:absolute;border:2.5px solid var(--blue);border-radius:50%;border-right-color:transparent;border-bottom-color:transparent;animation:sw 35s linear infinite}
.hero-swoosh .arc:nth-child(1){inset:0}
.hero-swoosh .arc:nth-child(2){inset:35px;animation-duration:42s}
.hero-swoosh .arc:nth-child(3){inset:70px;animation-duration:50s}
@keyframes sw{to{transform:rotate(360deg)}}

.hero-content{position:relative;z-index:2; max-width:820px;animation:heroIn .9s ease 2.1s both}
@keyframes heroIn{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.hero-eyebrow{font-size:13px;color:var(--blue-dark);margin-bottom:14px;font-weight:600;letter-spacing:3px;text-transform:uppercase}
.hero h1 .blue{color:var(--blue)}
.hero-desc{font-size:17px;line-height:1.8;color:var(--text-secondary);max-width:520px;margin-bottom:40px;font-weight:400}
.hero-desc strong{color:var(--dark);font-weight:600}
.hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:10px;padding:15px 36px;background:var(--blue);color:var(--white);font-family:var(--font);font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;text-decoration:none;border:none;border-radius:6px;cursor:pointer;transition:all .3s}
.btn-primary:hover{background:var(--blue-bright);transform:translateY(-2px);box-shadow:0 12px 40px rgba(26,143,196,.3)}
.btn-secondary{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;background:transparent;color:var(--blue-deep);font-family:var(--font);font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;text-decoration:none;border:2px solid var(--blue);border-radius:6px;cursor:pointer;transition:all .3s}
.btn-secondary:hover{background:var(--blue);color:var(--white)}

.hero-logo-float{position:absolute;right:60px;top:50%;transform:translateY(-50%);width:300px;opacity:.08;pointer-events:none;animation:heroIn 1.2s ease 2.4s both}

/* ========================================
   REDESIGNED HERO SECTION - OPTION 1: SPLIT SCREEN
   ======================================== */
.hero{
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  position:relative;
  overflow:hidden;
  background:var(--bg);
  gap:60px;
  padding:0 80px;
}

/* Left side - Content */
.hero-content{
  position:relative;
  z-index:2;
  animation:heroIn .9s ease 2.1s both;
}

@keyframes heroIn{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:translateY(0)}
}

.hero-eyebrow{
  font-size:13px;
  color:var(--blue-dark);
  margin-bottom:14px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
}

.hero h1{
  font-size:clamp(40px,5.5vw,60px);
  font-weight:800;
  line-height:1.08;
  margin-bottom:28px;
  color:var(--dark);
  letter-spacing:-1px;
}

.hero h1 .blue{
  color:var(--blue);
}

.hero-desc{
  font-size:17px;
  line-height:1.8;
  color:var(--text-secondary);
  max-width:520px;
  margin-bottom:40px;
  font-weight:400;
}

.hero-desc strong{
  color:var(--dark);
  font-weight:600;
}

.hero-actions{
  display:flex;
  gap:14px;
  align-items:center;
  flex-wrap:wrap;
}

/* Right side - Visual with Logo */
.hero-visual{
  position:relative;
  height:600px;
  animation:heroIn 1.2s ease 2.3s both;
}

/* Decorative frame */
.hero-frame{
  position:absolute;
  inset:20px;
  border:2px solid rgba(26,143,196,.2);
  border-radius:24px;
  background:linear-gradient(135deg, rgba(26,143,196,.08) 0%, rgba(210,238,246,.4) 100%);
  backdrop-filter:blur(10px);
  box-shadow:var(--shadow);
  display: none;
}

/* Main logo container */
.hero-logo-container{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
}

.hero-logo-main{
  width:100%;
  /*max-width:380px;*/
  height:auto;
  position:relative;
  z-index:3;
  filter:drop-shadow(0 20px 60px rgba(26,143,196,.25));
  animation:logoFloat 6s ease-in-out infinite;
}

@keyframes logoFloat{
  0%, 100%{transform:translateY(0) rotate(0deg)}
  25%{transform:translateY(-12px) rotate(-1deg)}
  50%{transform:translateY(0) rotate(0deg)}
  75%{transform:translateY(-8px) rotate(1deg)}
}

/* Rotating arcs behind logo */
.hero-arcs{
  position:absolute;
  inset:0;
  overflow:hidden;
  border-radius:24px;
}

.hero-arc{
  position:absolute;
  border:2px solid rgba(26,143,196,.15);
  border-radius:50%;
  border-right-color:transparent;
  border-bottom-color:transparent;
}

.hero-arc:nth-child(1){
  width:400px;
  height:400px;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  animation:arcRotate 25s linear infinite;
}

.hero-arc:nth-child(2){
  width:320px;
  height:320px;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  animation:arcRotate 30s linear infinite reverse;
}

.hero-arc:nth-child(3){
  width:240px;
  height:240px;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  animation:arcRotate 35s linear infinite;
}

@keyframes arcRotate{
  to{transform:translate(-50%, -50%) rotate(360deg)}
}

/* Glowing particles */
.hero-particles{
  position:absolute;
  inset:0;
  overflow:hidden;
  border-radius:24px;
  z-index:1;
}

.particle{
  position:absolute;
  width:4px;
  height:4px;
  background:var(--blue-light);
  border-radius:50%;
  opacity:.6;
  animation:particleFloat 8s ease-in-out infinite;
}

.particle:nth-child(1){top:15%;left:20%;animation-delay:0s}
.particle:nth-child(2){top:35%;left:80%;animation-delay:1.5s}
.particle:nth-child(3){top:65%;left:15%;animation-delay:3s}
.particle:nth-child(4){top:80%;left:70%;animation-delay:4.5s}
.particle:nth-child(5){top:25%;left:50%;animation-delay:2s}

@keyframes particleFloat{
  0%, 100%{transform:translateY(0) scale(1);opacity:.6}
  50%{transform:translateY(-30px) scale(1.5);opacity:.9}
}

/* Background gradient overlay */
.hero-bg-gradient{
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at 30% 40%, rgba(60,184,212,.12) 0%, transparent 60%);
  pointer-events:none;
}
.visitor-counter {
    text-align: center;
}
/* RESPONSIVE */
@media(max-width:1024px){
  .hero{
    grid-template-columns:1fr;
    padding:120px 40px 60px;
    gap:50px;
    min-height:auto;
  }
  
  .hero-visual{
    height:400px;
    order:-1;
  }
  
  .hero-content{
    text-align:center;
  }
  
  .hero-desc{
    margin-left:auto;
    margin-right:auto;
  }
  
  .hero-actions{
    justify-content:center;
  }
}

@media(max-width:768px){
  .hero{
    padding:100px 22px 40px;
  }
  
  .hero-visual{
    height:320px;
  }
  
  .hero-actions{
    flex-direction:column;
    width:100%;
  }
  
  .btn-primary, .btn-secondary{
    width:100%;
    justify-content:center;
  }
}


/* ========================================
   REDESIGNED HERO SECTION - OPTION 1: SPLIT SCREEN
   ======================================== */


/* SECTION */
section{padding:110px 80px;position:relative}
.section-label{display:inline-flex;align-items:center;gap:12px;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--blue-dark);margin-bottom:14px;font-weight:700}
.section-label::before{content:'';width:32px;height:2.5px;background:var(--blue);border-radius:2px}
.section-title{font-size:clamp(30px,3.5vw,48px);font-weight:700;line-height:1.15;color:var(--dark);margin-bottom:16px;letter-spacing:-.5px}
.section-subtitle{font-size:14px;color:var(--text-muted);font-weight:500;margin-bottom:10px}
.section-desc{font-size:16px;line-height:1.75;color:var(--text-secondary);max-width:560px;font-weight:400}

/* ABOUT */
.about{background:var(--bg-alt);display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:start;}
.about-visual{position:relative;height:460px}
.about-frame{position:absolute;inset:16px;border-radius:14px}
.about-image{position:absolute;inset:0;}
.about-image .logo-wm { max-width:100%; }
/*.about-image .logo-wm{width:200px;opacity:.25;filter:contrast(1.2)}*/
.about-arcs{position:absolute;inset:0;overflow:hidden;border-radius:14px}
.about-arcs .al{position:absolute;border:2px solid rgba(26,143,196,.12);border-radius:50%;border-right-color:transparent;border-bottom-color:transparent;animation:rot 28s linear infinite}
.about-arcs .al:nth-child(1){width:260px;height:260px;top:-30px;left:-30px}
.about-arcs .al:nth-child(2){width:210px;height:210px;top:-5px;left:-5px;animation-duration:34s}
.about-arcs .al:nth-child(3){width:160px;height:160px;top:20px;left:20px;animation-duration:40s}
@keyframes rot{to{transform:rotate(360deg)}}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:28px}
.about-value{padding:18px;border:1px solid var(--border);border-radius:10px;transition:all .3s;background:var(--bg-card)}
.about-value:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow)}
.about-value h4{font-size:14px;font-weight:700;color:var(--blue-dark);margin-bottom:4px}
.about-value p{font-size:12.5px;color:var(--text-secondary);line-height:1.55;font-weight:400}

/* MARQUEE — HIGH CONTRAST */
.marquee-section{padding:28px 0;overflow:hidden;border-top:2px solid rgba(26,143,196,.12);border-bottom:2px solid rgba(26,143,196,.12);background:var(--bg-warm)}
.marquee-track{display:flex;animation:mq 30s linear infinite;width:max-content}
.marquee-item{font-size:32px;font-weight:700;color:rgba(26,143,196,.28);white-space:nowrap;padding:0 28px;display:flex;align-items:center;gap:28px}
.marquee-item.guj{font-family:var(--font-guj);color:rgba(10,110,154,.22)}
.marquee-item .dot{width:8px;height:8px;background:rgba(26,143,196,.22);border-radius:50%}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* FIRST FILM */
.first-film{background:var(--bg-warm);text-align:center;overflow:hidden}
.first-film .section-label{justify-content:center}
.film-showcase{max-width:960px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;text-align:left;margin-top:50px}
.film-info-side{position:relative}
.film-status{display:inline-flex;align-items:center;gap:8px;padding:7px 18px;background:var(--blue);color:var(--white);border-radius:20px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:20px}
.film-status::before{content:'';width:8px;height:8px;background:var(--white);border-radius:50%;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.film-title-guj{font-family:var(--font-guj);font-size:16px;color:var(--blue-dark);font-weight:700;margin-bottom:6px}
.film-info-side h3{font-size:clamp(32px,4vw,50px);font-weight:800;color:var(--dark);margin-bottom:6px;line-height:1.15;letter-spacing:-1px}
.film-info-side h3 .blue{color:var(--blue)}
.film-tagline{font-size:15px;color:var(--text-muted);margin-bottom:20px;font-weight:500;font-style:italic}
.film-info-side .film-desc{font-size:14px;color:var(--text-secondary);line-height:1.75;margin-bottom:24px;font-weight:400}
.film-credits{display:grid;grid-template-columns:1fr 1fr;gap:10px 20px;margin-bottom:28px}
.film-credit{font-size:12px}
.film-credit .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;font-size:10px;font-weight:700;display:block;margin-bottom:2px}
.film-credit .name{color:var(--dark);font-weight:600;font-size:13px}
.film-press-side{position:relative}
.film-press-img{width:100%;border-radius:12px;box-shadow:var(--shadow);border:1px solid var(--border);transition:transform .4s,box-shadow .4s}
.film-press-img:hover{transform:translateY(-4px) rotate(-0.5deg);box-shadow:var(--shadow-hover)}
.press-caption{font-size:13px;color:var(--text-secondary);text-align:center;margin-top:14px;font-weight:500}
.press-caption strong{color:var(--blue-dark);font-weight:700}

/* CULTURE */
.culture{background:var(--bg-alt);overflow:hidden}
.culture-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;margin-top:50px}
.culture-item{padding:34px 28px;border:1px solid var(--border);border-radius:12px;background:var(--bg-card);transition:all .35s;cursor:pointer}
.culture-item:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.culture-icon{font-size:36px;margin-bottom:16px;display:block}
.culture-item h3{font-size:17px;font-weight:700;color:var(--dark);margin-bottom:8px}
.culture-item p{font-size:13px;color:var(--text-secondary);line-height:1.7;font-weight:400}

/* SERVICES */
.services{background:var(--bg)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:50px}
.service-card{padding:34px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;transition:all .35s;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--cyan));transform:scaleX(0);transition:transform .4s;transform-origin:left;border-radius:12px 12px 0 0}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.service-num{font-size:44px;font-weight:800;color:rgba(26,143,196,.12);margin-bottom:14px;line-height:1}
.service-card h3{font-size:17px;font-weight:700;color:var(--dark);margin-bottom:10px}
.service-card p{font-size:13px;color:var(--text-secondary);line-height:1.7;font-weight:400}

/* VISION */
.vision{background:var(--bg-alt)}
.vision-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;margin-top:50px}
.vision-card{padding:36px 28px;text-align:center;border:1px solid var(--border);border-radius:12px;background:var(--bg-card);transition:all .3s}
.vision-card:hover{border-color:var(--border-hover);transform:translateY(-3px);box-shadow:var(--shadow)}
.vision-icon{font-size:44px;margin-bottom:18px;display:block}
.vision-card h3{font-size:18px;font-weight:700;color:var(--dark);margin-bottom:8px}
.vision-card p{font-size:13px;color:var(--text-secondary);line-height:1.7;font-weight:400}

/* CTA */
.cta-section{padding:80px;text-align:center;background:linear-gradient(160deg,var(--cyan-pale) 0%,var(--bg-alt) 40%,var(--bg) 100%);position:relative;overflow:hidden}
.cta-section .section-title{max-width:620px;margin:0 auto 12px}
.cta-section .section-subtitle{text-align:center;margin-bottom:6px}
.cta-section .section-desc{max-width:460px;margin:0 auto 38px;text-align:center}
.cta-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

/* Override or add these styles to keep the layout neat */
.cta-content {display: flex; gap: 60px; margin: 40px 0 0; align-items: flex-start;}
.contact-left { color: var(--text-secondary); font-weight: 400;  font-size: 16px; line-height: 1.6;}
.contact-info p { margin: 0 0 20px 0; font-weight: 600; color: var(--blue); font-size: 14px;}
.contact-right form { background: #fff; padding: 30px; border-radius: 12px;}

.contact-right form label { display: block; margin-bottom: 0.5rem; font-weight: 600; font-size: 0.8rem; color: var(--text-muted);}
.contact-right form input[type="text"],
.contact-right form input[type="email"],
.contact-right form textarea {
    display: block;
    width: 100%;
    padding: .375rem .75rem;
    font-size: 1rem;
    line-height: 1.5;
    color: #212529;
    background-color: #fff;
    border: 1px solid #ced4da;
    border-radius: 0.375rem;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

.visitor-counter br { display:none !important; }

/* Focus effect */
.contact-right form input[type="text"]:focus,
.contact-right form input[type="email"]:focus,
.contact-right form textarea:focus {
    border-color: #86b7fe;
    outline: 0;
    box-shadow: none;
}

/* Textarea resize */
.contact-right form textarea { resize: none; height: 100px;}

/* Submit button */
.contact-right form input[type="submit"]{display:inline-flex;align-items:center;gap:10px;padding:15px 36px;background:var(--blue);color:var(--white);font-family:var(--font);font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;text-decoration:none;border:none;border-radius:6px;cursor:pointer;transition:all .3s}
.contact-right form input[type="submit"]:hover{background:var(--blue-bright);transform:translateY(-2px);box-shadow:0 12px 40px rgba(26,143,196,.3)}

/* Responsive adjustment */
@media (max-width: 768px) {
  .cta-content { flex-direction: column; gap: 40px; }
  .contact-left, .contact-right { max-width: 100%;}
}

/* FOOTER */
footer{background:var(--dark);padding:70px 80px 34px}
.footer-grid{display:grid; grid-template-columns: 2fr 1fr 1fr; gap:50px;margin-bottom:50px}
/*grid-template-columns:2fr 1fr 1fr 1fr;*/
.footer-brand .logo{margin-bottom:16px}
.footer-brand .logo img{height:42px;filter:brightness(10)}
.footer-brand p{font-size:13px;color:rgba(255,255,255,.55);line-height:1.7;max-width:280px;font-weight:400}
.footer-social{display:flex;gap:10px;margin-top:18px}
.footer-social a{width:36px;height:36px; padding: 10px;border:1px solid rgba(255,255,255,.18);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.55);text-decoration:none;font-size:11px;font-weight:600;transition:all .3s}
.footer-social a:hover{border-color:var(--blue-light);color:var(--blue-light);background:rgba(26,143,196,.15)}
.footer-col h4{font-size:14px;font-weight:700;color:var(--blue-light);margin-bottom:16px;letter-spacing:1px}
.footer-col a{display:block;color:rgba(255,255,255,.5);text-decoration:none;font-size:13px;padding:5px 0;transition:color .3s;font-weight:400}
.footer-col a:hover{color:rgba(255,255,255,.9)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;display:flex;justify-content:space-between;align-items:center}
.footer-bottom p{font-size:11px;color:rgba(255,255,255,.35)}
.footer-gujarati{font-family:var(--font-guj);font-size:13px;color:var(--blue-light);opacity:.6}

/* ANIMATIONS */
.reveal{opacity:0;transform:translateY(24px);transition:all .7s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:1024px){
  section{padding:80px 40px}nav{padding:16px 28px}
  .hero-content{padding:0 40px}.hero-logo-float{display:none}
  .about{grid-template-columns:1fr;gap:36px}.about-visual{height:260px}
  .film-showcase{grid-template-columns:1fr;gap:30px;text-align:center}
  .film-info-side{text-align:center}
  .film-credits{justify-content:center}
  .culture-grid,.services-grid{grid-template-columns:repeat(2,1fr)}
  .vision-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:34px}
}
@media(max-width:768px){
  section{padding:30px 22px}nav{padding:14px 22px}
  .nav-links{display:none}.hamburger{display:flex}
  .hero-content{padding:0 22px}
  .culture-grid,.services-grid,.vision-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .film-showcase{grid-template-columns:1fr}
  .film-credits{grid-template-columns:1fr 1fr}
  .cta-section{padding:70px 22px}
  .cta-actions{flex-direction:column;align-items:center}
  footer{padding:50px 22px 26px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:26px; margin-bottom: 20px;}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center}
  .hero-swoosh{display:none}
}

.mobile-menu{position:fixed;inset:0;background:rgba(228,235,240,.98);z-index:150;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;opacity:0;pointer-events:none;transition:opacity .4s;backdrop-filter:blur(10px)}
.mobile-menu.active{opacity:1;pointer-events:all}
.mobile-menu a{font-size:22px;font-weight:600;color:var(--dark);text-decoration:none;transition:color .3s}
.mobile-menu a:hover{color:var(--blue)}
.mobile-close{position:absolute;top:20px;right:22px;font-size:30px;color:var(--dark);cursor:pointer;background:none;border:none;font-family:var(--font)}