/* =========================
   Style.css — Complete for Acharya site
   Paste in Style.css?v=1.0
   ========================= */

/* ---------- Root & base ---------- */
:root{
  --orange: #ff6b00;
  --orange-2: #ff8a33;
  --bg: #fffaf6;
  --muted: #6b6f76;
  --card: #ffffff;
  --dark: #121213;
  --container: 1100px;
  --nav-height: 68px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: 'Inter', system-ui, Arial, sans-serif;
  background:var(--bg);
  color:var(--dark);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-size:18px;            /* heavier text as requested */
  line-height:1.7;          /* more readable */
  font-weight:500;
}

/* container */
.container{max-width:var(--container);margin:0 auto;padding:0 20px}

/* ---------- NAVBAR ---------- */
nav.navbar{
  position:sticky;
  top:0;
  z-index:2000;
  background: rgba(255,255,255,0.75);
  backdrop-filter: blur(6px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}

.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:12px 20px;
  max-width:var(--container);
  margin:0 auto;
  min-height:var(--nav-height);
}

/* brand */
.brand{display:flex;gap:12px;align-items:center;text-decoration:none;color:var(--dark)}
.logo{
  width:52px;height:52px;border-radius:12px;
  background:linear-gradient(135deg,var(--orange),var(--orange-2));
  display:grid;place-items:center;color:#fff;
  font-family:'Playfair Display',serif;font-weight:700;font-size:22px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
}
.brand-title{font-weight:700;font-size:1rem}
.brand-sub{display:block;color:var(--muted);font-size:0.9rem;margin-top:2px}

/* nav links (desktop) */
.nav-links{
  display:flex;align-items:center;gap:18px;
}
.nav-links a{
  text-decoration:none;color:var(--dark);font-size:16px;
  padding:8px 10px;border-radius:8px;font-weight:700;
  transition: background 180ms ease, color 180ms ease, transform 150ms ease;
}
.nav-links a:hover{background: rgba(0,0,0,0.04);transform:translateY(-2px)}
.cta{
  background: linear-gradient(90deg,var(--orange),var(--orange-2));
  color:#fff;padding:9px 14px;border-radius:10px;font-weight:800;
  box-shadow: 0 8px 20px rgba(255,107,0,0.12);
}
.cta:hover{opacity:0.95}

/* hamburger (mobile only) */
.hamburger{
  display:none;
  font-size:28px;
  line-height:1;
  cursor:pointer;
  padding:8px;
  border-radius:8px;
  user-select:none;
}
.hamburger:active{transform:scale(0.98)}

/* ---------------- MOBILE MENU ---------------- */
.mobile-menu{
  position:fixed;
  top:0;
  right:-110%;
  width:78%;
  max-width:420px;
  height:100vh;
  background: linear-gradient(180deg, var(--orange), var(--orange-2));
  padding:90px 26px 30px 26px;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:18px;
  transition: right 360ms cubic-bezier(.2,.9,.2,1);
  z-index:2500;
  box-shadow: -8px 0 30px rgba(0,0,0,0.18);
  color:#fff;
}

/* add a subtle inner panel for links look */
.mobile-menu li a{
  color:#fff;font-size:20px;text-decoration:none;font-weight:700;
  padding:12px 14px;border-radius:12px;background:rgba(255,255,255,0.06);
  display:block;
  transition: background 160ms, transform 160ms;
}
.mobile-menu li a:active{transform:translateY(1px)}
.mobile-menu button{
  padding:12px 16px;font-size:18px;border-radius:12px;border:none;background:#fff;color:var(--orange);
  font-weight:800;cursor:pointer;
  box-shadow: 0 10px 24px rgba(0,0,0,0.12);
}

/* close button (white-ish) */
.close-btn{
  margin-top:14px;font-size:22px;cursor:pointer;color:rgba(255,255,255,0.95);
  display:inline-block;font-weight:800;
}

/* open state */
.mobile-menu.open{ right:0; }

/* animate list items on open (stagger using nth-child) */
.mobile-menu li{
  opacity:0; transform:translateX(18px);
  transition:opacity 320ms ease, transform 320ms ease;
}
.mobile-menu.open li{ opacity:1; transform:translateX(0) }
.mobile-menu.open li:nth-child(1){ transition-delay:0.06s }
.mobile-menu.open li:nth-child(2){ transition-delay:0.08s }
.mobile-menu.open li:nth-child(3){ transition-delay:0.10s }
.mobile-menu.open li:nth-child(4){ transition-delay:0.12s }

/* optional backdrop to dim page when menu open — JS can toggle body.menu-open */
body.menu-open::before{
  content:"";
  position:fixed; inset:0;
  background:rgba(0,0,0,0.35);
  z-index:2400;
  transition:opacity 200ms;
}

/* ---------- HERO ---------- */
.hero{min-height:78vh;display:flex;align-items:center;padding:44px 0;}
.hero-inner{display:flex;align-items:center;justify-content:space-between;gap:36px;flex-wrap:wrap;max-width:var(--container);margin:0 auto;padding:0 20px}
.hero-text{flex:1;min-width:280px}
.kicker{display:inline-block;padding:8px 14px;border-radius:999px;background:linear-gradient(90deg,var(--orange),var(--orange-2));color:#fff;font-weight:800;margin-bottom:16px;font-size:0.95rem}
.hero-text h1{font-family:'Playfair Display',serif;font-size:2.6rem;margin:10px 0;line-height:1.08;font-weight:700;color:#111}
.lead{color:var(--muted);font-size:1.05rem}

/* hero image */
.hero-img img{width:420px;max-width:100%;border-radius:12px;box-shadow:0 18px 60px rgba(0,0,0,0.12);object-fit:cover;display:block}

/* ---------- SECTIONS & TYPOGRAPHY ---------- */
.section{padding:64px 0}
.section-title-wrap{display:flex;justify-content:center}
.section-title{font-family:'Playfair Display',serif;font-size:2.1rem;margin:0;text-align:center;font-weight:700}
.section-sub{color:var(--muted);text-align:center;margin-top:8px;max-width:820px;margin-left:auto;margin-right:auto;font-size:1rem}

/* services grid */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:28px}
.service-card{
  background:var(--card);border-radius:14px;padding:20px;text-align:center;box-shadow:0 18px 40px rgba(16,16,16,0.06);
  text-decoration:none;color:inherit;transition:transform .35s ease,box-shadow .35s ease;
}
.service-card:hover{transform:translateY(-8px);box-shadow:0 30px 60px rgba(16,16,16,0.12)}
.service-card img{width:120px;height:120px;object-fit:cover;margin:0 auto 14px;border-radius:12px}
.service-card h3{margin:0;font-size:1.15rem;font-weight:800}
.service-card p{color:var(--muted);margin-top:10px;font-size:0.97rem}

/* about */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;margin-top:18px}
.about-box{background:linear-gradient(180deg,rgba(255,255,255,0.95),rgba(255,255,255,0.9));padding:24px;border-radius:12px;box-shadow:0 18px 40px rgba(16,16,16,0.06)}
.about-box h3{margin-top:0;font-size:1.25rem;font-weight:800}
.about-box p{color:var(--muted);font-size:0.98rem}

/* gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:18px}
.gallery-item{height:150px;border-radius:10px;background-size:cover;background-position:center;box-shadow:0 12px 30px rgba(0,0,0,0.06)}

/* contact / form */
.contact-wrap{max-width:720px;margin:24px auto 0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
input,select,textarea{width:100%;padding:12px;border-radius:10px;border:1px solid #eee;font-size:1rem;font-weight:600}
textarea{min-height:140px}
.form-actions{display:flex;gap:12px;align-items:center;margin-top:12px}

/* whatsapp floating */
.whatsapp{position:fixed;right:18px;bottom:18px;width:56px;height:56px;border-radius:999px;background:linear-gradient(180deg,var(--orange),var(--orange-2));display:grid;place-items:center;color:#fff;box-shadow:0 18px 40px rgba(0,0,0,0.2);z-index:2000}
.whatsapp img{width:26px;height:26px;display:block}

/* footer */
footer{padding:28px 0;text-align:center;color:var(--muted);font-size:0.95rem}

/* subtle alternation for premium look */
.section:nth-of-type(even){background: #fff9e6}

/* small helpers */
.text-center{text-align:center}
.mb-8{margin-bottom:32px}

/* ---------- RESPONSIVE ---------- */
@media (max-width:1100px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
}

@media (max-width:980px){
  .hero-inner{flex-direction:column-reverse;align-items:center;text-align:center;padding:0 20px}
  .hero-text h1{font-size:2.0rem}
  .hero-img img{max-width:320px}
  .services-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr}
}

@media (max-width:520px){
  :root{--container:1000px}
  .brand-title{font-size:0.98rem}
  .brand-sub{font-size:0.82rem}
  .hero-text h1{font-size:1.6rem}
  .lead{font-size:0.95rem}
  .hero-img img{max-width:240px}
  .mobile-menu{width:84%}
  .nav-inner{padding:10px 14px}
  .nav-links{display:none}
  .hamburger{display:block}
  .form-row{grid-template-columns:1fr}
  .hero{padding:28px 0}
  .section{padding:36px 0}
  .service-card img{width:100px;height:100px}
  .gallery-item{height:120px}
  input,textarea,select{font-size:0.98rem}
}

#mobileMenu {
    transform: translateX(100%);
    transition: none; /* GSAP handle karega */
}

/* Prevent flicker: set initial transform for mobile menu & reduce layout shift */
@media (prefers-reduced-motion: reduce){
  *{transition:none!important;animation:none!important}
}
