/* ============================================================
   HEMANT FRESH — Orchards of India
   Shared stylesheet : design tokens, type scale, motion, parts
   ============================================================ */

:root{
  /* surfaces */
  --ivory:#FFFDF7;
  --cream:#F7F1E3;
  --beige:#EBE1CC;
  --sand:#E0D3B6;
  /* greens */
  --leaf:#7C8C5A;
  --olive:#3C4A2C;
  --forest:#222D18;
  --moss:#54643A;
  /* accents */
  --mango:#E6A53C;
  --amber:#D9772E;
  --rust:#B2532A;
  --earth:#8A6A48;
  /* ink */
  --charcoal:#2A2620;
  --ink:#191712;
  --muted:#6B6353;
  /* utility */
  --line:rgba(42,38,32,.14);
  --shadow:0 30px 60px -28px rgba(34,45,24,.45);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset / base ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  background:var(--ivory);
  color:var(--charcoal);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--mango);color:var(--forest)}

/* film-grain atmosphere */
body::after{
  content:"";position:fixed;inset:0;z-index:9000;pointer-events:none;
  opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- typography ---------- */
.font-display{font-family:'Fraunces',Georgia,serif;font-optical-sizing:auto}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.04;
  letter-spacing:-.015em;color:var(--ink)}

.kicker{
  font-family:'Hanken Grotesk',sans-serif;font-weight:600;
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--amber);display:inline-flex;align-items:center;gap:.7rem;
}
.kicker::before{content:"";width:30px;height:1px;background:var(--amber);display:inline-block}
.kicker.center::after{content:"";width:30px;height:1px;background:var(--amber);display:inline-block}

.display-xl{font-size:clamp(3.1rem,9vw,8rem)}
.display-lg{font-size:clamp(2.6rem,6.4vw,5.6rem)}
.display-md{font-size:clamp(2rem,4.2vw,3.5rem)}
.lede{font-size:clamp(1.05rem,1.6vw,1.4rem);line-height:1.6;color:var(--muted)}
.serif-italic{font-style:italic;font-weight:400}

/* ---------- layout helpers ---------- */
.wrap{max-width:1280px;margin:0 auto;padding:0 clamp(1.25rem,5vw,4rem)}
.section{padding:clamp(5rem,11vw,9.5rem) 0}
.eyebrow-num{font-family:'Fraunces',serif;font-size:.95rem;color:var(--amber);
  letter-spacing:.05em}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--forest);--fg:var(--ivory);
  position:relative;display:inline-flex;align-items:center;gap:.6rem;
  font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
  padding:1.05rem 2.1rem;border-radius:999px;cursor:pointer;border:1px solid transparent;
  background:var(--bg);color:var(--fg);overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.btn span{position:relative;z-index:2}
.btn::before{content:"";position:absolute;inset:0;z-index:1;
  background:var(--mango);transform:translateY(101%);transition:transform .5s var(--ease)}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 30px -16px rgba(34,45,24,.55)}
.btn:hover::before{transform:translateY(0)}
.btn:hover span{color:var(--forest)}
.btn-ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line)}
.btn-ghost:hover span{color:var(--forest)}
.btn-light{--bg:var(--ivory);--fg:var(--forest)}
.btn-arrow svg{transition:transform .4s var(--ease)}
.btn:hover .btn-arrow svg{transform:translateX(4px)}

/* text link */
.tlink{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;
  font-size:.82rem;letter-spacing:.13em;text-transform:uppercase;
  padding-bottom:4px;border-bottom:1px solid var(--line);transition:.4s var(--ease)}
.tlink:hover{border-color:var(--amber);color:var(--amber)}

/* ---------- navigation ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),padding .4s var(--ease);
  padding:1.5rem 0;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between}
.nav.scrolled{background:rgba(255,253,247,.92);backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line);padding:.85rem 0}
.brand{font-family:'Fraunces',serif;font-weight:600;font-size:1.55rem;
  letter-spacing:.04em;color:var(--ink);display:flex;align-items:center;gap:.55rem}
.brand .mark{width:13px;height:13px;border-radius:50%;
  background:radial-gradient(circle at 32% 30%,var(--mango),var(--amber) 70%);
  box-shadow:0 0 0 4px rgba(230,165,60,.18)}
.brand small{font-family:'Hanken Grotesk',sans-serif;font-size:.58rem;
  letter-spacing:.34em;font-weight:600;color:var(--muted);text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:2.4rem}
.nav-links a{font-size:.82rem;font-weight:600;letter-spacing:.11em;
  text-transform:uppercase;position:relative;padding:.3rem 0;color:var(--charcoal)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;
  background:var(--amber);transition:width .4s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--amber)}
.nav-cta{margin-left:.5rem}
.nav.on-dark:not(.scrolled) .brand,
.nav.on-dark:not(.scrolled) .brand small,
.nav.on-dark:not(.scrolled) .nav-links a{color:var(--ivory)}
.nav.on-dark:not(.scrolled) .burger span{background:var(--ivory)}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;
  cursor:pointer;padding:6px;z-index:1100}
.burger span{width:26px;height:2px;background:var(--ink);display:block;
  transition:.35s var(--ease);transform-origin:center}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{
  position:fixed;inset:0;z-index:1050;background:var(--forest);
  display:flex;flex-direction:column;justify-content:center;gap:.4rem;
  padding:2rem clamp(1.25rem,8vw,4rem);
  clip-path:circle(0% at calc(100% - 3rem) 3rem);
  transition:clip-path .65s var(--ease);
}
.mobile-menu.open{clip-path:circle(150% at calc(100% - 3rem) 3rem)}
.mobile-menu a{font-family:'Fraunces',serif;font-size:clamp(2.2rem,9vw,3.6rem);
  color:var(--ivory);font-weight:500;letter-spacing:-.01em;
  border-bottom:1px solid rgba(255,255,255,.12);padding:.7rem 0;
  display:flex;align-items:baseline;justify-content:space-between}
.mobile-menu a span{font-family:'Hanken Grotesk',sans-serif;font-size:.8rem;
  color:var(--mango);letter-spacing:.2em}
.mobile-foot{margin-top:2rem;color:rgba(255,253,247,.55);font-size:.85rem;
  display:flex;gap:1.5rem;flex-wrap:wrap}

/* ---------- image figure : built-in fallback ---------- */
.fig{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--moss),var(--olive) 55%,var(--forest));
}
.fig::before{ /* fallback label shows only if image missing */
  content:attr(data-label);position:absolute;inset:0;z-index:0;
  display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:'Fraunces',serif;font-style:italic;font-size:1.1rem;
  color:rgba(255,253,247,.4);letter-spacing:.04em;padding:1rem;
}
.fig img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;
  transition:transform 1.1s var(--ease),opacity .8s ease}
.fig.zoom:hover img{transform:scale(1.07)}
.fig img.failed{opacity:0}

/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(38px);
  transition:opacity 1s var(--ease),transform 1s var(--ease);
  transition-delay:var(--d,0s)}
.reveal.in{opacity:1;transform:none}
.reveal-zoom{opacity:0;transform:scale(1.08);
  transition:opacity 1.2s var(--ease),transform 1.4s var(--ease)}
.reveal-zoom.in{opacity:1;transform:scale(1)}
.mask-line{display:block;overflow:hidden}
.mask-line>*{display:block;transform:translateY(105%);
  transition:transform 1s var(--ease);transition-delay:var(--d,0s)}
.mask-line.in>*{transform:translateY(0)}
@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-zoom,.mask-line>*{transition:none;opacity:1;transform:none}
}

/* ---------- marquee ---------- */
.marquee{overflow:hidden;border-block:1px solid var(--line);
  padding:1.5rem 0;background:var(--cream)}
.marquee-track{display:flex;gap:3.5rem;width:max-content;
  animation:slide 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:flex;align-items:center;gap:3.5rem;
  font-family:'Fraunces',serif;font-size:1.5rem;font-style:italic;color:var(--olive)}
.marquee-item b{font-style:normal;color:var(--amber);font-size:.7rem;
  letter-spacing:.2em;text-transform:uppercase;font-family:'Hanken Grotesk',sans-serif}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- floating light orbs ---------- */
.orb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none;
  opacity:.5;animation:float 14s ease-in-out infinite}
@keyframes float{50%{transform:translate(20px,-26px) scale(1.08)}}

/* ---------- footer ---------- */
.footer{background:var(--forest);color:var(--ivory);position:relative;overflow:hidden}
.footer a{color:rgba(255,253,247,.7);transition:color .3s ease}
.footer a:hover{color:var(--mango)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;
  gap:3rem;padding:clamp(4rem,8vw,7rem) 0 3rem}
.footer h5{font-family:'Hanken Grotesk',sans-serif;font-size:.72rem;
  letter-spacing:.24em;text-transform:uppercase;color:var(--mango);
  margin-bottom:1.4rem;font-weight:700}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:.85rem;font-size:.95rem}
.foot-news{display:flex;border:1px solid rgba(255,253,247,.2);
  border-radius:999px;overflow:hidden;margin-top:1.2rem;max-width:340px}
.foot-news input{flex:1;background:none;border:0;padding:.9rem 1.2rem;
  color:var(--ivory);font-family:inherit;font-size:.9rem;outline:none}
.foot-news input::placeholder{color:rgba(255,253,247,.45)}
.foot-news button{background:var(--mango);border:0;padding:0 1.4rem;cursor:pointer;
  color:var(--forest);font-weight:700;transition:background .3s ease}
.foot-news button:hover{background:var(--amber)}
.foot-bottom{border-top:1px solid rgba(255,253,247,.13);padding:1.8rem 0;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-size:.82rem;color:rgba(255,253,247,.55)}
.footer-watermark{position:absolute;bottom:-3.5vw;left:50%;transform:translateX(-50%);
  font-family:'Fraunces',serif;font-weight:600;font-size:23vw;line-height:1;
  color:rgba(255,253,247,.04);white-space:nowrap;pointer-events:none}

/* ---------- forms ---------- */
.field{position:relative;margin-bottom:1.6rem}
.field label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);margin-bottom:.55rem}
.field input,.field textarea,.field select{
  width:100%;background:var(--ivory);border:1px solid var(--line);
  border-radius:14px;padding:1rem 1.1rem;font-family:inherit;font-size:1rem;
  color:var(--ink);transition:border-color .35s var(--ease),box-shadow .35s var(--ease)}
.field textarea{resize:vertical;min-height:140px}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--mango);box-shadow:0 0 0 4px rgba(230,165,60,.15)}

/* ---------- misc decorative ---------- */
.rule{height:1px;background:var(--line);width:100%}
.tag{display:inline-flex;align-items:center;gap:.45rem;font-size:.66rem;
  font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:.42rem .8rem;border-radius:999px}
.tag-export{background:var(--forest);color:var(--mango)}
.tag-season{background:rgba(230,165,60,.16);color:var(--amber)}
.dot{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}

.scroll-cue{display:flex;flex-direction:column;align-items:center;gap:.6rem;
  font-size:.66rem;letter-spacing:.28em;text-transform:uppercase}
.scroll-cue .bar{width:1px;height:46px;background:linear-gradient(var(--mango),transparent);
  animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.3);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}}

/* progress bar */
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:1200;
  background:linear-gradient(90deg,var(--mango),var(--amber))}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  body{font-size:16px}
  .nav-links{display:none}
  .nav-cta{display:none}
  .burger{display:flex}
  .footer-grid{grid-template-columns:1fr;gap:2.4rem}
  .marquee-item{font-size:1.2rem;gap:2.2rem}
  .marquee-track{gap:2.2rem}
}
