/* ============================================================
   HOMEPAGE — Layout & section-level styles
   /assets/css/homepage.css
============================================================ */

/* ── Section defaults ── */
.ggn-section {
  padding: 5.5rem 0;
}
.ggn-section--light  { background: var(--surface, #F8FAFC); }
.ggn-section--dark   { background: var(--navy, #0A1628); color: #fff; }
.ggn-section--dark h1,
.ggn-section--dark h2,
.ggn-section--dark h3,
.ggn-section--dark h4 { color: #fff; }
.ggn-section--dark p  { color: rgba(255,255,255,.75); }

/* ── Section header ── */
.ggn-section__head     { text-align: center; max-width: 640px; margin: 0 auto 3.5rem; }
.ggn-section__eyebrow  { display: block; font-family: var(--sans,'Montserrat',sans-serif); font-size: .7rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--flame, #E8832A); margin-bottom: .75rem; }
.ggn-section__head h2  { margin-bottom: .875rem; }
.ggn-section__sub      { color: var(--steel, #475569); font-size: 1.05rem; line-height: 1.75; }
.ggn-section__rule     { width: 48px; height: 3px; border-radius: 9999px; background: linear-gradient(90deg, var(--ocean,#0A4F6E), var(--flame,#E8832A)); margin: .875rem auto 0; }
.ggn-section__head.left,.ggn-section__head.left .ggn-section__rule { text-align: left; margin-left: 0; }
.ggn-section__cta      { text-align: center; margin-top: 2.75rem; }

/* ── Empty state ── */
.ggn-empty-state { text-align: center; padding: 3rem; color: var(--steel,#475569); background: var(--surface,#F8FAFC); border-radius: var(--r-xl,24px); border: 1px dashed var(--border,#E2E8F0); }

/* ── Stats ── */
.ggn-stats { background: var(--ocean,#0A4F6E); padding: 1.375rem 0; }
.ggn-stats__grid { display: flex; justify-content: center; flex-wrap: wrap; }
.ggn-stats__item { flex: 1; max-width: 180px; text-align: center; padding: .75rem 1rem; border-right: 1px solid rgba(255,255,255,.12); }
.ggn-stats__item:last-child { border-right: none; }
.ggn-stats__val  { display: block; font-family: var(--sans,'Montserrat',sans-serif); font-size: 1.625rem; font-weight: 800; color: var(--flame,#E8832A); line-height: 1; }
.ggn-stats__lbl  { display: block; font-size: .62rem; text-transform: uppercase; letter-spacing: .1em; color: rgba(255,255,255,.6); margin-top: .3rem; }

/* ── Affiliations ── */
.ggn-affil { background: var(--surface,#F8FAFC); border-top: 1px solid var(--border,#E2E8F0); border-bottom: 1px solid var(--border,#E2E8F0); padding: 1rem 0; }
.ggn-affil__inner { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.ggn-affil__label { font-size: .66rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--mist,#94A3B8); white-space: nowrap; margin-right: .5rem; }
.ggn-affil__badge { display: inline-flex; align-items: center; gap: .4rem; padding: .32rem .875rem; background: #fff; border: 1px solid var(--border,#E2E8F0); border-radius: 9999px; font-size: .72rem; font-weight: 700; color: var(--ocean,#0A4F6E); transition: all .15s; white-space: nowrap; }
.ggn-affil__badge:hover { border-color: var(--ocean,#0A4F6E); }
.ggn-affil__abbr { font-weight: 800; }
.ggn-affil__full { color: var(--mist,#94A3B8); font-weight: 400; }

/* ── Filter tabs ── */
.ggn-filters { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; margin-bottom: 2.5rem; }
.ggn-filter {
  padding: .45rem 1.15rem; border-radius: 9999px; font-size: .815rem; font-weight: 600;
  border: 1.5px solid var(--border,#E2E8F0); background: #fff; color: var(--steel,#475569);
  cursor: pointer; transition: all .15s; font-family: var(--sans,'Montserrat',sans-serif);
}
.ggn-filter:hover  { border-color: var(--ocean,#0A4F6E); color: var(--ocean,#0A4F6E); }
.ggn-filter.active { background: var(--ocean,#0A4F6E); border-color: var(--ocean,#0A4F6E); color: #fff; box-shadow: 0 4px 14px rgba(10,79,110,.3); }
.ggn-filter:focus-visible { outline: 2px solid var(--ocean,#0A4F6E); outline-offset: 3px; }

/* ── About section ── */
.ggn-about__text { display: flex; flex-direction: column; gap: 1rem; }
.ggn-about__text h2 { margin-bottom: .25rem; }
.ggn-about__text p  { color: var(--steel,#475569); line-height: 1.8; }
.ggn-about__feats { display: grid; grid-template-columns: 1fr 1fr; gap: .4rem .875rem; margin: .5rem 0 1.25rem; list-style: none; }
.ggn-about__feat { display: flex; align-items: center; gap: .45rem; font-size: .875rem; color: var(--ink,#111827); }
.ggn-about__feat-icon { flex-shrink: 0; }
.ggn-about__ctas { display: flex; gap: .875rem; flex-wrap: wrap; }
.ggn-about__card-wrap { position: relative; }
.ggn-about__quote-card { background: linear-gradient(135deg, var(--ocean,#0A4F6E), var(--flame,#E8832A)); border-radius: 24px; padding: 2.5rem; color: #fff; box-shadow: 0 20px 60px rgba(10,79,110,.25); }
.ggn-about__quote-mark { font-size: 3.5rem; font-style: italic; color: rgba(255,255,255,.28); line-height: 1; margin-bottom: .5rem; font-family: var(--serif,'Playfair Display',serif); }
.ggn-about__quote { font-family: var(--serif,'Playfair Display',serif); font-size: 1.1rem; line-height: 1.75; margin-bottom: 1.25rem; font-style: normal; color: #fff; }
.ggn-about__author { display: flex; align-items: center; gap: .75rem; }
.ggn-about__author-avatar { width: 48px; height: 48px; border-radius: 50%; background: rgba(255,255,255,.2); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1.1rem; flex-shrink: 0; }
.ggn-about__author-name  { font-weight: 700; font-size: .9rem; }
.ggn-about__author-title { font-size: .78rem; opacity: .82; }
.ggn-about__badge { position: absolute; top: -1rem; right: -1rem; background: var(--gold,#C9A84C); color: #fff; border-radius: 12px; padding: .75rem 1.25rem; font-size: .75rem; font-weight: 700; text-align: center; box-shadow: 0 8px 24px rgba(201,168,76,.38); }
.ggn-about__badge-num { font-size: 1.5rem; font-weight: 800; line-height: 1; }
.ggn-about__badge-lbl { margin-top: .2rem; }

/* ── Why grid ── */
.ggn-why-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px,1fr)); gap: 1.5rem; }

/* ── Trust platforms ── */
.ggn-trust-platforms { display: flex; justify-content: center; gap: 1.75rem; flex-wrap: wrap; margin-bottom: 2.25rem; }
.ggn-trust-platform { display: flex; align-items: center; gap: .625rem; padding: .75rem 1.375rem; background: #fff; border: 1px solid var(--border,#E2E8F0); border-radius: 12px; box-shadow: 0 2px 8px rgba(0,0,0,.04); }
.ggn-trust-platform__star  { font-size: 1.25rem; }
.ggn-trust-platform__score { font-weight: 700; font-size: .9rem; color: var(--navy,#0A1628); line-height: 1.2; }
.ggn-trust-platform__name  { font-size: .72rem; color: var(--mist,#94A3B8); }

/* ── Custom trip section ── */
.ggn-ctrip__info { display: flex; flex-direction: column; gap: 1rem; }
.ggn-ctrip__info h2 { color: #fff; font-size: clamp(1.75rem,3vw,2.5rem); margin-bottom: .25rem; }
.ggn-ctrip__points { display: flex; flex-direction: column; gap: .6rem; list-style: none; margin: .5rem 0; }
.ggn-ctrip__point { display: flex; align-items: flex-start; gap: .6rem; color: rgba(255,255,255,.88); font-size: .9rem; line-height: 1.55; }
.ggn-ctrip__contact { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 1rem; }
.ggn-ctrip__contact-btn { display: flex; align-items: center; gap: .625rem; color: rgba(255,255,255,.88); font-size: .875rem; text-decoration: none; transition: color .15s; }
.ggn-ctrip__contact-btn:hover { color: #fff; }
.ggn-ctrip__contact-icon { width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,.12); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background .15s; }
.ggn-ctrip__contact-icon--wa { background: #25D366; }
.ggn-ctrip__contact-btn:hover .ggn-ctrip__contact-icon { background: rgba(255,255,255,.22); }
.ggn-ctrip__form-wrap { }
.ggn-ctrip__form { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.13); border-radius: 24px; padding: 2rem; backdrop-filter: blur(12px); }
.ggn-ctrip__form-title { color: #fff; font-size: 1.15rem; margin-bottom: 1.25rem; }
.ggn-ctrip__form .form-field { margin-bottom: 0; }
.ggn-ctrip__form-note { text-align: center; color: rgba(255,255,255,.45); font-size: .74rem; margin-top: .75rem; }
.dark-input {
  width: 100%; padding: .75rem 1rem;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
  border-radius: 10px; color: #fff; font-size: .875rem;
  transition: border-color .15s, background .15s; outline: none;
  -webkit-appearance: none;
}
.dark-input::placeholder { color: rgba(255,255,255,.45); }
.dark-input:focus { border-color: rgba(255,255,255,.45); background: rgba(255,255,255,.13); }
.dark-input option { background: #1e293b; color: #fff; }

/* ── Blog grid ── */
.ggn-blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.75rem; }
.ggn-blog-card { background: #fff; border-radius: 20px; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,.06), 0 0 0 1px rgba(0,0,0,.04); transition: transform .25s, box-shadow .25s; }
.ggn-blog-card:hover { transform: translateY(-5px); box-shadow: 0 16px 40px rgba(0,0,0,.10); }
.ggn-blog-card__img-wrap { display: block; overflow: hidden; aspect-ratio: 16/9; }
.ggn-blog-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.ggn-blog-card:hover .ggn-blog-card__img { transform: scale(1.05); }
.ggn-blog-card__img-ph { width: 100%; height: 100%; min-height: 200px; background: linear-gradient(135deg,var(--ocean,#0A4F6E),var(--flame,#E8832A)); display: flex; align-items: center; justify-content: center; }
.ggn-blog-card__body  { padding: 1.5rem; }
.ggn-blog-card__cat   { font-size: .72rem; color: var(--flame,#E8832A); font-weight: 600; letter-spacing: .06em; text-transform: uppercase; margin-bottom: .4rem; }
.ggn-blog-card__title { font-size: 1.02rem; margin-bottom: .5rem; line-height: 1.38; }
.ggn-blog-card__title a { color: var(--navy,#111827); transition: color .15s; }
.ggn-blog-card__title a:hover { color: var(--ocean,#0A4F6E); }
.ggn-blog-card__date   { font-size: .78rem; color: var(--mist,#94A3B8); margin-bottom: .625rem; display: block; }
.ggn-blog-card__excerpt{ font-size: .875rem; color: var(--steel,#475569); line-height: 1.65; margin-bottom: .875rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ggn-blog-card__link { color: var(--ocean,#0A4F6E); font-size: .875rem; font-weight: 600; display: inline-flex; align-items: center; gap: .3rem; transition: gap .15s; }
.ggn-blog-card__link:hover { gap: .5rem; }

/* ── Contact ── */
.ggn-contact__info    { display: flex; flex-direction: column; gap: 1.25rem; }
.ggn-contact__info h3 { font-size: 1.05rem; margin-bottom: .25rem; }
.ggn-contact__items   { display: flex; flex-direction: column; gap: .875rem; }
.ggn-contact__item    { display: flex; gap: .875rem; align-items: flex-start; }
.ggn-contact__item-icon  { width: 42px; height: 42px; background: var(--surface,#F8FAFC); border: 1px solid var(--border,#E2E8F0); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0; }
.ggn-contact__item-label { font-size: .68rem; font-weight: 700; color: var(--mist,#94A3B8); letter-spacing: .06em; text-transform: uppercase; }
.ggn-contact__item-val   { font-size: .9rem; color: var(--ink,#111827); margin-top: .15rem; }
.ggn-contact__item-val a { color: var(--ink,#111827); transition: color .15s; }
.ggn-contact__item-val a:hover { color: var(--ocean,#0A4F6E); }
.ggn-contact__map  { border-radius: 16px; overflow: hidden; height: 260px; background: var(--surface,#F8FAFC); margin-top: .5rem; }
.ggn-contact__form-wrap { background: #fff; border-radius: 20px; padding: 2rem; box-shadow: 0 4px 24px rgba(0,0,0,.06); border: 1px solid var(--border,#E2E8F0); }
.ggn-contact__form { display: flex; flex-direction: column; gap: .875rem; }
.ggn-contact__form .contact-form-field { margin-bottom: 0; }
.ggn-contact__form .ggn-form-row { margin-bottom: 0; }

/* ── Homepage responsive ── */
@media (max-width: 1024px) {
  .ggn-blog-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 768px) {
  .ggn-section { padding: 3.5rem 0; }
  .ggn-stats__item { flex: 0 0 33.333%; max-width: 33.333%; }
  .ggn-stats__item:nth-child(3n) { border-right: none; }
  .ggn-stats__item:nth-child(n+4) { border-top: 1px solid rgba(255,255,255,.1); }
  .ggn-affil__full { display: none; }
  .ggn-about__feats { grid-template-columns: 1fr; }
  .ggn-about__badge { display: none; }
  .ggn-trust-platforms { gap: .75rem; }
  .ggn-trust-platform { padding: .625rem 1rem; }
  .ggn-blog-grid { grid-template-columns: 1fr; }
  .ggn-ctrip__form { padding: 1.5rem; }
  .ggn-filters { flex-wrap: nowrap; overflow-x: auto; justify-content: flex-start; padding-bottom: .5rem; scrollbar-width: none; }
  .ggn-filters::-webkit-scrollbar { display: none; }
  .ggn-filter { flex-shrink: 0; }
}
@media (max-width: 480px) {
  .ggn-stats__item { flex: 0 0 50%; max-width: 50%; }
  .ggn-stats__item:nth-child(3n) { border-right: 1px solid rgba(255,255,255,.12); }
  .ggn-stats__item:nth-child(even) { border-right: none; }
  .ggn-trust-platforms { justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; }
}
