/* ============================================================
   Dholera.co.in — Jazzed-up Stylesheet
   Google Fonts loaded via HTML <link> for Inter + Playfair Display
   ============================================================ */

/* ---------- Custom Properties ---------- */
:root {
  --bg:          #f5f3ee;
  --surface:     #ffffff;
  --surface-alt: #edeae2;
  --surface-2:   #f9f8f5;
  --text:        #1a2332;
  --muted:       #5a6a7a;
  --accent:      #2a6b69;
  --accent-2:    #e8a020;       /* warm gold accent */
  --accent-dark: #1d4e4d;
  --accent-light:#e4f0ef;
  --border:      #ddd8ce;
  --shadow-sm:   0 2px 8px rgba(30,45,60,.07);
  --shadow:      0 8px 32px rgba(30,45,60,.10);
  --shadow-lg:   0 20px 60px rgba(30,45,60,.14);
  --radius-sm:   10px;
  --radius:      18px;
  --radius-lg:   28px;
  --max-width:   1180px;
  --font-body:   'Inter', Arial, Helvetica, sans-serif;
  --font-display:'Playfair Display', Georgia, serif;
  --transition:  0.25s cubic-bezier(.4,0,.2,1);
}

/* ---------- Reset & Base ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-body);
  color: var(--text);
  background: var(--bg);
  line-height: 1.78;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--accent-dark); text-decoration: none; transition: color var(--transition); }
a:hover, a:focus { color: var(--accent); text-decoration: underline; }

img { max-width: 100%; display: block; }

/* ---------- Utility ---------- */
.container {
  width: min(calc(100% - 2.5rem), var(--max-width));
  margin-inline: auto;
}

.visually-hidden {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 9999;
}
.skip-link:focus {
  left: 1rem; top: 1rem;
  background: var(--surface); color: var(--text);
  padding: .75rem 1.25rem; border-radius: var(--radius-sm);
  box-shadow: var(--shadow); font-weight: 600;
}

/* ---------- Scroll-reveal ---------- */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .65s cubic-bezier(.4,0,.2,1), transform .65s cubic-bezier(.4,0,.2,1);
}
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 200;
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  border-bottom: 1px solid rgba(221,216,206,.6);
  transition: box-shadow var(--transition);
}
.site-header.scrolled { box-shadow: var(--shadow); }

.header-inner {
  display: flex; align-items: center;
  justify-content: space-between; gap: 1rem;
  padding: .85rem 0;
}

.branding { display: flex; flex-direction: column; gap: .15rem; }

.logo {
  display: flex; align-items: center; gap: .5rem;
  text-decoration: none !important;
}
.logo-img { height: 46px; width: auto; }
.logo-text {
  font-size: 1.3rem; font-weight: 800;
  color: var(--text); display: none;
}

.tagline { color: var(--muted); font-size: .84rem; letter-spacing: .01em; }

/* Nav */
.site-nav ul {
  list-style: none; display: flex; flex-wrap: wrap; gap: .3rem;
}
.site-nav a {
  display: inline-block; padding: .6rem 1.1rem;
  border-radius: 999px; color: var(--text);
  font-weight: 600; font-size: .93rem;
  transition: background var(--transition), color var(--transition);
}
.site-nav a:hover, .site-nav a:focus, .site-nav a.active {
  background: var(--accent-light); color: var(--accent-dark);
  text-decoration: none;
}
.site-nav a.active {
  background: var(--accent); color: #fff;
}

/* Mobile hamburger */
.nav-toggle {
  display: none; flex-direction: column; justify-content: center;
  gap: 5px; width: 40px; height: 40px;
  background: none; border: none; cursor: pointer; padding: .5rem;
  border-radius: var(--radius-sm);
}
.nav-toggle span {
  display: block; height: 2px; width: 100%;
  background: var(--text); border-radius: 2px;
  transition: transform var(--transition), opacity var(--transition);
}
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero {
  position: relative; overflow: hidden;
  padding: 5rem 0 3rem;
  background: linear-gradient(135deg, #ffffff 0%, #eaf2f1 55%, #f5f3ee 100%);
}

/* floating blobs */
.hero::before, .hero::after {
  content: ''; position: absolute; border-radius: 50%;
  pointer-events: none; opacity: .35;
  animation: blob-drift 12s ease-in-out infinite alternate;
}
.hero::before {
  width: 420px; height: 420px;
  background: radial-gradient(circle, #b8d9d8 0%, transparent 70%);
  top: -120px; right: -80px;
}
.hero::after {
  width: 320px; height: 320px;
  background: radial-gradient(circle, #f7dfa0 0%, transparent 70%);
  bottom: -100px; left: -60px;
  animation-delay: -6s;
}

@keyframes blob-drift {
  from { transform: translate(0,0) scale(1); }
  to   { transform: translate(30px, 20px) scale(1.08); }
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 2.5rem; align-items: center;
  position: relative; z-index: 1;
}

.hero-text {}

.eyebrow {
  display: inline-flex; align-items: center; gap: .45rem;
  margin-bottom: 1.1rem;
  padding: .4rem .9rem;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent-light), #fff);
  color: var(--accent-dark); font-size: .82rem;
  font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  border: 1px solid rgba(42,107,105,.2);
}
.eyebrow::before { content: '✦'; font-size: .75rem; opacity: .7; }

.hero h1, .page-intro h1 {
  font-family: var(--font-display);
  font-size: clamp(2.1rem, 4.2vw, 3.8rem);
  line-height: 1.1; font-weight: 700;
  letter-spacing: -.02em;
  margin-bottom: 1.1rem;
  background: linear-gradient(135deg, var(--text) 0%, var(--accent-dark) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero p, .page-intro p {
  font-size: 1.07rem; color: var(--muted);
  max-width: 56ch; line-height: 1.8;
}

/* Hero card */
.hero-card {
  border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-lg);
  transform: perspective(1000px) rotateY(-4deg) rotateX(2deg);
  transition: transform .5s cubic-bezier(.4,0,.2,1);
  border: 1px solid rgba(255,255,255,.8);
}
.hero-card:hover {
  transform: perspective(1000px) rotateY(0deg) rotateX(0deg) scale(1.02);
}
.hero-card img {
  width: 100%; aspect-ratio: 4/3; object-fit: cover;
  display: block;
}
.hero-card figcaption {
  padding: .9rem 1.2rem 1.1rem;
  font-size: .88rem; color: var(--muted);
  background: var(--surface);
}

/* ---------- Buttons ---------- */
.button-row {
  display: flex; flex-wrap: wrap; gap: .75rem;
  margin-top: 1.75rem;
}

.button {
  display: inline-flex; align-items: center; gap: .45rem;
  padding: .85rem 1.5rem;
  border-radius: var(--radius-sm);
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  color: #fff; font-weight: 700; font-size: .95rem;
  box-shadow: 0 4px 18px rgba(42,107,105,.35);
  transition: transform var(--transition), box-shadow var(--transition), filter var(--transition);
  letter-spacing: .01em;
}
.button:hover, .button:focus {
  text-decoration: none; color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(42,107,105,.45);
  filter: brightness(1.06);
}
.button.secondary {
  background: var(--surface); color: var(--text);
  border: 1.5px solid var(--border);
  box-shadow: var(--shadow-sm);
}
.button.secondary:hover { color: var(--accent-dark); border-color: var(--accent); }
.button.gold {
  background: linear-gradient(135deg, var(--accent-2) 0%, #c8880e 100%);
  box-shadow: 0 4px 18px rgba(232,160,32,.35);
}
.button.gold:hover { box-shadow: 0 8px 28px rgba(232,160,32,.45); }

/* ---------- Stat / Feature Cards ---------- */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem; margin: 1.5rem 0 2.5rem;
}

.stat-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.6rem 1.4rem;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition), box-shadow var(--transition);
  position: relative; overflow: hidden;
}
.stat-card::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  border-radius: var(--radius) var(--radius) 0 0;
}
.stat-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }

.stat-card strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1.9rem; font-weight: 700;
  color: var(--accent-dark); margin-bottom: .3rem;
  letter-spacing: -.02em;
}
.stat-card span { color: var(--muted); font-size: .92rem; line-height: 1.5; }

/* ---------- Image Grid ---------- */
.image-grid {
  display: grid; grid-template-columns: repeat(2,1fr);
  gap: 1.5rem; margin: 2rem 0 1.5rem;
}
.image-card {
  border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--shadow);
  border: 1px solid rgba(221,216,206,.6);
  transition: transform var(--transition), box-shadow var(--transition);
}
.image-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.image-card img { width: 100%; aspect-ratio: 16/10; object-fit: cover; }
.image-card figcaption {
  padding: .9rem 1.1rem 1.1rem;
  color: var(--muted); font-size: .88rem; line-height: 1.55;
  background: var(--surface);
}

/* ---------- Content Sections ---------- */
.content-section { padding: 1.5rem 0; }

.content-block {
  background: var(--surface);
  border: 1px solid rgba(221,216,206,.7);
  border-radius: var(--radius);
  padding: 2rem 2.2rem;
  margin-bottom: 1.5rem;
  box-shadow: var(--shadow-sm);
}

.content-block h2 {
  font-family: var(--font-display);
  font-size: 1.75rem; font-weight: 700;
  margin-bottom: 1rem; margin-top: 0;
  color: var(--text); line-height: 1.2;
}
.content-block h3 {
  font-size: 1.13rem; font-weight: 700;
  margin-top: 1.8rem; margin-bottom: .5rem;
  color: var(--accent-dark);
}
.content-block p { margin-bottom: 1rem; }
.content-block ul, .content-block ol { padding-left: 1.4rem; }
.content-block li { margin-bottom: .4rem; }

/* ---------- Table of Contents ---------- */
.table-of-contents {
  background: linear-gradient(135deg, var(--accent-light), #fff);
  border: 1px solid rgba(42,107,105,.18);
  border-radius: var(--radius);
  padding: 1.5rem 1.75rem;
  margin: 2rem 0;
}
.table-of-contents h2 {
  font-family: var(--font-display);
  font-size: 1.15rem; margin: 0 0 .75rem; color: var(--accent-dark);
}
.table-of-contents ol { margin: 0; padding-left: 1.3rem; }
.table-of-contents li { margin-bottom: .35rem; }
.table-of-contents a {
  color: var(--accent-dark); font-weight: 600; font-size: .95rem;
}
.table-of-contents a:hover { color: var(--accent); }

/* ---------- Info / Highlight Strips ---------- */
.info-strip {
  display: flex; gap: .75rem; align-items: flex-start;
  background: linear-gradient(135deg, #fff9ec, #fffdf7);
  border: 1px solid rgba(232,160,32,.3);
  border-left: 4px solid var(--accent-2);
  border-radius: var(--radius-sm);
  padding: 1.1rem 1.3rem;
  margin: 1.5rem 0;
  font-size: .95rem;
}
.info-strip::before { content: '💡'; font-size: 1.1rem; flex-shrink: 0; margin-top: .05rem; }

.highlight-box {
  display: flex; gap: .75rem; align-items: flex-start;
  background: linear-gradient(135deg, var(--accent-light), #fff);
  border: 1px solid rgba(42,107,105,.2);
  border-left: 4px solid var(--accent);
  border-radius: var(--radius-sm);
  padding: 1.1rem 1.3rem;
  margin: 1.5rem 0;
  font-size: .95rem;
}
.highlight-box::before { content: '📌'; font-size: 1.1rem; flex-shrink: 0; margin-top: .05rem; }

/* ---------- Page Intro (inner pages) ---------- */
.page-intro {
  padding: 3rem 0 .5rem;
  background: linear-gradient(135deg, #ffffff 0%, #eaf2f1 100%);
  border-bottom: 1px solid rgba(221,216,206,.5);
}
.page-intro .container { padding-bottom: 1.5rem; }

.breadcrumbs {
  font-size: .88rem; color: var(--muted); margin-bottom: 1rem;
  display: flex; align-items: center; gap: .4rem;
}
.breadcrumbs::before { content: '🏠'; font-size: .85rem; }
.breadcrumbs a { color: var(--muted); }
.breadcrumbs a:hover { color: var(--accent); }

/* ---------- Activity / Feature Cards ---------- */
.activity-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 1.25rem; margin: 1.5rem 0 2rem;
}
.activity-card {
  background: var(--surface); border-radius: var(--radius);
  border: 1px solid var(--border); padding: 1.5rem 1.4rem;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition), box-shadow var(--transition);
  display: flex; flex-direction: column; gap: .6rem;
}
.activity-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.activity-icon {
  font-size: 2.2rem; line-height: 1;
  width: 56px; height: 56px; display: flex; align-items: center; justify-content: center;
  background: var(--accent-light); border-radius: var(--radius-sm);
}
.activity-card h3 { font-size: 1.05rem; font-weight: 700; color: var(--text); margin: 0; }
.activity-card p  { font-size: .9rem; color: var(--muted); margin: 0; line-height: 1.55; }

/* ---------- Season Strip ---------- */
.season-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 1.1rem; margin: 1.25rem 0;
}
.season-card {
  border-radius: var(--radius-sm); padding: 1.2rem;
  text-align: center; border: 1px solid var(--border);
  box-shadow: var(--shadow-sm); background: var(--surface);
  transition: transform var(--transition);
}
.season-card:hover { transform: translateY(-3px); }
.season-card .season-icon { font-size: 2rem; margin-bottom: .5rem; }
.season-card strong { display: block; font-size: .95rem; font-weight: 700; margin-bottom: .2rem; }
.season-card span  { font-size: .85rem; color: var(--muted); }
.season-card.best  { background: var(--accent-light); border-color: rgba(42,107,105,.3); }
.season-card.best strong { color: var(--accent-dark); }

/* ---------- Economy Stat Counters ---------- */
.economy-stats {
  display: grid; grid-template-columns: repeat(4,1fr);
  gap: 1.1rem; margin: 1.5rem 0 2rem;
}
.econ-card {
  background: linear-gradient(135deg, var(--accent-dark) 0%, var(--accent) 100%);
  border-radius: var(--radius); padding: 1.5rem 1.2rem;
  text-align: center; color: #fff;
  box-shadow: 0 8px 24px rgba(42,107,105,.3);
  transition: transform var(--transition);
}
.econ-card:hover { transform: translateY(-4px); }
.econ-card .econ-num {
  font-family: var(--font-display);
  font-size: 1.9rem; font-weight: 700;
  line-height: 1; display: block; margin-bottom: .3rem;
}
.econ-card .econ-label {
  font-size: .8rem; opacity: .85; letter-spacing: .04em;
  text-transform: uppercase; font-weight: 600;
}

/* Industry cards */
.industry-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 1.1rem; margin: 1.25rem 0;
}
.industry-card {
  background: var(--surface-2); border-radius: var(--radius-sm);
  border: 1px solid var(--border); padding: 1.2rem;
  display: flex; gap: .9rem; align-items: flex-start;
  transition: transform var(--transition), box-shadow var(--transition);
}
.industry-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.industry-icon {
  font-size: 1.7rem; flex-shrink: 0;
  width: 48px; height: 48px;
  background: var(--accent-light); border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
}
.industry-card h4 { font-size: .95rem; font-weight: 700; margin-bottom: .25rem; }
.industry-card p  { font-size: .84rem; color: var(--muted); margin: 0; line-height: 1.5; }

/* ---------- Footer ---------- */
.site-footer {
  margin-top: 4rem;
  background: linear-gradient(160deg, #1a2332 0%, #0f1a26 100%);
  color: #e8ecf0;
  position: relative; overflow: hidden;
}
.site-footer::before {
  content: ''; position: absolute;
  top: -80px; right: -80px;
  width: 320px; height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(42,107,105,.25) 0%, transparent 70%);
  pointer-events: none;
}

.footer-inner {
  padding: 3rem 0 2rem;
  display: grid; grid-template-columns: 1.3fr 0.7fr;
  gap: 2.5rem; position: relative; z-index: 1;
}
.footer-brand h2 {
  font-family: var(--font-display);
  font-size: 1.4rem; color: #fff; margin-bottom: .75rem;
}
.footer-note, .cookie-note { color: #9aa5b1; font-size: .88rem; line-height: 1.65; margin-bottom: .6rem; }

.footer-links {
  display: flex; flex-wrap: wrap; gap: .6rem 1rem;
  margin-bottom: 1.25rem;
}
.footer-links a {
  color: #c8d4df; font-size: .9rem; font-weight: 500;
  padding: .3rem .6rem; border-radius: 6px;
  transition: background var(--transition), color var(--transition);
}
.footer-links a:hover { background: rgba(255,255,255,.08); color: #fff; text-decoration: none; }

.footer-copy { color: #6b7a8a; font-size: .84rem; }
.footer-copy a { color: #9aa5b1; }
.footer-copy a:hover { color: #fff; }

/* footer email */
#secure-email { color: #7ecac8; }
#secure-email:hover { color: #fff; }

/* ---------- Divider ---------- */
.section-divider {
  border: none; margin: .5rem 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}

/* ---------- Quick-links / 3-col ---------- */
.quick-links { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; margin: 2rem 0; }
.three-col-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .economy-stats { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 900px) {
  .hero-grid,
  .footer-inner,
  .stats-grid,
  .image-grid,
  .quick-links,
  .three-col-grid,
  .activity-grid,
  .industry-grid,
  .season-grid { grid-template-columns: 1fr; }

  .economy-stats { grid-template-columns: repeat(2,1fr); }

  .header-inner { flex-direction: row; flex-wrap: wrap; align-items: center; }
  .branding { flex: 1 1 auto; }

  .site-nav {
    display: none; width: 100%;
    background: var(--surface);
    border-top: 1px solid var(--border);
    padding: .75rem 0;
  }
  .site-nav.open { display: block; }
  .site-nav ul { flex-direction: column; gap: .2rem; }
  .site-nav a { border-radius: var(--radius-sm); padding: .65rem .9rem; }

  .nav-toggle { display: flex; }

  .hero-card {
    transform: none;
    max-width: 480px; margin: 0 auto;
  }
}

@media (max-width: 640px) {
  .hero { padding: 3rem 0 2rem; }
  .content-block { padding: 1.35rem 1.25rem; }
  .economy-stats { grid-template-columns: repeat(2,1fr); }
  .econ-card .econ-num { font-size: 1.5rem; }
  .button-row { gap: .6rem; }
  .button { padding: .75rem 1.1rem; font-size: .88rem; }
}
