/* ════════════════════════════════════════════════════════════
   COMMON — variables, reset, header, footer, announcement,
   buttons, breadcrumb, AOS, shared responsive
════════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --black: #0a0a0a;
  --white: #fafaf8;
  --cream: #f5f3ee;
  --gold: #b89b6a;
  --gold-light: #d4b98a;
  --dark-grey: #2a2a2a;
  --mid-grey: #6b6b6b;
  --light-grey: #e8e5df;
  --font-serif: 'Cormorant Garamond', Georgia, serif;
  --font-sans: 'Jost', sans-serif;
}

html { scroll-behavior: smooth; }
body { font-family: var(--font-sans); background: var(--white); color: var(--black); overflow-x: hidden; }

/* ── PAGES (SPA toggle) ── */
.page { display: none; }
.page.active { display: block; }

/* ── ANNOUNCEMENT ── */
.announcement { background: var(--black); color: var(--white); text-align: center; padding: 9px 20px; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; }

/* ══════════════════════════════════════
   HEADER
══════════════════════════════════════ */
header { background: var(--white); border-bottom: 1px solid var(--light-grey); position: sticky; top: 0; z-index: 1000; }
.header-top { display: flex; align-items: center; justify-content: space-between; padding: 0 48px; height: 72px; max-width: 1440px; margin: 0 auto; }
.logo { font-family: var(--font-serif); font-size: 26px; font-weight: 600; letter-spacing: 4px; color: var(--black); text-decoration: none; text-transform: uppercase; cursor: pointer; }
.logo span { color: var(--gold); }
.header-icons { display: flex; gap: 20px; align-items: center; }
.header-icons span { font-size: 18px; cursor: pointer; color: var(--dark-grey); transition: color .2s; }
.header-icons span:hover { color: var(--gold); }

/* ── MOBILE MENU BUTTON + DRAWER ── */
.mobile-menu-btn { display: none; background: none; border: none; font-size: 24px; cursor: pointer; color: var(--dark-grey); padding: 6px 8px; line-height: 1; transition: color .2s; }
.mobile-menu-btn:hover { color: var(--gold); }
.mobile-nav { display: none; }
.mobile-nav-link { padding: 16px 24px; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; color: var(--dark-grey); text-decoration: none; border-bottom: 1px solid var(--light-grey); cursor: pointer; font-weight: 500; transition: color .2s, background .2s; }
.mobile-nav-link:last-child { border-bottom: none; }
.mobile-nav-link:hover { color: var(--gold); background: var(--cream); }

/* ── MAIN NAV ── */
.main-nav { display: flex; gap: 0; list-style: none; position: relative; }
.nav-item { position: relative; }
.nav-link { display: flex; align-items: center; gap: 5px; padding: 0 18px; height: 72px; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--dark-grey); text-decoration: none; font-weight: 500; border-bottom: 2px solid transparent; transition: color .2s, border-color .2s; cursor: pointer; background: none; border-top: none; border-left: none; border-right: none; font-family: var(--font-sans); white-space: nowrap; }
.nav-link:hover, .nav-item:hover > .nav-link { color: var(--gold); border-bottom-color: var(--gold); }
.nav-arrow { font-size: 9px; transition: transform .25s; }
.nav-item:hover .nav-arrow { transform: rotate(180deg); }

/* ── MEGA MENU ── */
.mega-menu { position: absolute; top: 72px; left: 0; background: var(--white); border-top: 2px solid var(--gold); box-shadow: 0 16px 48px rgba(0, 0, 0, .13); display: none; z-index: 999; min-width: 700px; }
.nav-item:hover .mega-menu { display: flex; }
.mega-sidebar { width: 210px; flex-shrink: 0; background: var(--cream); border-right: 1px solid var(--light-grey); padding: 20px 0; }
.mega-sidebar-item { padding: 12px 22px; font-size: 12px; font-weight: 500; color: var(--dark-grey); cursor: pointer; border-left: 3px solid transparent; transition: all .15s; display: flex; align-items: center; justify-content: space-between; }
.mega-sidebar-item:hover, .mega-sidebar-item.active { background: var(--white); border-left-color: var(--gold); color: var(--gold); }
.mega-sidebar-item .arr { font-size: 10px; color: var(--mid-grey); }
.mega-content { flex: 1; padding: 24px 28px; min-width: 0; }
.mega-panel { display: none; }
.mega-panel.active { display: block; }
.mega-panel-label { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); margin-bottom: 18px; font-weight: 600; }

.mega-subcat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.mega-sub-card { cursor: pointer; transition: transform .2s; }
.mega-sub-card:hover { transform: translateY(-2px); }
.mega-sub-img { aspect-ratio: 4/3; overflow: hidden; background: var(--cream); margin-bottom: 7px; position: relative; display: flex; align-items: center; justify-content: center; font-size: 26px; }
.mega-sub-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s; position: absolute; inset: 0; }
.mega-sub-card:hover .mega-sub-img img { transform: scale(1.07); }
.mega-sub-name { font-size: 11px; font-weight: 500; color: var(--dark-grey); }

.mega-link-list { display: flex; flex-direction: column; gap: 10px; }
.mega-link-list a { font-size: 12px; color: var(--mid-grey); text-decoration: none; transition: color .2s; display: flex; align-items: center; gap: 8px; cursor: pointer; }
.mega-link-list a::before { content: '—'; color: var(--gold); font-size: 9px; }
.mega-link-list a:hover { color: var(--dark-grey); }

/* ══════════════════════════════════════
   BUTTONS
══════════════════════════════════════ */
.btn-gold { padding: 13px 30px; background: var(--gold); color: var(--white); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; font-family: var(--font-sans); font-weight: 500; transition: background .3s; cursor: pointer; border: none; }
.btn-gold:hover { background: var(--gold-light); }
.btn-ghost { padding: 12px 28px; background: transparent; color: var(--white); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; font-family: var(--font-sans); font-weight: 500; border: 1px solid rgba(255, 255, 255, .5); transition: all .3s; cursor: pointer; }
.btn-ghost:hover { border-color: var(--gold); background: rgba(184, 155, 106, .1); }

/* ══════════════════════════════════════
   SECTION HEADER
══════════════════════════════════════ */
.sec-hdr { text-align: center; margin-bottom: 44px; }
.sec-tag { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); display: block; margin-bottom: 10px; }
.sec-title { font-family: var(--font-serif); font-size: clamp(26px, 3.5vw, 44px); font-weight: 300; color: var(--dark-grey); line-height: 1.2; }
.sec-title em { font-style: italic; }
.sec-div { width: 44px; height: 1px; background: var(--gold); margin: 14px auto 0; }

/* ══════════════════════════════════════
   BREADCRUMB
══════════════════════════════════════ */
.breadcrumb { max-width: 1440px; margin: 0 auto; padding: 14px 48px; display: flex; gap: 7px; align-items: center; font-size: 11px; color: var(--mid-grey); flex-wrap: wrap; }
.breadcrumb a { color: var(--mid-grey); text-decoration: none; cursor: pointer; transition: color .2s; }
.breadcrumb a:hover { color: var(--gold); }
.bc-sep, .breadcrumb .sep { color: var(--light-grey); }
.bc-cur, .breadcrumb .current { color: var(--dark-grey); font-weight: 500; }

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer { background: #111; color: var(--white); padding: 56px 48px 28px; }
.footer-inner { max-width: 1200px; margin: 0 auto; }
.footer-top { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; padding-bottom: 40px; border-bottom: 1px solid rgba(255, 255, 255, .08); }
.f-logo, .footer-logo { font-family: var(--font-serif); font-size: 22px; font-weight: 600; letter-spacing: 4px; display: block; margin-bottom: 14px; color: var(--white); text-decoration: none; cursor: pointer; }
.f-logo span, .footer-logo span { color: var(--gold); }
.f-desc, .footer-desc { font-size: 12px; color: rgba(255, 255, 255, .45); line-height: 1.8; margin-bottom: 20px; }
.soc-links, .social-links { display: flex; gap: 10px; }
.soc { width: 32px; height: 32px; border: 1px solid rgba(255, 255, 255, .2); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; color: rgba(255, 255, 255, .5); text-decoration: none; transition: all .2s; }
.soc:hover { border-color: var(--gold); color: var(--gold); }
.f-col h4, .footer-col h4 { font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); margin-bottom: 16px; font-weight: 500; }
.f-col ul, .footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.f-col ul li a, .footer-col ul li a { font-size: 12px; color: rgba(255, 255, 255, .45); text-decoration: none; transition: color .2s; cursor: pointer; }
.f-col ul li a:hover, .footer-col ul li a:hover { color: var(--white); }
.footer-bot, .footer-bottom { display: flex; justify-content: space-between; font-size: 11px; color: rgba(255, 255, 255, .25); flex-wrap: wrap; gap: 10px; }
.footer-bot a, .footer-bottom a { color: rgba(255, 255, 255, .35); text-decoration: none; }
.footer-bot a:hover, .footer-bottom a:hover { color: var(--gold); }

/* ══════════════════════════════════════
   AOS (animate on scroll)
══════════════════════════════════════ */
.aos { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.aos.visible { opacity: 1; transform: none; }

/* ══════════════════════════════════════
   SHARED RESPONSIVE
══════════════════════════════════════ */
@media (max-width: 860px) {
  .header-top { padding: 0 20px; }
  .main-nav { display: none; }
  .mobile-menu-btn { display: flex; align-items: center; justify-content: center; }
  .mobile-nav.mobile-open {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 72px; left: 0; right: 0;
    background: var(--white);
    border-top: 1px solid var(--light-grey);
    box-shadow: 0 16px 32px rgba(0, 0, 0, .1);
    z-index: 999;
  }
  .footer-top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  footer { padding: 40px 20px 24px; }
  .footer-top { grid-template-columns: 1fr; gap: 28px; }
  .breadcrumb { padding: 12px 20px; }
}
