/* ─── RESET & BASE ─── */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; font-size: 16px; }
    body { font-family: 'DM Sans', sans-serif; background: #faf7f4; color: #1c1410; overflow-x: hidden; }
    img { display: block; max-width: 100%; }
    a { text-decoration: none; color: inherit; }
    button { cursor: pointer; background: none; border: none; font-family: inherit; }
    ::-webkit-scrollbar { width: 5px; }
    ::-webkit-scrollbar-thumb { background: #c4985a; border-radius: 3px; }

    /* ─── CSS VARIABLES ─── */
    :root {
      --gold: #8B4F6B;
      --gold-dark: #6d3a52;
      --dark: #1c1410;
      --cream: #faf7f4;
      --stone: #f2eef0;
      --muted: #7a6e65;
      --border: #ddd4d9;
      --serif: 'Playfair Display', Georgia, serif;
      --sans: 'DM Sans', sans-serif;
    }

    /* ─── TYPOGRAPHY ─── */
    .serif { font-family: var(--serif); }
    .sans  { font-family: var(--sans);  }

    h1, h2, h3 { font-family: var(--serif); font-weight: 500; line-height: 1.15; }
    h1 { font-size: clamp(38px, 6vw, 76px); }
    h2 { font-size: clamp(28px, 4vw, 50px); }
    h3 { font-size: clamp(18px, 2.5vw, 24px); }

    p { line-height: 1.85; color: var(--muted); font-weight: 300; }

    .eyebrow {
      font-family: var(--sans);
      font-size: 11px;
      font-weight: 500;
      letter-spacing: 3.5px;
      text-transform: uppercase;
      color: var(--gold);
      display: block;
      margin-bottom: 14px;
    }

    /* ─── BUTTONS ─── */
    .btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-family: var(--sans);
      font-size: 13px;
      font-weight: 500;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      padding: 15px 36px;
      transition: all .25s ease;
    }
    .btn-gold  { background: var(--gold);  color: #fff; }
    .btn-gold:hover  { background: var(--gold-dark); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(196,152,90,.3); }
    .btn-ghost { border: 1px solid var(--gold); color: var(--gold); }
    .btn-ghost:hover { background: var(--gold); color: #fff; }

    /* ─── FADE-IN UTILITY ─── */
    @keyframes fadeUp {
      from { opacity: 0; transform: translateY(28px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    .fade-in { animation: fadeUp .8s ease forwards; }
    .fade-in.delay-1 { animation-delay: .12s; }
    .fade-in.delay-2 { animation-delay: .24s; }
    .fade-in.delay-3 { animation-delay: .36s; }
    .fade-in.delay-4 { animation-delay: .48s; }
    /* Override transition delays on section-level fades */
    .section .fade-in { animation-delay: 0s; }
    

    /* ─── DIVIDER ─── */
    .rule { width: 44px; height: 1px; background: var(--gold); margin: 22px 0; }
    .rule.center { margin: 22px auto; }

    /* ─── NAVBAR ─── */
    #navbar {
      position: fixed; top: 0; left: 0; right: 0; z-index: 900;
      padding: 0 48px;
      display: flex; align-items: center; justify-content: space-between;
      height: 72px;
      background: rgba(250,247,244,.94);
      backdrop-filter: blur(14px);
      border-bottom: 1px solid transparent;
      transition: border-color .3s, box-shadow .3s;
    }
    #navbar.scrolled { border-color: var(--border); box-shadow: 0 2px 20px rgba(0,0,0,.06); }

    .nav-logo { font-family: var(--serif); font-size: 20px; font-weight: 700; letter-spacing: 1px; }
    .nav-logo span { color: var(--gold); }

    .nav-links { display: flex; align-items: center; gap: 34px; }
    .nav-links a {
      font-size: 12px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase;
      color: var(--muted); transition: color .2s;
      padding-bottom: 2px; border-bottom: 1px solid transparent;
    }
    .nav-links a:hover,
    .nav-links a.active { color: var(--dark); border-bottom-color: var(--gold); }

    .lang-picker {
      display: flex; align-items: center; gap: 6px;
      font-size: 11px; font-weight: 500; letter-spacing: 1px;
      color: var(--muted);
    }
    .lang-btn {
      padding: 3px 7px;
      border-radius: 3px;
      transition: background .2s, color .2s;
      font-family: var(--sans);
    }
    .lang-btn:hover    { background: var(--stone); color: var(--dark); }
    .lang-btn.active   { background: var(--gold);  color: #fff; }

    .hamburger { display: none; flex-direction: column; gap: 5px; }
    .hamburger span { width: 24px; height: 1.5px; background: var(--dark); transition: all .3s; }

    /* ─── HERO ─── */
    #hero {
      min-height: 100vh;
      display: grid;
      grid-template-columns: 1fr 1fr;
      padding-top: 72px;
    }
    @media (max-width: 960px) {
      #hero { grid-template-columns: 1fr; min-height: auto; }
      .hero-right { height: 60vw; min-height: 300px; }
    }

    .hero-left {
      display: flex; flex-direction: column; justify-content: center;
      padding: 80px 64px 80px 72px;
      position: relative;
    }
    .hero-left::before {
      content: '';
      position: absolute; top: 0; left: 0;
      width: 0; height: 0;
    }

    .hero-title { letter-spacing: -1px; }
    .hero-title em { font-style: italic; color: var(--gold); }

    .hero-subtitle {
      font-size: 16px; line-height: 1.9; color: var(--muted);
      max-width: 420px; margin-top: 22px; font-weight: 300;
    }

    .hero-ctas { display: flex; gap: 14px; margin-top: 38px; flex-wrap: wrap; }

    .hero-badges {
      display: flex; gap: 36px; margin-top: 56px; padding-top: 40px;
      border-top: 1px solid var(--border);
    }
    .badge-num { font-family: var(--serif); font-size: 30px; font-weight: 500; color: var(--gold); }
    .badge-label { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-top: 2px; }

    .hero-right {
      position: relative; overflow: hidden;
      background: var(--dark);
      min-height: 500px;
    }
    .hero-img-main {
      position: absolute;
      top: 0; left: 0;
      width: 100%; height: 100%;
      object-fit: cover;
      opacity: .78;
      transition: transform 8s ease;
    }
    #hero:hover .hero-img-main { transform: scale(1.04); }

    .hero-overlay {
      position: absolute; inset: 0;
      background: linear-gradient(to right, rgba(28,20,16,.35) 0%, transparent 60%);
    }
    .hero-pill {
      position: absolute; bottom: 40px; left: 40px; right: 40px;
      background: rgba(250,247,244,.1);
      backdrop-filter: blur(18px);
      border: 1px solid rgba(196,152,90,.3);
      padding: 22px 28px;
      display: flex; gap: 24px; justify-content: space-around;
    }
    .pill-item { text-align: center; color: #fff; }
    .pill-val { font-family: var(--serif); font-size: 22px; color: var(--gold); }
    .pill-txt { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; opacity: .7; margin-top: 3px; font-family: var(--sans); }

    /* ─── SECTION WRAPPER ─── */
    .section { padding: 96px 48px; }
    .section-center { text-align: center; }
    .section-head { max-width: 560px; }
    .section-head.center { margin: 0 auto; }

    .container { max-width: 1200px; margin: 0 auto; }

    /* ─── TREATMENTS ─── */
    #treatments { background: #fff; }
    .treatments-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1px;
      background: var(--border);
      margin-top: 60px;
    }
    @media (max-width: 768px) {
      .treatments-grid { grid-template-columns: 1fr; }
    }
    @media (min-width: 769px) and (max-width: 960px) {
      .treatments-grid { grid-template-columns: 1fr 1fr; }
    }
    .treatment-card {
      background: #fff;
      overflow: hidden;
      position: relative;
      cursor: pointer;
    }
    .treatment-card:hover .tc-img { transform: scale(1.06); }
    .tc-img-wrap { height: 240px; overflow: hidden; }
    .tc-img { width: 100%; height: 240px; object-fit: cover; transition: transform .5s ease; display: block; }
    .tc-body { padding: 28px 26px 32px; }
    .tc-title { font-family: var(--serif); font-size: 20px; margin-bottom: 10px; }
    .tc-desc { font-size: 14px; line-height: 1.8; color: var(--muted); }
    .tc-tag {
      display: inline-block; margin-top: 16px;
      font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
      color: var(--gold); border-bottom: 1px solid var(--gold); padding-bottom: 1px;
      font-family: var(--sans);
    }

    /* ─── TECHNOLOGY ─── */
    #technology { background: var(--dark); color: #fff; }
    .tech-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
    .tech-img-wrap { position: relative; }
    .tech-img { width: 100%; height: 480px; object-fit: cover; display: block; }
    .tech-img-label {
      position: absolute; bottom: -1px; left: 0; right: 0;
      background: var(--gold); color: #fff;
      padding: 14px 22px;
      font-family: var(--sans); font-size: 11px; font-weight: 500; letter-spacing: 2.5px; text-transform: uppercase;
    }
    .tech-features { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; margin-top: 36px; }
    .tf-item {
      background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07);
      padding: 16px 14px;
      font-family: var(--sans); font-size: 12px; color: rgba(255,255,255,.65);
      display: flex; align-items: center; gap: 8px;
    }
    .tf-dot { width: 5px; height: 5px; background: var(--gold); border-radius: 50%; flex-shrink: 0; }

    /* ─── RESULTS / GALLERY ─── */
    #results { background: var(--cream); }
    .gallery-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 3px; margin-top: 56px; }
    @media (max-width: 768px) { 
      .gallery-grid { grid-template-columns: 1fr; }
      .gallery-item.tall { grid-row: span 1; }
    }
    .gallery-item { overflow: hidden; position: relative; }
    .gallery-item.tall { grid-row: span 2; }
    .gallery-img { width: 100%; height: 260px; object-fit: cover; transition: transform .5s ease; display: block; }
    .gallery-item:hover .gallery-img { transform: scale(1.04); }
    .gallery-caption {
      position: absolute; bottom: 0; left: 0; right: 0;
      background: linear-gradient(transparent, rgba(28,20,16,.7));
      padding: 24px 16px 14px;
      color: #fff; font-size: 12px; letter-spacing: 1px; text-transform: uppercase;
      font-family: var(--sans);
      opacity: 0; transition: opacity .3s;
    }
    .gallery-item:hover .gallery-caption { opacity: 1; }

    /* ─── REVIEWS ─── */
    #reviews { background: var(--stone); padding: 80px 48px; }
    .review-carousel { max-width: 760px; margin: 48px auto 0; text-align: center; position: relative; min-height: 200px; }
    .review-slide {
      position: absolute; inset: 0;
      display: flex; flex-direction: column; align-items: center;
      opacity: 0; transform: translateY(10px);
      transition: opacity .6s ease, transform .6s ease;
      pointer-events: none;
    }
    .review-slide.active { opacity: 1; transform: translateY(0); pointer-events: auto; position: relative; }
    .review-quote { font-family: var(--serif); font-size: clamp(18px, 2.5vw, 26px); font-style: italic; font-weight: 400; line-height: 1.6; color: var(--dark); }
    .review-stars { color: var(--gold); font-size: 15px; margin: 18px 0 12px; letter-spacing: 2px; }
    .review-name { font-family: var(--sans); font-size: 12px; font-weight: 500; letter-spacing: 2.5px; text-transform: uppercase; color: var(--muted); }
    .review-dots { display: flex; justify-content: center; gap: 8px; margin-top: 32px; }
    .rdot { width: 8px; height: 8px; border-radius: 50%; background: var(--border); border: none; transition: background .3s, transform .3s; }
    .rdot.active { background: var(--gold); transform: scale(1.25); }

    /* ─── RATES ─── */
    #rates { background: #fff; }
    .rate-hero {
      background: var(--dark); color: #fff;
      display: flex; flex-direction: column; align-items: center; justify-content: center;
      padding: 48px; text-align: center; margin-bottom: 48px;
    }
    .rate-price { font-family: var(--serif); font-size: 72px; font-weight: 400; color: var(--gold); line-height: 1; }
    .rate-unit { font-family: var(--sans); font-size: 14px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.55); margin-top: 8px; }
    .rates-table { width: 100%; border-collapse: collapse; }
    .rates-table tr { border-bottom: 1px solid var(--border); transition: background .2s; }
    .rates-table tr:hover { background: var(--stone); }
    .rates-table td { padding: 18px 24px; font-size: 15px; }
    .rates-table td:last-child { text-align: right; color: var(--gold); font-family: var(--serif); font-size: 17px; }
    .rates-table td:nth-child(2) { color: var(--muted); font-size: 13px; }
    .rates-note {
      margin-top: 32px; padding: 24px 28px;
      background: var(--stone); border-left: 3px solid var(--gold);
      font-size: 14px; line-height: 1.85; color: var(--muted);
    }

    /* ─── ABOUT ─── */
    #about { background: var(--cream); }
    .about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
    .about-images { position: relative; height: 520px; }
    .about-img-1 { position: absolute; top: 0; left: 0; width: 72%; height: 82%; object-fit: cover; display: block; }
    .about-img-2 { position: absolute; bottom: 0; right: 0; width: 56%; height: 60%; object-fit: cover; border: 6px solid var(--cream); display: block; }
    .about-gold-line { position: absolute; top: 20px; right: 20px; width: 1px; height: 80px; background: var(--gold); opacity: .5; }
    @media (max-width: 960px) {
      .about-images { height: 280px; }
      .about-img-1 { width: 68%; height: 78%; }
      .about-img-2 { width: 52%; height: 52%; }
    }
    .about-facts { margin-top: 36px; display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
    .af-item { padding: 18px 20px; border: 1px solid var(--border); }
    .af-val { font-family: var(--serif); font-size: 22px; color: var(--gold); }
    .af-label { font-size: 12px; color: var(--muted); margin-top: 4px; }
    .inclusive-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 24px; }
    .itag {
      padding: 6px 14px; border: 1px solid var(--border);
      font-size: 12px; color: var(--muted);
      font-family: var(--sans);
    }

    /* ─── FAQ ─── */
    #faq { background: var(--dark); color: #fff; }
    .faq-list { max-width: 760px; margin: 56px auto 0; }
    .faq-item { border-bottom: 1px solid rgba(255,255,255,.1); }
    .faq-q {
      width: 100%; display: flex; justify-content: space-between; align-items: center;
      padding: 24px 0; text-align: left;
      font-family: var(--serif); font-size: 18px; color: #fff;
      cursor: pointer; transition: color .2s;
    }
    .faq-q:hover { color: var(--gold); }
    .faq-icon { font-size: 22px; color: var(--gold); transition: transform .3s; flex-shrink: 0; margin-left: 20px; }
    .faq-item.open .faq-icon { transform: rotate(45deg); }
    .faq-a {
      max-height: 0; overflow: hidden;
      transition: max-height .4s ease, padding .4s ease;
      font-size: 14px; line-height: 1.9; color: rgba(255,255,255,.55);
    }
    .faq-item.open .faq-a { max-height: 200px; padding-bottom: 22px; }

    /* ─── CONTACT ─── */
    #contact { background: var(--cream); }
    .contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; margin-top: 56px; }
    .contact-img { width: 100%; height: 420px; object-fit: cover; display: block; }
    .contact-info { display: flex; flex-direction: column; justify-content: center; }
    .info-block { margin-bottom: 32px; }
    .info-label { font-size: 11px; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); font-family: var(--sans); margin-bottom: 8px; }
    .info-val { font-family: var(--serif); font-size: 18px; line-height: 1.7; }
    .info-val small { font-family: var(--sans); font-size: 13px; color: var(--muted); display: block; margin-top: 3px; }
    .social-row { display: flex; gap: 14px; margin-top: 8px; }
    .social-btn {
      padding: 10px 20px; border: 1px solid var(--border);
      font-size: 12px; font-family: var(--sans); letter-spacing: 1px; text-transform: uppercase;
      color: var(--muted); transition: border-color .2s, color .2s;
    }
    .social-btn:hover { border-color: var(--gold); color: var(--gold); }

    /* ─── CTA BANNER ─── */
    #cta-banner { background: var(--gold); color: #fff; padding: 72px 48px; text-align: center; }
    #cta-banner h2 { color: #fff; font-size: clamp(28px, 4vw, 48px); }
    #cta-banner p { color: rgba(255,255,255,.8); max-width: 480px; margin: 16px auto 36px; font-size: 16px; }
    .btn-white { background: #fff; color: var(--gold); font-family: var(--sans); font-size: 13px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; padding: 16px 42px; transition: all .25s; display: inline-block; }
    .btn-white:hover { background: var(--dark); color: #fff; }

    /* ─── FOOTER ─── */
    footer {
      background: #120e0b; color: rgba(255,255,255,.35);
      padding: 32px 48px;
      display: flex; align-items: center; justify-content: space-between;
      font-family: var(--sans); font-size: 12px; letter-spacing: .5px;
      flex-wrap: wrap; gap: 12px;
    }
    footer a { color: var(--gold); }

    /* ─── FLOATING WA ─── */
    #wa-float {
      position: fixed; bottom: 28px; right: 28px; z-index: 800;
      width: 58px; height: 58px; border-radius: 50%;
      background: #25D366; color: #fff;
      display: flex; align-items: center; justify-content: center;
      font-size: 27px;
      box-shadow: 0 6px 24px rgba(37,211,102,.4);
      transition: transform .2s, box-shadow .2s;
    }
    #wa-float:hover { transform: scale(1.1) translateY(-2px); box-shadow: 0 10px 32px rgba(37,211,102,.5); }

    /* ─── MOBILE NAV ─── */
    #mobile-menu {
      display: none;
      position: fixed; top: 72px; left: 0; right: 0; bottom: 0;
      background: rgba(250,247,244,.98); backdrop-filter: blur(20px);
      flex-direction: column; align-items: center; justify-content: center; gap: 28px;
      z-index: 800;
    }
    #mobile-menu.open { display: flex; }
    #mobile-menu a { font-family: var(--serif); font-size: 28px; color: var(--dark); }
    #mobile-menu .lang-picker { margin-top: 20px; }

    /* ─── RESPONSIVE ─── */
    @media (max-width: 960px) {
      #hero, .tech-grid, .about-grid, .contact-grid, .grid-2 { grid-template-columns: 1fr !important; }
      .hero-right { height: 50vw; min-height: 320px; }
      .treatments-grid { grid-template-columns: 1fr 1fr; }
      .gallery-grid { grid-template-columns: 1fr 1fr; }
      .gallery-item.tall { grid-row: span 1; }
      .about-images { height: 320px; }
      .nav-links { display: none; }
      .hamburger { display: flex; }
      .hero-left { padding: 56px 32px; }
      .section { padding: 72px 28px; }
    }

    @media (max-width: 600px) {
      #navbar { padding: 0 24px; }
      .treatments-grid { grid-template-columns: 1fr; }
      .gallery-grid { grid-template-columns: 1fr; }
      .tech-features { grid-template-columns: 1fr; }
      .about-facts { grid-template-columns: 1fr; }
      footer { flex-direction: column; text-align: center; }
    }
  
    @media (max-width: 960px) {
      .course-grid { grid-template-columns: 1fr !important; }
    }
  
.page-hero{min-height:65vh;display:grid;grid-template-columns:1fr 1fr;padding-top:72px;}
.phl{display:flex;flex-direction:column;justify-content:center;padding:64px 56px 64px 72px;}
.phr{position:relative;overflow:hidden;background:var(--dark);min-height:400px;}
.phi{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.78;}
.bc{font-family:var(--sans);font-size:12px;color:var(--muted);margin-bottom:20px;display:flex;gap:8px;align-items:center;}
.bc a{color:var(--gold);text-decoration:none;}
.cs{padding:80px 48px;}.csw{max-width:1200px;margin:0 auto;}
.two{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;}
.ci{width:100%;height:380px;object-fit:cover;display:block;}
.ktags{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0;}
.ktag{background:var(--stone);border:1px solid var(--border);padding:6px 14px;font-family:var(--sans);font-size:12px;color:var(--muted);}
.fbox{background:var(--stone);padding:40px;margin:48px 0;}
.fbox h3{font-family:var(--serif);font-size:22px;margin-bottom:24px;}
.fi{border-bottom:1px solid var(--border);padding:18px 0;}
.fi strong{font-family:var(--sans);font-size:14px;font-weight:500;display:block;margin-bottom:8px;color:var(--dark);}
.fi p{font-size:14px;color:var(--muted);line-height:1.8;margin:0;}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin:40px 0;}
.stat{background:var(--stone);padding:28px 24px;border:1px solid var(--border);text-align:center;}
.stat-val{font-family:var(--serif);font-size:36px;color:var(--gold);}
.stat-lab{font-family:var(--sans);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:6px;}
.rp{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.rc{background:var(--stone);padding:28px 24px;border:1px solid var(--border);text-decoration:none;color:var(--dark);transition:background .2s;display:block;}
.rc:hover{background:#fff;}.rct{font-family:var(--serif);font-size:18px;margin-bottom:8px;}
.rcd{font-family:var(--sans);font-size:13px;color:var(--muted);line-height:1.7;}
.rcl{font-family:var(--sans);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-top:14px;display:block;}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.card-w{background:#fff;border:1px solid var(--border);padding:28px 24px;}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;}
.blog-card{background:#fff;border:1px solid var(--border);text-decoration:none;color:var(--dark);display:block;transition:transform .2s,box-shadow .2s;}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08);}
.blog-card-img{width:100%;height:220px;object-fit:cover;display:block;}
.blog-card-body{padding:24px;}
.blog-card-cat{font-family:var(--sans);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.blog-card-title{font-family:var(--serif);font-size:19px;line-height:1.3;margin-bottom:10px;}
.blog-card-excerpt{font-family:var(--sans);font-size:13px;color:var(--muted);line-height:1.8;}
.blog-card-link{font-family:var(--sans);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-top:16px;display:block;}
@media(max-width:960px){
  .page-hero{grid-template-columns:1fr;}.phr{height:55vw;min-height:260px;}
  .phl{padding:48px 28px;}.two{grid-template-columns:1fr;}
  .rp{grid-template-columns:1fr;}.cs{padding:56px 24px;}
  .stat-row{grid-template-columns:1fr 1fr;}.grid3{grid-template-columns:1fr;}
  .blog-grid{grid-template-columns:1fr;}
}
.lang-dropdown{position:relative;display:inline-block;}
.lang-selected{display:flex;align-items:center;gap:8px;cursor:pointer;font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--dark);padding:8px 14px;border:1px solid var(--border);background:var(--cream);transition:all .2s;user-select:none;}
.lang-selected:hover{border-color:var(--gold);color:var(--gold);}
.lang-selected svg{transition:transform .2s;}
.lang-dropdown.open .lang-selected svg{transform:rotate(180deg);}
.lang-menu{display:none;position:absolute;top:calc(100% + 4px);right:0;background:var(--cream);border:1px solid var(--border);min-width:140px;z-index:999;box-shadow:0 8px 24px rgba(0,0,0,.08);}
.lang-dropdown.open .lang-menu{display:block;}
.lang-menu-item{display:flex;align-items:center;gap:10px;padding:11px 16px;cursor:pointer;font-family:var(--sans);font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--dark);transition:background .15s;border-bottom:1px solid var(--border);}
.lang-menu-item:last-child{border-bottom:none;}
.lang-menu-item:hover{background:var(--stone);color:var(--gold);}
.lang-menu-item.active{color:var(--gold);font-weight:500;}
