/* ============================================================
   The Atelier — atelier.market
   Brand: #121212 dark / #C27F3C gold / #f01d4f accent
   Type:  Frank Ruhl Libre (display, HE+EN) / Heebo (body)
   RTL/LTR handled via html[dir] + logical properties.
   ============================================================ */
:root {
  --ink:        #121212;
  --ink-soft:   #1c1c1c;
  --paper:      #f7f4ef;
  --gold:       #C27F3C;
  --gold-soft:  #d99b5c;
  --accent:     #f01d4f;
  --text:       #ece7df;
  --text-dim:   #b7b0a5;
  --display:    'Frank Ruhl Libre', Georgia, serif;
  --body:       'Heebo', 'Segoe UI', Arial, sans-serif;
  --wrap:       1100px;
  --narrow:     760px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
}

body {
  font-family: var(--body);
  font-weight: 300;
  background: var(--ink);
  color: var(--text);
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
}

.wrap   { max-width: var(--wrap);   margin-inline: auto; padding-inline: 1.25rem; }
.narrow { max-width: var(--narrow); }

h1, h2, h3, h4 { font-family: var(--display); font-weight: 400; line-height: 1.2; }
a { color: var(--gold); text-decoration: none; }
a:hover { color: var(--gold-soft); }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }

.skip-link {
  position: absolute; inset-inline-start: -999px; top: 0;
  background: var(--gold); color: var(--ink); padding: .5rem 1rem; z-index: 100;
}
.skip-link:focus { inset-inline-start: 0; }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(18, 18, 18, .92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(194, 127, 60, .25);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; min-height: 72px; }
.brand { display: flex; flex-direction: column; line-height: 1.1; }
.brand-main { font-family: var(--display); font-size: 1.5rem; color: var(--gold); letter-spacing: .04em; }
.brand-sub  { font-size: .75rem; color: var(--text-dim); letter-spacing: .28em; text-transform: uppercase; }

.site-nav ul { display: flex; align-items: center; gap: 1.75rem; list-style: none; }
.site-nav a { color: var(--text); font-size: .95rem; letter-spacing: .03em; padding-block: .4rem; }
.site-nav a:hover, .site-nav a.active { color: var(--gold); }
.site-nav a.active { border-bottom: 1px solid var(--gold); }
.lang-switch a { color: var(--gold); border: 1px solid rgba(194,127,60,.5); border-radius: 2px; padding: .25rem .7rem; }
.lang-switch a:hover { background: var(--gold); color: var(--ink); }

.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: .5rem; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--gold); margin: 5px 0; transition: .2s; }

@media (max-width: 820px) {
  .nav-toggle { display: block; }
  .site-nav { display: none; position: absolute; inset-inline: 0; top: 100%; background: var(--ink-soft); border-bottom: 1px solid rgba(194,127,60,.25); }
  .site-nav.open { display: block; }
  .site-nav ul { flex-direction: column; gap: 0; padding: .5rem 0; }
  .site-nav li { width: 100%; text-align: center; }
  .site-nav a { display: block; padding: .8rem; }
  .lang-switch a { display: inline-block; margin-block: .6rem; }
}

/* ---------- Hero (crossfade slideshow, per original Vegas behavior) ---------- */
.hero {
  position: relative;
  min-height: calc(100vh - 72px);
  display: grid; place-items: center; text-align: center;
  overflow: hidden;
  border-bottom: 1px solid rgba(194,127,60,.25);
}
.hero-slides, .hero-slides .slide { position: absolute; inset: 0; }
.hero-slides .slide {
  background-size: cover; background-position: center;
  opacity: 0;
  transition: opacity 3s ease-in-out; /* original transitionDuration: 3000 */
}
.hero-slides .slide.on { opacity: 1; }
.hero-veil { position: absolute; inset: 0; background: linear-gradient(rgba(18,18,18,.5), rgba(18,18,18,.8)); }
.hero-inner { position: relative; z-index: 1; }

/* Circular play button (original: fa-play-circle) */
.play-btn {
  display: inline-flex; flex-direction: column; align-items: center; gap: .9rem;
  background: none; border: 0; cursor: pointer; color: var(--gold);
  margin-top: 1.2rem;
}
.play-circle { width: 88px; height: 88px; transition: transform .25s ease, color .25s ease; }
.play-btn:hover .play-circle { transform: scale(1.08); color: var(--gold-soft); }
.play-btn:hover .play-label { color: var(--gold-soft); }
.play-label { color: var(--text); font-size: 1rem; letter-spacing: .05em; transition: color .25s; }
@media (prefers-reduced-motion: no-preference) {
  .play-circle { animation: playpulse 2.4s ease-in-out infinite; }
  @keyframes playpulse {
    0%, 100% { filter: drop-shadow(0 0 0 rgba(194,127,60,.0)); }
    50%      { filter: drop-shadow(0 0 14px rgba(194,127,60,.55)); }
  }
}
.hero h1 {
  font-size: clamp(2.4rem, 6vw, 4.2rem);
  color: var(--gold);
  letter-spacing: .06em;
  text-transform: uppercase;
}
html[dir="rtl"] .hero h1 { text-transform: none; letter-spacing: .02em; }
.hero-sub { max-width: 560px; margin: 1.2rem auto 2rem; font-size: 1.1rem; color: var(--text); }

.btn {
  display: inline-block; cursor: pointer; border: 0;
  font-family: var(--body); font-size: 1rem; letter-spacing: .05em;
  padding: .8rem 2rem; border-radius: 2px; transition: .2s;
}
.btn-gold { background: var(--gold); color: var(--ink); }
.btn-gold:hover { background: var(--gold-soft); color: var(--ink); }

/* ---------- Home cards ---------- */
.home-cards {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem;
  padding-block: 3rem;
}
.card {
  position: relative; min-height: 320px; border-radius: 3px; overflow: hidden;
  background-size: cover; background-position: center; display: block;
}
.card-overlay {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: .6rem;
  background: rgba(18,18,18,.45); transition: background .25s;
}
.card:hover .card-overlay { background: rgba(18,18,18,.65); }
.card h2 { color: #fff; font-size: 1.7rem; }
.card-more {
  color: var(--gold); font-size: .85rem; letter-spacing: .2em; text-transform: uppercase;
  border-bottom: 1px solid var(--gold); padding-bottom: 2px;
  opacity: 0; transform: translateY(6px); transition: .25s;
}
.card:hover .card-more { opacity: 1; transform: none; }
@media (max-width: 820px) { .home-cards { grid-template-columns: 1fr; } .card { min-height: 220px; } }

/* ---------- Gallery ---------- */
.gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: .6rem; padding-bottom: 3.5rem; }
.gallery img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 3px; }
@media (max-width: 820px) { .gallery { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Content pages: intro-effect-fadeout (per original theme) ---------- */
.page-hero {
  position: relative;
  height: calc(100vh - 72px);
  display: grid; place-items: center; text-align: center;
  overflow: hidden;
}
.page-hero-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: top center;
  transition: transform .6s ease, opacity .6s ease;
  will-change: transform;
}
.page-hero-veil { position: absolute; inset: 0; background: rgba(0,0,0,.4); } /* original .bg-img span */
.page-hero-title { position: relative; z-index: 1; padding: 0 1.25rem; }
.page-hero-title h1 { font-size: clamp(2.4rem, 6vw, 4rem); color: #fff; text-shadow: 0 2px 18px rgba(0,0,0,.5); }
/* reveal state: bg slides up + dims, like .modify .bg-img { translateY(-25%) } */
body.revealed .page-hero-bg { transform: translateY(-12%) scale(1.04); opacity: .35; }

.section-nav { margin-top: 1.4rem; display: flex; justify-content: center; flex-wrap: wrap; gap: 1.5rem; }
.section-nav a { color: #fff; font-size: 1rem; text-shadow: 0 1px 8px rgba(0,0,0,.6); }
.section-nav a:hover { color: var(--gold); }

/* Scroll-down trigger (original button.trigger, bouncing arrow + label) */
.trigger {
  position: absolute; bottom: 40px; left: 50%; transform: translateX(-50%);
  z-index: 2; background: none; border: 0; cursor: pointer;
  color: #fff; font-size: 2rem; line-height: 1;
  transition: opacity .3s .3s;
}
.trigger::before {
  content: attr(data-info);
  position: absolute; bottom: 110%; left: 50%; transform: translateX(-50%);
  white-space: nowrap; font-size: .85rem; letter-spacing: .12em; color: #fff;
}
@media (prefers-reduced-motion: no-preference) {
  .trigger span { display: block; animation: bounce 2s infinite; }
  @keyframes bounce {
    0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
    40% { transform: translateY(-14px); }
    60% { transform: translateY(-7px); }
  }
}
body.revealed .trigger { opacity: 0; pointer-events: none; transition-delay: 0s; }

/* Content rises into view on reveal (original .content > div translateY(350px)) */
.page-body { opacity: 0; transform: translateY(120px); transition: opacity .6s ease, transform .6s ease; }
body.revealed .page-body { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .page-body { opacity: 1; transform: none; }
  body.revealed .page-hero-bg { transform: none; opacity: 1; }
}

/* Full-width image bands between sections (original .imgSep) */
.img-sep {
  height: clamp(170px, 26vh, 300px);
  background-size: cover; background-position: center;
  border-block: 1px solid rgba(194,127,60,.25);
}
@media (min-width: 821px) { .img-sep { background-attachment: fixed; } }

.content-section { scroll-margin-top: 90px; }

.content-section { padding: 3.5rem 0; }
.content-section.alt { background: var(--ink-soft); }
.content-section h2 {
  font-size: 2rem; color: var(--gold); margin-bottom: 1.4rem;
  padding-bottom: .6rem; border-bottom: 1px solid rgba(194,127,60,.35);
  display: inline-block;
}
.content-section p { margin-bottom: 1.1rem; color: var(--text); }
.content-section .lead { font-size: 1.15rem; color: var(--gold-soft); }
blockquote {
  border-inline-start: 3px solid var(--gold);
  padding-inline-start: 1.2rem; margin: 1.5rem 0;
  font-family: var(--display); font-size: 1.1rem; color: var(--text-dim);
}

.embed { position: relative; aspect-ratio: 16/9; margin: 1.5rem 0; }
.embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; border-radius: 3px; }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 3rem; }
@media (max-width: 820px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-details h2, .contact-form h2 { font-size: 1.6rem; color: var(--gold); margin-bottom: 1rem; }
.contact-form label { display: block; margin-bottom: 1rem; font-size: .9rem; color: var(--text-dim); }
.contact-form input, .contact-form textarea {
  display: block; width: 100%; margin-top: .3rem;
  background: var(--ink-soft); border: 1px solid rgba(194,127,60,.35); border-radius: 2px;
  color: var(--text); font-family: var(--body); font-size: 1rem; padding: .7rem .9rem;
}
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--gold); outline: none; }
.hp { position: absolute !important; inset-inline-start: -9999px; height: 0; opacity: 0; }
.form-msg { padding: .8rem 1rem; border-radius: 2px; margin-bottom: 1rem; }
.form-msg.ok  { background: rgba(60, 140, 80, .18); border: 1px solid #3c8c50; }
.form-msg.err { background: rgba(240, 29, 79, .12); border: 1px solid var(--accent); }

.map iframe { display: block; width: 100%; height: 380px; border: 0; filter: grayscale(.3); }

/* ---------- Video modal ---------- */
.video-modal { position: fixed; inset: 0; z-index: 90; display: grid; place-items: center; }
.video-modal[hidden] { display: none; }
.video-modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.85); }
.video-modal-body { position: relative; width: min(920px, 92vw); }
.video-frame { aspect-ratio: 16/9; background: #000; }
.video-frame iframe { width: 100%; height: 100%; border: 0; }
.video-close {
  position: absolute; top: -2.6rem; inset-inline-end: 0;
  background: none; border: 0; color: var(--gold); font-size: 2rem; cursor: pointer;
}
.video-cta { margin-top: 1rem; }

/* ---------- Footer ---------- */
.site-footer { border-top: 1px solid rgba(194,127,60,.25); margin-top: 2rem; background: var(--ink-soft); }
.footer-grid { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 2rem; padding-block: 2.5rem 1rem; }
.footer-contact h4 { color: var(--gold); margin-bottom: .6rem; font-size: 1.1rem; }
.footer-contact p, .footer-contact a { color: var(--text-dim); font-size: .95rem; }
.footer-contact a:hover { color: var(--gold); }
.footer-social { display: flex; gap: 1.2rem; align-items: flex-start; }
.footer-social a { color: var(--text-dim); font-size: .9rem; letter-spacing: .1em; text-transform: uppercase; }
.footer-social a:hover { color: var(--gold); }
.copyright { padding-block: 1rem 1.6rem; }
.copyright p { color: var(--text-dim); font-size: .85rem; }

/* ---------- Brand logo & social icons (from original theme) ---------- */
.brand-logo { height: 52px; width: auto; display: block; }
.footer-social a img { height: 26px; width: 26px; opacity: .7; transition: opacity .2s; }
.footer-social a:hover img { opacity: 1; }
