/* ============================================================ AMUTHU VEG RESTAURANT — ANIMATIONS & SCROLL EFFECTS ============================================================ */ /* ---------- AOS (Animate On Scroll) custom classes ---------- */ [data-aos] { opacity: 0; transition-property: opacity, transform; transition-duration: 0.8s; transition-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94); } [data-aos].aos-animate { opacity: 1; transform: none !important; } [data-aos="fade-up"] { transform: translateY(40px); } [data-aos="fade-down"] { transform: translateY(-40px); } [data-aos="fade-left"] { transform: translateX(40px); } [data-aos="fade-right"] { transform: translateX(-40px); } [data-aos="zoom-in"] { transform: scale(0.88); } [data-aos="zoom-out"] { transform: scale(1.12); opacity: 1; } [data-aos="flip-left"] { transform: perspective(800px) rotateY(-30deg); } [data-aos="flip-right"] { transform: perspective(800px) rotateY(30deg); } /* Delay utilities */ [data-aos-delay="100"] { transition-delay: 0.1s; } [data-aos-delay="150"] { transition-delay: 0.15s; } [data-aos-delay="200"] { transition-delay: 0.2s; } [data-aos-delay="250"] { transition-delay: 0.25s; } [data-aos-delay="300"] { transition-delay: 0.3s; } [data-aos-delay="400"] { transition-delay: 0.4s; } [data-aos-delay="500"] { transition-delay: 0.5s; } [data-aos-delay="600"] { transition-delay: 0.6s; } [data-aos-delay="700"] { transition-delay: 0.7s; } [data-aos-delay="800"] { transition-delay: 0.8s; } /* ---------- Hero text animations ---------- */ @keyframes heroFadeIn { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } } @keyframes heroSlideLeft { from { opacity: 0; transform: translateX(-50px); } to { opacity: 1; transform: translateX(0); } } @keyframes heroSlideRight { from { opacity: 0; transform: translateX(50px); } to { opacity: 1; transform: translateX(0); } } @keyframes heroZoom { from { opacity: 0; transform: scale(0.85); } to { opacity: 1; transform: scale(1); } } @keyframes slideUp { from { opacity: 0; transform: translateY(60px); } to { opacity: 1; transform: translateY(0); } } @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } } @keyframes shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } } @keyframes borderPulse { 0%, 100% { border-color: rgba(201,168,76,0.3); } 50% { border-color: rgba(201,168,76,0.8); } } @keyframes goldGlow { 0%, 100% { text-shadow: 0 0 10px rgba(201,168,76,0.3); } 50% { text-shadow: 0 0 30px rgba(201,168,76,0.7); } } @keyframes rotateIn { from { opacity: 0; transform: rotate(-10deg) scale(0.9); } to { opacity: 1; transform: rotate(0deg) scale(1); } } @keyframes lineGrow { from { transform: scaleX(0); } to { transform: scaleX(1); } } /* ---------- Hero startup animation sequence ---------- */ .hero-label { animation: heroFadeIn 0.8s ease 0.3s both; } .hero-title { animation: heroFadeIn 0.9s ease 0.5s both; } .hero-sub { animation: heroFadeIn 0.8s ease 0.7s both; } .hero-image-wrap { animation: heroZoom 1s ease 0.6s both; } .hero-deco-left { animation: heroSlideLeft 0.8s ease 0.9s both; } .hero-deco-right { animation: heroSlideRight 0.8s ease 0.9s both; } .hero-info-bar { animation: fadeIn 0.8s ease 1.1s both; } /* ---------- Typing cursor ---------- */ .typing-cursor::after { content: '|'; animation: blink 1s step-end infinite; color: var(--gold); margin-left: 2px; } @keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: 0; } } /* ---------- Stagger children ---------- */ .stagger-children > * { opacity: 0; transform: translateY(30px); transition: opacity 0.6s ease, transform 0.6s ease; } .stagger-children.in-view > *:nth-child(1) { opacity: 1; transform: none; transition-delay: 0.05s; } .stagger-children.in-view > *:nth-child(2) { opacity: 1; transform: none; transition-delay: 0.15s; } .stagger-children.in-view > *:nth-child(3) { opacity: 1; transform: none; transition-delay: 0.25s; } .stagger-children.in-view > *:nth-child(4) { opacity: 1; transform: none; transition-delay: 0.35s; } .stagger-children.in-view > *:nth-child(5) { opacity: 1; transform: none; transition-delay: 0.45s; } .stagger-children.in-view > *:nth-child(6) { opacity: 1; transform: none; transition-delay: 0.55s; } /* ---------- Parallax elements ---------- */ .parallax-slow { will-change: transform; } .parallax-fast { will-change: transform; } /* ---------- Counter animation ---------- */ .counter-num { display: inline-block; font-variant-numeric: tabular-nums; } /* ---------- Gold line decorators ---------- */ .gold-line-left, .gold-line-right { position: absolute; top: 50%; width: 60px; height: 1px; background: var(--gold); opacity: 0.4; transform: translateY(-50%); } .gold-line-left { left: 0; } .gold-line-right { right: 0; } /* ---------- Gradient text ---------- */ .gradient-text { background: linear-gradient(135deg, var(--gold-light), var(--gold), var(--gold-dark)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; } /* ---------- Menu item hover line ---------- */ .menu-item { transition: padding-left 0.3s ease; position: relative; } .menu-item::before { content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 0; height: 2px; background: var(--gold); transition: width 0.3s ease; } .menu-item:hover::before { width: 6px; } /* ---------- Button ripple effect ---------- */ .btn-ripple { position: relative; overflow: hidden; } .btn-ripple .ripple { position: absolute; border-radius: 50%; background: rgba(255,255,255,0.25); transform: scale(0); animation: ripple-anim 0.6s linear; pointer-events: none; } @keyframes ripple-anim { to { transform: scale(4); opacity: 0; } } /* ---------- Image reveal ---------- */ .img-reveal-wrap { overflow: hidden; position: relative; } .img-reveal-wrap::after { content: ''; position: absolute; inset: 0; background: var(--gold); transform: scaleX(1); transform-origin: left; transition: transform 0.8s cubic-bezier(0.76, 0, 0.24, 1); z-index: 1; } .img-reveal-wrap.revealed::after { transform: scaleX(0); transform-origin: right; } .img-reveal-wrap img { opacity: 0; transition: opacity 0.1s 0.4s ease; } .img-reveal-wrap.revealed img { opacity: 1; } /* ---------- Scroll indicator (hero) ---------- */ .scroll-indicator { position: absolute; bottom: 80px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 8px; z-index: 5; animation: fadeIn 1s ease 1.5s both; cursor: pointer; } .scroll-indicator-mouse { width: 24px; height: 38px; border: 1.5px solid rgba(255,255,255,0.4); border-radius: 12px; position: relative; } .scroll-indicator-wheel { width: 3px; height: 6px; background: var(--gold); border-radius: 3px; position: absolute; top: 6px; left: 50%; transform: translateX(-50%); animation: mouseWheel 1.5s ease infinite; } @keyframes mouseWheel { 0% { top: 6px; opacity: 1; } 80% { top: 22px; opacity: 0; } 100% { top: 6px; opacity: 0; } } .scroll-indicator-text { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(255,255,255,0.4); } /* ---------- Particle dots decorations ---------- */ .particle-dot { position: absolute; border-radius: 50%; background: var(--gold); opacity: 0.15; pointer-events: none; } /* ---------- Page transition overlay ---------- */ .page-transition { position: fixed; inset: 0; background: var(--dark-green); z-index: 9990; transform: scaleY(0); transform-origin: bottom; transition: transform 0.5s cubic-bezier(0.76, 0, 0.24, 1); } .page-transition.entering { transform: scaleY(1); transform-origin: bottom; } .page-transition.leaving { transform: scaleY(0); transform-origin: top; } /* ---------- Active nav underline animation ---------- */ .nav-link.active::after { animation: lineGrow 0.4s ease forwards; } /* ---------- Card tilt effect (applied via JS) ---------- */ .tilt-card { transform-style: preserve-3d; transition: transform 0.1s ease; } .tilt-card-inner { transform: translateZ(20px); } /* ---------- Floating particles ---------- */ @keyframes floatParticle { 0% { transform: translateY(0) rotate(0deg); opacity: 0.15; } 50% { opacity: 0.3; } 100% { transform: translateY(-100vh) rotate(720deg); opacity: 0; } } /* ---------- Gold shimmer on borders ---------- */ @keyframes borderShimmer { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } } /* ---------- Section entrance ---------- */ .section-enter { opacity: 0; transform: translateY(60px); transition: opacity 0.8s ease, transform 0.8s ease; } .section-enter.visible { opacity: 1; transform: translateY(0); }