
  /* ============================================================
   GOLDEN FLAME RESTAURANT — style.css
   Theme: Black + Gold + Dark Red | Luxury Modern
============================================================ */

  /* ---------- CSS Variables ---------- */
  :root {
      --gold: #D4A537;
      --gold-light: #F0C060;
      --gold-pale: #f5e6c0;
      --crimson: #8B0000;
      --crimson-light: #C0392B;
      --black: #0A0A0A;
      --black-2: #111111;
      --black-3: #1a1a1a;
      --dark: #1C1C1C;
      --dark-2: #252525;
      --dark-3: #2e2e2e;
      --white: #FFFFFF;
      --white-80: rgba(255, 255, 255, .8);
      --white-60: rgba(255, 255, 255, .6);
      --white-20: rgba(255, 255, 255, .12);
      --gold-20: rgba(212, 165, 55, .2);
      --gold-10: rgba(212, 165, 55, .08);
      --ff-display: 'Playfair Display', serif;
      --ff-body: 'Montserrat', sans-serif;
      --ff-accent: 'Cormorant Garamond', serif;
      --shadow-gold: 0 0 30px rgba(212, 165, 55, .25);
      --shadow-card: 0 8px 40px rgba(0, 0, 0, .5);
      --transition: all .35s cubic-bezier(.4, 0, .2, 1);
      --radius: 4px;
      --radius-lg: 12px;
  }

  /* ---------- Reset & Base ---------- */
  *,
  *::before,
  *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
  }

  html {
      scroll-behavior: smooth;
      font-size: 16px;
  }

  body {
      font-family: var(--ff-body);
      background: var(--black);
      color: var(--white);
      overflow-x: hidden;
      line-height: 1.7;
      -webkit-font-smoothing: antialiased;
  }

  img {
      display: block;
      width: 100%;
      object-fit: cover;
  }

  a {
      text-decoration: none;
      color: inherit;
  }

  ul {
      list-style: none;
  }

  input,
  textarea,
  button {
      font-family: var(--ff-body);
  }

  .container {
      max-width: 1240px;
      margin: 0 auto;
      padding: 0 24px;
  }

  .section-pad {
      padding: 100px 0;
  }

  .d-none-sm {
      display: initial;
  }

  /* ---------- Reveal Animations ---------- */
  .reveal,
  .reveal-left,
  .reveal-right {
      opacity: 0;
      transform: translateY(40px);
      transition: opacity .7s ease, transform .7s ease;
  }

  .reveal-left {
      transform: translateX(-50px);
  }

  .reveal-right {
      transform: translateX(50px);
  }

  .revealed {
      opacity: 1 !important;
      transform: none !important;
  }

  /* ---------- Section Header ---------- */
  .section-tag {
      font-family: var(--ff-body);
      font-size: .7rem;
      font-weight: 600;
      letter-spacing: .35em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 14px;
      display: block;
  }

  .section-title {
      font-family: var(--ff-display);
      font-size: clamp(2rem, 4vw, 3rem);
      font-weight: 700;
      line-height: 1.15;
      color: var(--white);
  }

  .section-title em {
      color: var(--gold);
      font-style: italic;
  }

  .section-desc {
      color: var(--white-60);
      font-size: .95rem;
      margin-top: 14px;
      max-width: 560px;
  }

  .section-header {
      text-align: center;
      margin-bottom: 56px;
  }

  .section-header .section-desc {
      margin: 14px auto 0;
  }

  /* ---------- Buttons ---------- */
  .btn-primary {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: linear-gradient(135deg, var(--gold), var(--gold-light));
      color: var(--black);
      font-weight: 600;
      font-size: .85rem;
      letter-spacing: .1em;
      text-transform: uppercase;
      padding: 14px 32px;
      border-radius: var(--radius);
      border: none;
      cursor: pointer;
      transition: var(--transition);
      position: relative;
      overflow: hidden;
  }

  .btn-primary::after {
      content: '';
      position: absolute;
      inset: 0;
      background: rgba(255, 255, 255, .15);
      opacity: 0;
      transition: var(--transition);
  }

  .btn-primary:hover::after {
      opacity: 1;
  }

  .btn-primary:hover {
      box-shadow: var(--shadow-gold);
      transform: translateY(-2px);
  }

  .btn-outline {
      display: inline-flex;
      align-items: center;
      padding: 13px 32px;
      border: 1.5px solid rgba(212, 165, 55, .6);
      color: var(--gold-light);
      font-weight: 500;
      font-size: .85rem;
      letter-spacing: .1em;
      text-transform: uppercase;
      border-radius: var(--radius);
      transition: var(--transition);
  }

  .btn-outline:hover {
      background: var(--gold-20);
      border-color: var(--gold);
      color: var(--white);
  }

  .btn-full {
      width: 100%;
      justify-content: center;
  }


  /* ============================================================
   NAVBAR
============================================================ */
  .navbar {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 1000;
      padding: 20px 0;
      transition: var(--transition);
  }

  .navbar.scrolled {
      background: rgba(10, 10, 10, .95);
      backdrop-filter: blur(20px);
      padding: 14px 0;
      border-bottom: 1px solid var(--gold-20);
      box-shadow: 0 4px 30px rgba(0, 0, 0, .5);
  }

  .nav-container {
      max-width: 1240px;
      margin: 0 auto;
      padding: 0 24px;
      display: flex;
      align-items: center;
      justify-content: space-between;
  }

  .nav-logo {
      display: flex;
      align-items: center;
      gap: 10px;
  }

  .flame-icon {
      font-size: 1.5rem;
  }

  .logo-text {
      font-family: var(--ff-display);
      font-size: 1.3rem;
      font-weight: 700;
      color: var(--white);
      letter-spacing: .02em;
  }

  .logo-text .gold {
      color: var(--gold);
  }

  .nav-links {
      display: flex;
      align-items: center;
      gap: 8px;
  }

  .nav-link {
      padding: 6px 14px;
      font-size: .8rem;
      font-weight: 500;
      letter-spacing: .05em;
      text-transform: uppercase;
      color: var(--white-80);
      border-radius: var(--radius);
      transition: var(--transition);
      position: relative;
  }

  .nav-link::after {
      content: '';
      position: absolute;
      bottom: 2px;
      left: 14px;
      right: 14px;
      height: 1px;
      background: var(--gold);
      transform: scaleX(0);
      transition: transform .3s ease;
  }

  .nav-link:hover {
      color: var(--gold);
  }

  .nav-link:hover::after {
      transform: scaleX(1);
  }

  .nav-cta {
      margin-left: 10px;
      background: linear-gradient(135deg, var(--gold), var(--gold-light));
      color: var(--black);
      padding: 9px 22px;
      border-radius: var(--radius);
      font-size: .78rem;
      font-weight: 700;
      letter-spacing: .06em;
      text-transform: uppercase;
      transition: var(--transition);
  }

  .nav-cta:hover {
      box-shadow: var(--shadow-gold);
      transform: translateY(-1px);
  }

  .hamburger {
      display: none;
      flex-direction: column;
      gap: 5px;
      background: none;
      border: none;
      cursor: pointer;
      padding: 4px;
  }

  .hamburger span {
      display: block;
      width: 26px;
      height: 2px;
      background: var(--gold);
      border-radius: 2px;
      transition: var(--transition);
  }

  .hamburger.open span:nth-child(1) {
      transform: translateY(7px) rotate(45deg);
  }

  .hamburger.open span:nth-child(2) {
      opacity: 0;
  }

  .hamburger.open span:nth-child(3) {
      transform: translateY(-7px) rotate(-45deg);
  }


  /* ============================================================
   HERO
============================================================ */
  .hero {
      position: relative;
      min-height: 100vh;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      overflow: hidden;
  }

  .hero-bg {
      position: absolute;
      inset: 0;
      background-image: url('https://images.unsplash.com/photo-1517248135467-4c7edcad34c4?w=1600&q=90');
      background-size: cover;
      background-position: center;
      animation: heroZoom 20s ease infinite alternate;
  }

  @keyframes heroZoom {
      from {
          transform: scale(1);
      }

      to {
          transform: scale(1.08);
      }
  }

  .hero-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg,
              rgba(10, 10, 10, .6) 0%,
              rgba(10, 10, 10, .75) 50%,
              rgba(10, 10, 10, .95) 100%);
  }

  .hero-particles {
      position: absolute;
      inset: 0;
      pointer-events: none;
  }

  .particle {
      position: absolute;
      width: 2px;
      height: 2px;
      background: var(--gold);
      border-radius: 50%;
      opacity: 0;
      animation: float var(--dur, 8s) ease-in-out infinite var(--delay, 0s);
  }

  @keyframes float {
      0% {
          opacity: 0;
          transform: translateY(0) scale(1);
      }

      50% {
          opacity: .7;
      }

      100% {
          opacity: 0;
          transform: translateY(-120px) scale(0);
      }
  }

  .hero-content {
      position: relative;
      z-index: 2;
      text-align: center;
      padding: 0 24px;
      max-width: 800px;
  }

  .hero-badge {
      display: inline-block;
      border: 1px solid var(--gold-20);
      background: var(--gold-10);
      color: var(--gold-light);
      font-size: .7rem;
      letter-spacing: .35em;
      text-transform: uppercase;
      padding: 7px 20px;
      border-radius: 50px;
      margin-bottom: 28px;
      backdrop-filter: blur(10px);
  }

  .hero-title {
      font-family: var(--ff-display);
      font-size: clamp(2.8rem, 8vw, 6rem);
      font-weight: 900;
      line-height: 1.05;
      margin-bottom: 24px;
      color: var(--white);
  }

  .hero-title em {
      color: var(--gold);
      font-style: italic;
      display: block;
  }

  .hero-title span {
      display: block;
      color: var(--white-80);
  }

  .hero-subtitle {
      font-family: var(--ff-accent);
      font-size: clamp(1rem, 2vw, 1.25rem);
      color: var(--white-60);
      margin-bottom: 40px;
      font-weight: 300;
      line-height: 1.8;
  }

  .hero-btns {
      display: flex;
      gap: 16px;
      justify-content: center;
      flex-wrap: wrap;
  }

  .hero-scroll-indicator {
      position: absolute;
      bottom: 120px;
      left: 50%;
      transform: translateX(-50%);
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 10px;
      color: var(--white-60);
      font-size: .68rem;
      letter-spacing: .2em;
      text-transform: uppercase;
      z-index: 2;
  }

  .scroll-line {
      width: 1px;
      height: 50px;
      background: linear-gradient(var(--gold), transparent);
      animation: scrollPulse 2s ease infinite;
  }

  @keyframes scrollPulse {

      0%,
      100% {
          opacity: .3;
          transform: scaleY(1);
      }

      50% {
          opacity: 1;
          transform: scaleY(1.2);
      }
  }

  .hero-stats {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      z-index: 2;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0;
      background: rgba(10, 10, 10, .8);
      backdrop-filter: blur(20px);
      border-top: 1px solid var(--gold-20);
      padding: 24px 0;
  }

  .stat {
      text-align: center;
      padding: 0 48px;
  }

  .stat-num {
      display: block;
      font-family: var(--ff-display);
      font-size: 2rem;
      font-weight: 700;
      color: var(--gold);
  }

  .stat-label {
      font-size: .72rem;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--white-60);
  }

  .stat-divider {
      width: 1px;
      height: 50px;
      background: var(--white-20);
  }


  /* ============================================================
   ABOUT
============================================================ */
  .about {
      background: var(--black-2);
  }

  .about-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
  }

  .about-images {
      position: relative;
  }

  .about-img-main {
      border-radius: var(--radius-lg);
      overflow: hidden;
      aspect-ratio: 4/3;
      box-shadow: var(--shadow-card);
  }

  .about-img-main img {
      height: 100%;
      transition: transform .7s ease;
  }

  .about-img-main:hover img {
      transform: scale(1.04);
  }

  .about-img-accent {
      position: absolute;
      bottom: -40px;
      right: -40px;
      width: 200px;
      border-radius: var(--radius-lg);
      overflow: hidden;
      box-shadow: var(--shadow-card);
      border: 3px solid var(--dark-2);
  }

  .about-img-accent img {
      height: 160px;
  }

  .about-badge-floating {
      position: absolute;
      bottom: 0;
      left: 0;
      background: linear-gradient(135deg, var(--gold), var(--gold-light));
      color: var(--black);
      padding: 10px 14px;
      text-align: center;
      width: 100%;
  }

  .badge-num {
      display: block;
      font-weight: 700;
      font-size: 1rem;
  }

  .badge-txt {
      font-size: .65rem;
      text-transform: uppercase;
      letter-spacing: .1em;
  }

  .about-text {
      padding: 20px 0;
  }

  .about-lead {
      font-family: var(--ff-accent);
      font-size: 1.2rem;
      color: var(--white-80);
      margin: 20px 0 16px;
      line-height: 1.8;
      font-weight: 400;
  }

  .about-body {
      color: var(--white-60);
      font-size: .92rem;
      margin-bottom: 36px;
  }

  .about-features {
      display: flex;
      flex-direction: column;
      gap: 20px;
      margin-bottom: 36px;
  }

  .feature-item {
      display: flex;
      align-items: flex-start;
      gap: 16px;
  }

  .feature-item i {
      font-size: 1.3rem;
      color: var(--gold);
      margin-top: 2px;
      flex-shrink: 0;
      width: 36px;
      height: 36px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--gold-10);
      border-radius: 50%;
  }

  .feature-item strong {
      display: block;
      color: var(--white);
      font-size: .92rem;
      margin-bottom: 2px;
  }

  .feature-item p {
      color: var(--white-60);
      font-size: .82rem;
  }


  /* ============================================================
   MENU
============================================================ */
  .menu {
      background: var(--black-3);
  }

  .menu-filters {
      display: flex;
      gap: 10px;
      justify-content: center;
      flex-wrap: wrap;
      margin-bottom: 48px;
  }

  .filter-btn {
      padding: 9px 24px;
      border: 1.5px solid var(--white-20);
      background: transparent;
      color: var(--white-60);
      border-radius: 50px;
      font-size: .78rem;
      font-weight: 500;
      letter-spacing: .08em;
      text-transform: uppercase;
      cursor: pointer;
      transition: var(--transition);
  }

  .filter-btn:hover,
  .filter-btn.active {
      background: linear-gradient(135deg, var(--gold), var(--gold-light));
      border-color: transparent;
      color: var(--black);
      font-weight: 700;
  }

  .menu-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
      gap: 28px;
  }

  .menu-card {
      background: var(--dark-2);
      border-radius: var(--radius-lg);
      overflow: hidden;
      border: 1px solid var(--white-20);
      transition: var(--transition);
      position: relative;
  }

  .menu-card.hidden {
      display: none;
  }

  .menu-card:hover {
      transform: translateY(-8px);
      border-color: var(--gold-20);
      box-shadow: 0 20px 60px rgba(0, 0, 0, .5), var(--shadow-gold);
  }

  .card-img-wrap {
      position: relative;
      overflow: hidden;
      height: 200px;
  }

  .card-img-wrap img {
      height: 100%;
      transition: transform .6s ease;
  }

  .menu-card:hover .card-img-wrap img {
      transform: scale(1.08);
  }

  .card-badge {
      position: absolute;
      top: 12px;
      left: 12px;
      background: linear-gradient(135deg, var(--gold), var(--gold-light));
      color: var(--black);
      font-size: .65rem;
      font-weight: 700;
      letter-spacing: .1em;
      text-transform: uppercase;
      padding: 4px 10px;
      border-radius: 50px;
  }

  .card-body {
      padding: 20px;
  }

  .card-top {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      margin-bottom: 10px;
      gap: 8px;
  }

  .card-name {
      font-family: var(--ff-display);
      font-size: 1.05rem;
      font-weight: 600;
      color: var(--white);
      line-height: 1.3;
  }

  .card-price {
      font-weight: 700;
      color: var(--gold);
      font-size: 1rem;
      white-space: nowrap;
      flex-shrink: 0;
  }

  .card-desc {
      color: var(--white-60);
      font-size: .82rem;
      line-height: 1.7;
      margin-bottom: 14px;
  }

  .card-tag {
      font-size: .7rem;
      color: var(--gold);
      letter-spacing: .05em;
      text-transform: uppercase;
  }


  /* ============================================================
   GALLERY
============================================================ */
  .gallery {
      background: var(--black);
  }

  .gallery-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      grid-template-rows: 280px 280px;
      gap: 12px;
      padding: 0 16px;
      max-width: 1240px;
      margin: 0 auto;
  }

  .g-item {
      position: relative;
      overflow: hidden;
      border-radius: var(--radius);
      cursor: pointer;
  }

  .g-item img {
      height: 100%;
      transition: transform .7s ease;
  }

  .g-item:hover img {
      transform: scale(1.08);
  }

  .g-wide {
      grid-column: span 2;
  }

  .g-tall {
      grid-row: span 2;
  }

  .g-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(transparent 50%, rgba(10, 10, 10, .85) 100%);
      display: flex;
      align-items: flex-end;
      padding: 20px;
      opacity: 0;
      transition: var(--transition);
  }

  .g-item:hover .g-overlay {
      opacity: 1;
  }

  .g-overlay span {
      font-family: var(--ff-display);
      font-size: 1rem;
      color: var(--gold-light);
      font-style: italic;
  }


  /* ============================================================
   TESTIMONIALS
============================================================ */
  .testimonials {
      background: var(--black-2);
  }

  .testi-slider {
      overflow: hidden;
      position: relative;
  }

  .testi-track {
      display: flex;
      gap: 28px;
      transition: transform .5s cubic-bezier(.4, 0, .2, 1);
  }

  .testi-card {
      flex: 0 0 calc((100% - 56px) / 3);
      background: var(--dark-2);
      border: 1px solid var(--white-20);
      border-radius: var(--radius-lg);
      padding: 36px;
      position: relative;
      transition: var(--transition);
  }

  .testi-card:hover {
      border-color: var(--gold-20);
      transform: translateY(-4px);
      box-shadow: 0 20px 60px rgba(0, 0, 0, .4);
  }

  .testi-quote {
      color: var(--gold);
      font-size: 1.8rem;
      margin-bottom: 16px;
      opacity: .5;
  }

  .testi-text {
      font-family: var(--ff-accent);
      font-size: 1.05rem;
      color: var(--white-80);
      line-height: 1.8;
      margin-bottom: 28px;
      font-style: italic;
  }

  .testi-author {
      display: flex;
      align-items: center;
      gap: 14px;
  }

  .author-avatar {
      width: 44px;
      height: 44px;
      background: linear-gradient(135deg, var(--gold), var(--crimson-light));
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 700;
      color: var(--white);
      font-size: 1rem;
      flex-shrink: 0;
  }

  .testi-author strong {
      display: block;
      color: var(--white);
      font-size: .9rem;
  }

  .testi-author span {
      color: var(--white-60);
      font-size: .78rem;
  }

  .testi-stars {
      margin-left: auto;
      color: var(--gold);
      font-size: .8rem;
      letter-spacing: 2px;
  }

  .testi-controls {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 20px;
      margin-top: 40px;
  }

  .testi-btn {
      width: 44px;
      height: 44px;
      border-radius: 50%;
      border: 1.5px solid var(--white-20);
      background: transparent;
      color: var(--gold);
      cursor: pointer;
      font-size: .9rem;
      transition: var(--transition);
  }

  .testi-btn:hover {
      background: var(--gold-20);
      border-color: var(--gold);
  }

  .testi-dots {
      display: flex;
      gap: 8px;
  }

  .testi-dot {
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: var(--white-20);
      cursor: pointer;
      transition: var(--transition);
      border: none;
  }

  .testi-dot.active {
      background: var(--gold);
      width: 24px;
      border-radius: 4px;
  }


  /* ============================================================
   CONTACT
============================================================ */
  .contact {
      background: var(--black-3);
  }

  .contact-grid {
      display: grid;
      grid-template-columns: 1fr 1.4fr;
      gap: 80px;
      align-items: flex-start;
  }

  .contact-info {
      display: flex;
      flex-direction: column;
      gap: 32px;
      padding-top: 8px;
  }

  .info-item {
      display: flex;
      align-items: flex-start;
      gap: 18px;
  }

  .info-icon {
      width: 48px;
      height: 48px;
      background: var(--gold-10);
      border: 1px solid var(--gold-20);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--gold);
      font-size: 1rem;
      flex-shrink: 0;
  }

  .info-item strong {
      display: block;
      color: var(--white);
      font-size: .9rem;
      margin-bottom: 5px;
  }

  .info-item p {
      color: var(--white-60);
      font-size: .87rem;
      line-height: 1.7;
  }

  .contact-form {
      background: var(--dark-2);
      border: 1px solid var(--white-20);
      border-radius: var(--radius-lg);
      padding: 48px;
      display: flex;
      flex-direction: column;
      gap: 20px;
  }

  .form-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 20px;
  }

  .form-group {
      display: flex;
      flex-direction: column;
      gap: 8px;
  }

  .form-group label {
      font-size: .75rem;
      font-weight: 600;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--gold);
  }

  .form-group input,
  .form-group textarea {
      background: var(--dark-3);
      border: 1px solid var(--white-20);
      border-radius: var(--radius);
      padding: 13px 16px;
      color: var(--white);
      font-size: .9rem;
      transition: var(--transition);
      outline: none;
  }

  .form-group input::placeholder,
  .form-group textarea::placeholder {
      color: rgba(255, 255, 255, .3);
  }

  .form-group input:focus,
  .form-group textarea:focus {
      border-color: var(--gold);
      background: rgba(212, 165, 55, .05);
      box-shadow: 0 0 0 3px rgba(212, 165, 55, .1);
  }

  .form-group textarea {
      resize: vertical;
      min-height: 100px;
  }

  .form-success {
      display: none;
      background: rgba(0, 128, 0, .1);
      border: 1px solid rgba(0, 200, 0, .3);
      color: #4caf50;
      padding: 14px 20px;
      border-radius: var(--radius);
      font-size: .87rem;
      align-items: center;
      gap: 10px;
  }

  .form-success.visible {
      display: flex;
  }


  /* ============================================================
   FOOTER
============================================================ */
  .footer {
      background: var(--black);
      border-top: 1px solid var(--gold-20);
  }

  .footer-top {
      padding: 70px 0 50px;
  }

  .footer-grid {
      display: grid;
      grid-template-columns: 2fr 1fr 1fr 1.5fr;
      gap: 60px;
  }

  .footer-brand .nav-logo {
      margin-bottom: 16px;
  }

  .footer-brand p {
      color: var(--white-60);
      font-size: .87rem;
      line-height: 1.8;
      max-width: 280px;
  }

  .social-links {
      display: flex;
      gap: 12px;
      margin-top: 24px;
  }

  .social-links a {
      width: 38px;
      height: 38px;
      background: var(--dark-2);
      border: 1px solid var(--white-20);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--white-60);
      font-size: .85rem;
      transition: var(--transition);
  }

  .social-links a:hover {
      background: linear-gradient(135deg, var(--gold), var(--gold-light));
      border-color: transparent;
      color: var(--black);
      transform: translateY(-2px);
  }

  .footer-links h4,
  .footer-newsletter h4 {
      font-family: var(--ff-display);
      color: var(--white);
      font-size: 1rem;
      margin-bottom: 20px;
  }

  .footer-links ul {
      display: flex;
      flex-direction: column;
      gap: 10px;
  }

  .footer-links a {
      color: var(--white-60);
      font-size: .87rem;
      transition: var(--transition);
  }

  .footer-links a:hover {
      color: var(--gold);
      padding-left: 6px;
  }

  .footer-newsletter p {
      color: var(--white-60);
      font-size: .87rem;
      margin-bottom: 16px;
  }

  .newsletter-form {
      display: flex;
      gap: 0;
  }

  .newsletter-form input {
      flex: 1;
      background: var(--dark-2);
      border: 1px solid var(--white-20);
      border-right: none;
      border-radius: var(--radius) 0 0 var(--radius);
      padding: 12px 16px;
      color: var(--white);
      font-size: .85rem;
      outline: none;
      transition: var(--transition);
  }

  .newsletter-form input:focus {
      border-color: var(--gold);
  }

  .newsletter-form button {
      background: linear-gradient(135deg, var(--gold), var(--gold-light));
      border: none;
      border-radius: 0 var(--radius) var(--radius) 0;
      padding: 12px 18px;
      color: var(--black);
      cursor: pointer;
      transition: var(--transition);
  }

  .newsletter-form button:hover {
      opacity: .9;
  }

  .footer-bottom {
      border-top: 1px solid var(--white-20);
      padding: 24px;
      text-align: center;
      color: var(--white-60);
      font-size: .82rem;
  }


  /* ============================================================
   BACK TO TOP
============================================================ */
  .back-to-top {
      position: fixed;
      bottom: 28px;
      right: 28px;
      width: 44px;
      height: 44px;
      background: linear-gradient(135deg, var(--gold), var(--gold-light));
      border: none;
      border-radius: 50%;
      color: var(--black);
      font-size: .85rem;
      cursor: pointer;
      opacity: 0;
      visibility: hidden;
      transform: translateY(10px);
      transition: var(--transition);
      z-index: 999;
      box-shadow: 0 4px 20px rgba(212, 165, 55, .4);
  }

  .back-to-top.visible {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
  }

  .back-to-top:hover {
      transform: translateY(-3px);
  }


  /* ============================================================
   RESPONSIVE
============================================================ */
  @media (max-width: 1024px) {
      .about-grid {
          grid-template-columns: 1fr;
          gap: 60px;
      }

      .about-img-accent {
          right: 0;
          bottom: -30px;
      }

      .contact-grid {
          grid-template-columns: 1fr;
          gap: 48px;
      }

      .footer-grid {
          grid-template-columns: 1fr 1fr;
          gap: 40px;
      }

      .testi-card {
          flex: 0 0 calc((100% - 28px) / 2);
      }

      .gallery-grid {
          grid-template-columns: repeat(3, 1fr);
      }

      .g-wide {
          grid-column: span 2;
      }
  }

  @media (max-width: 768px) {
      .section-pad {
          padding: 72px 0;
      }

      .hamburger {
          display: flex;
      }

      .nav-links {
          position: fixed;
          top: 0;
          right: -100%;
          width: 280px;
          height: 100vh;
          background: rgba(10, 10, 10, .98);
          backdrop-filter: blur(20px);
          flex-direction: column;
          justify-content: center;
          padding: 60px 40px;
          border-left: 1px solid var(--gold-20);
          transition: right .4s cubic-bezier(.4, 0, .2, 1);
          gap: 16px;
      }

      .nav-links.open {
          right: 0;
      }

      .nav-link {
          font-size: .95rem;
      }

      .nav-cta {
          margin-left: 0;
          margin-top: 8px;
      }

      .hero-title {
          font-size: clamp(2.2rem, 8vw, 3.5rem);
      }

      .hero-stats {
          display: none;
      }

      .d-none-sm {
          display: none;
      }

      .hero-scroll-indicator {
          bottom: 30px;
      }

      .about-img-accent {
          display: none;
      }

      .gallery-grid {
          grid-template-columns: 1fr 1fr;
          grid-template-rows: auto;
      }

      .g-wide {
          grid-column: span 2;
      }

      .g-tall {
          grid-row: span 1;
      }

      .testi-card {
          flex: 0 0 100%;
      }

      .contact-form {
          padding: 28px;
      }

      .form-row {
          grid-template-columns: 1fr;
      }

      .footer-grid {
          grid-template-columns: 1fr;
          gap: 36px;
      }

      .stat {
          padding: 0 24px;
      }
  }

  @media (max-width: 480px) {
      .menu-grid {
          grid-template-columns: 1fr;
      }

      .hero-btns {
          flex-direction: column;
          align-items: center;
      }

      .btn-primary,
      .btn-outline {
          width: 100%;
          justify-content: center;
      }

      .gallery-grid {
          grid-template-columns: 1fr;
      }

      .g-wide {
          grid-column: span 1;
      }

      .hero-scroll-indicator {
          display: none;
      }

      .contact-form {
          padding: 20px;
      }
  }

