
/* ---------- TOKENS ---------- */
:root{
  /* color */
  --bg:        #0c0b08;   /* hlubší, čistější — starlink-like clean black */
  --bg-soft:   #14130e;
  --bg-card:   #15140f;
  --line:      rgba(232, 222, 200, 0.07);
  --line-strong: rgba(232, 222, 200, 0.18);

  --ink:       #ece3cd;   /* teplá slonová kost */
  --ink-soft:  #c8bfa8;
  --ink-mute:  #8a8270;
  --brass:     #c8a96a;   /* tlumená mosaz */
  --brass-deep:#a98a4d;

  /* type */
  --serif: "Cormorant Garamond", "EB Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  /* layout */
  --container: 1240px;
  --gutter: clamp(24px, 5vw, 64px);
  --section-y: clamp(64px, 8vw, 120px);
  --radius: 2px;

  /* motion */
  --ease: cubic-bezier(.2, .7, .2, 1);
}

/* ---------- RESET ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
input,select,textarea{ font:inherit; color:inherit; }
::selection{ background:var(--brass); color:#15140f; }

/* ---------- LAYOUT ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
}
.container.narrow{ max-width:1060px; }
.section{ padding:var(--section-y) 0; position:relative; }
.section + .section{ border-top:1px solid var(--line); }

/* ---------- TYPE ---------- */
h1,h2,h3{
  font-family:var(--serif);
  font-weight:400;
  letter-spacing:-0.005em;
  line-height:1.05;
  margin:0 0 .4em;
  color:var(--ink);
}
h1 em, h2 em, h3 em{
  font-style:italic;
  color:var(--brass);
  font-weight:400;
}
h2{ font-size:clamp(36px, 5.2vw, 72px); line-height:1.04; letter-spacing:-0.015em; }
h3{ font-size:clamp(22px, 2vw, 28px); line-height:1.2; }
p{ margin:0 0 1em; color:var(--ink-soft); line-height:1.7; max-width:62ch; }
.lede{ font-size:clamp(16px, 1.3vw, 19px); line-height:1.75; color:var(--ink-soft); max-width:60ch; margin-top:32px; }
.lede.center{ margin-left:auto; margin-right:auto; }
.eyebrow{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--brass);
  margin:0 0 28px;
  font-weight:500;
}
.eyebrow.center{ text-align:center; }

/* ---------- BUTTONS ---------- */
.btn{
  --pad-y: 14px;
  --pad-x: 26px;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:var(--pad-y) var(--pad-x);
  border:1px solid var(--line-strong);
  color:var(--ink);
  font-family:var(--sans);
  font-size:13px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  border-radius:var(--radius);
  transition:background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease), transform .35s var(--ease);
}
.btn-sm{ --pad-y:10px; --pad-x:18px; font-size:11px; }
.btn-primary{
  background:var(--brass);
  color:#15140f;
  border-color:var(--brass);
}
.btn-primary:hover{ background:var(--brass-deep); border-color:var(--brass-deep); }
.btn-ghost{ background:transparent; }
.btn-ghost:hover{ border-color:var(--brass); color:var(--brass); }
.btn-link{
  border:0; padding:14px 0;
  color:var(--ink); letter-spacing:0.18em;
}
.btn-link:hover{ color:var(--brass); }
.link-arrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; letter-spacing:0.22em; text-transform:uppercase;
  color:var(--ink); padding:6px 0;
  border-bottom:1px solid var(--line-strong);
  transition:color .3s var(--ease), border-color .3s var(--ease);
}
.link-arrow::after{ content:"→"; transition:transform .3s var(--ease); }
.link-arrow:hover{ color:var(--brass); border-color:var(--brass); }
.link-arrow:hover::after{ transform:translateX(4px); }

/* ---------- HEADER ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(21,20,15,.72);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; height:78px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{
  width:36px; height:36px;
  display:grid; place-items:center;
  border:1px solid var(--brass);
  color:var(--brass);
  font-family:var(--serif); font-size:20px;
  border-radius:var(--radius);
}
.brand-word{
  font-family:var(--sans);
  letter-spacing:0.32em;
  font-size:14px;
  font-weight:500;
}
.primary-nav{ display:flex; gap:28px; align-items:center; flex-wrap:nowrap; }
.primary-nav a{
  font-size:12px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--ink-soft);
  transition:color .3s var(--ease);
  padding:8px 0;
  white-space:nowrap;
}
@media (max-width: 1280px){
  .primary-nav{ gap:22px; }
  .primary-nav a{ font-size:11.5px; letter-spacing:0.12em; }
}
.primary-nav a:hover{ color:var(--brass); }
.header-tools{ display:flex; align-items:center; gap:18px; }
.lang-switch{
  display:flex; gap:2px;
  border:1px solid var(--line);
  padding:2px;
  border-radius:var(--radius);
}
.lang-switch button{
  padding:6px 10px;
  font-size:11px;
  letter-spacing:0.2em;
  color:var(--ink-mute);
  border-radius:var(--radius);
}
.lang-switch button.is-active{ color:var(--ink); background:rgba(232,222,200,.06); }
.lang-switch button:disabled{ cursor:not-allowed; opacity:.45; }

.nav-toggle{ display:none; width:40px; height:40px; position:relative; }
.nav-toggle span{
  position:absolute; left:8px; right:8px; height:1px; background:var(--ink);
  transition:transform .3s var(--ease), opacity .3s var(--ease), top .3s var(--ease);
}
.nav-toggle span:nth-child(1){ top:14px; }
.nav-toggle span:nth-child(2){ top:20px; }
.nav-toggle span:nth-child(3){ top:26px; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ top:20px; transform:rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ top:20px; transform:rotate(-45deg); }

.mobile-nav{
  display:none;
  flex-direction:column;
  padding:18px var(--gutter) 28px;
  border-top:1px solid var(--line);
  background:var(--bg);
}
.mobile-nav:not([hidden]){ display:flex; }
.mobile-nav a{
  padding:14px 0;
  font-size:14px; letter-spacing:0.18em; text-transform:uppercase;
  border-bottom:1px solid var(--line);
  color:var(--ink-soft);
}
.mobile-nav .btn{ margin-top:24px; align-self:stretch; justify-content:center; color:#fff; }

/* ---------- HERO ---------- */
.hero{
  position:relative;
  min-height:min(96vh, 960px);
  display:flex; align-items:flex-end;
  overflow:hidden;
  isolation:isolate;
  padding-bottom:clamp(80px, 10vw, 160px);
}
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-bg{
  position:absolute; inset:0;
  background-color:#1a1c1f;
}
.hero-figure{
  position:absolute;
  right:4%;
  top:0;
  bottom:0;
  width:auto;
  height:100%;
  filter:saturate(1.0) contrast(1.05) brightness(1.05);
}
.hero-vignette{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(15,14,10,.20) 0%, rgba(15,14,10,0) 25%, rgba(15,14,10,0) 65%, rgba(15,14,10,.80) 100%),
    linear-gradient(90deg, rgba(15,14,10,.92) 0%, rgba(15,14,10,.78) 25%, rgba(15,14,10,.35) 45%, rgba(15,14,10,0) 62%);
}
@keyframes heroBreath{
  from{ transform:scale(1.00); }
  to  { transform:scale(1.00); }
}
.hero-inner{ position:relative; z-index:2; max-width:800px; margin-left:clamp(16px, 5vw, 80px); margin-right:auto; }
.hero-title{
  font-family:var(--serif);
  font-size:clamp(48px, 8vw, 128px);
  line-height:.98;
  letter-spacing:-0.015em;
  margin:.1em 0 .35em;
  color:var(--ink);
}
.hero-title em{ color:var(--brass); font-style:italic; }
.hero-lede{
  max-width:540px;
  font-size:clamp(16px, 1.25vw, 19px);
  line-height:1.75;
  color:var(--ink-soft);
  margin-bottom:56px;
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:20px; align-items:center; }

.scroll-cue{
  position:relative;
  display:inline-block;
  vertical-align:middle;
  width:2px; height:1.4em;
  background:var(--line-strong);
  overflow:hidden;
  margin-left:12px;
}
.scroll-cue span{
  position:absolute; left:0; top:0; width:100%; height:30%; transform:translateY(-100%);
  background:var(--brass);
  animation:cue 2.4s ease-in-out infinite;
}
@keyframes cue{
  0%  { transform:translateY(-100%); }
  100%{ transform:translateY(333%); }
}

/* ---------- STATEMENT ---------- */
.section-statement{ text-align:center; padding:clamp(60px, 7vw, 100px) 0; }
.statement{
  font-size:clamp(30px, 4vw, 58px);
  line-height:1.2;
  margin-bottom:.8em;
  margin-left:auto; margin-right:auto;
}
.statement em{ color:var(--brass); font-style:italic; }
.statement-sub{
  max-width:54ch; margin:0 auto;
  color:var(--ink-soft);
  font-size:clamp(15px, 1.15vw, 17px);
  line-height:1.75;
}

/* ---------- SECTION HEAD ---------- */
.section-head{ margin-bottom:88px; }
.section-head.center{ text-align:center; }
.section-head-split{
  display:flex; align-items:flex-end; justify-content:space-between; gap:32px;
}
.section-head-note{
  color:var(--ink-mute); font-size:13px; letter-spacing:0.18em;
  text-transform:uppercase; max-width:280px; text-align:right; margin:0;
}
.section-lede{ max-width:680px; margin:0 auto; color:var(--ink-soft); }

/* ---------- COLLECTIONS ---------- */
.collections-grid{
  display:grid; grid-template-columns:repeat(2, 1fr);
  gap:clamp(32px, 4vw, 64px);
  max-width:900px;
  margin-inline: auto;
}
.collection{ display:flex; flex-direction:column; }
.collection-media{
  position:relative; display:block;
  aspect-ratio: 4 / 5;
  overflow:hidden;
  background:#0f0e0a;
  border:1px solid var(--line);
}
.collection-image{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  background-color:#1a1812;
  transition:transform 1.2s var(--ease), filter .6s var(--ease);
  filter:saturate(.9);
}
.collection-image::after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(80% 80% at 50% 50%, transparent 30%, rgba(21,20,15,.5) 100%),
    linear-gradient(180deg, rgba(21,20,15,0) 50%, rgba(21,20,15,.85) 100%);
}
.collection-media:hover .collection-image{ transform:scale(1.04); filter:saturate(1); }
.collection-num{
  position:absolute; top:18px; left:20px; z-index:1;
  font-family:var(--serif); font-size:14px; letter-spacing:0.2em;
  color:var(--brass);
}
.collection-body{ padding:32px 0 0; }
.collection-body h3{ margin-bottom:.4em; }
.collection-body p{ font-size:15px; color:var(--ink-soft); margin-bottom:18px; }

/* ---------- FEATURED WORKS ---------- */
.works-grid{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:clamp(48px, 6vw, 96px) clamp(32px, 4vw, 64px);
}
.work{ display:flex; flex-direction:column; }
.work-media{
  position:relative; aspect-ratio: 4 / 5;
  overflow:hidden;
  background:
    radial-gradient(ellipse at 50% 92%, rgba(200,169,106,.11) 0%, transparent 55%),
    linear-gradient(170deg, #18160d 0%, #0e0d09 55%, #0b0a07 100%);
  border:1px solid rgba(200,169,106,.18);
  box-shadow: 0 0 0 1px rgba(200,169,106,.06);
}
.work-image{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transition:transform 1.4s var(--ease);
}
.work-image::after{
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at center, transparent 45%, rgba(9,8,6,.40) 100%),
    linear-gradient(to bottom, rgba(9,8,6,.28) 0%, transparent 20%, transparent 60%, rgba(9,8,6,.65) 100%);
  pointer-events:none;
}
.work:hover .work-image{ transform:scale(1.025); }
.work-media .work-tag{
  position:absolute; top:16px; right:16px;
  font-size:10px; letter-spacing:0.28em; text-transform:uppercase;
  padding:6px 10px;
  background:rgba(21,20,15,.7);
  color:var(--brass);
  border:1px solid var(--brass);
}
.work-meta{ padding:24px 4px 0; }
.work-meta h3{ font-size:clamp(22px, 1.8vw, 28px); margin-bottom:6px; }
.work-line{ font-size:13px; letter-spacing:0.06em; color:var(--ink-mute); margin-bottom:10px; }
.work-price{
  font-family:var(--serif); font-style:italic;
  color:var(--brass); margin-bottom:18px;
  font-size:17px;
}
.featured-note{
  margin-top:80px; text-align:center;
  color:var(--ink-mute); font-size:13px;
  letter-spacing:0.18em; text-transform:uppercase;
  max-width:640px; margin-left:auto; margin-right:auto;
}

/* ---------- ABOUT ---------- */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px, 6vw, 96px);
  align-items:center;
}
.about-media{
  position:relative; aspect-ratio: 4 / 5;
  border:1px solid var(--line); overflow:hidden;
  background:#0f0e0a;
}
.about-image{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  background-color:#1a1812;
}
.section-about{ padding:clamp(24px, 2.5vw, 40px) 0; }
.section-about .split{ align-items:stretch; gap:clamp(32px, 4vw, 64px); }
.about-media--logo{ aspect-ratio:unset !important; }
.about-media--logo{
  aspect-ratio: 1;
  position:relative;
  display:flex; align-items:center; justify-content:center;
  background: radial-gradient(ellipse at center, rgba(200,169,106,.07) 0%, transparent 70%);
  border:1px solid rgba(200,169,106,.15);
}
.about-media--logo .about-logo-mark{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%, -50%);
}
.about-logo-mark{
  width: 55%;
  max-width: 260px;
  opacity: 0.90;
  filter: drop-shadow(0 0 40px rgba(200,169,106,.35));
  animation: about-mark-pulse 4s ease-in-out infinite;
}
@keyframes about-mark-pulse {
  0%,100% { filter: drop-shadow(0 0 28px rgba(200,169,106,.28)); }
  50%      { filter: drop-shadow(0 0 56px rgba(200,169,106,.55)); }
}
.about-body h2{ margin-bottom:.4em; }
.about-list{ list-style:none; padding:0; margin:24px auto 0; max-width:520px; }
.about-list li{
  padding:16px 0;
  border-top:1px solid var(--line);
  color:var(--ink-soft);
  font-size:15px;
  display:flex; gap:12px; align-items:baseline;
}
.about-list li::before{
  content:"—";
  color:var(--brass);
  font-family:var(--serif);
}
.about-list li:last-child{ border-bottom:1px solid var(--line); }

/* ---------- TRADE ---------- */
.section-trade{ background:var(--bg-soft); }
.trade-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:clamp(16px, 2vw, 32px);
  margin-top:60px;
}
.trade-card{
  padding:36px 28px;
  border:1px solid var(--line);
  background:rgba(232,222,200,.015);
  transition:border-color .4s var(--ease), background .4s var(--ease), transform .4s var(--ease);
}
.trade-card:hover{
  border-color:var(--brass);
  background:rgba(200,169,106,.04);
}
.trade-num{
  font-family:var(--serif);
  font-size:18px;
  color:var(--brass);
  letter-spacing:0.18em;
  margin-bottom:18px;
}
.trade-card h3{ font-size:21px; margin-bottom:10px; }
.trade-card p{ font-size:14px; color:var(--ink-soft); margin:0; }

/* ---------- CONTACT ---------- */
.section-contact{ padding-bottom:clamp(60px, 7vw, 100px); }
.section-contact .split{ align-items:flex-start; }
.contact-intro h2{ margin-bottom:.5em; }
.contact-list{ list-style:none; padding:0; margin:36px 0 0; }
.contact-list li{
  display:flex; gap:24px; align-items:baseline;
  padding:16px 0;
  border-top:1px solid var(--line);
  font-size:15px;
}
.contact-list li:last-child{ border-bottom:1px solid var(--line); }
.contact-list li > span{
  flex:0 0 110px;
  font-size:11px; letter-spacing:0.24em; text-transform:uppercase;
  color:var(--ink-mute);
}
.contact-list li a{ color:var(--ink); border-bottom:1px solid var(--line-strong); }
.contact-list li a:hover{ color:var(--brass); border-color:var(--brass); }

.contact-form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px 24px;
  padding:clamp(28px, 3vw, 44px);
  border:1px solid var(--line);
  background:rgba(232,222,200,.015);
  position:relative;
}
.contact-form .field.full,
.contact-form .form-foot.full{ grid-column:1 / -1; }
.field{ display:flex; flex-direction:column; gap:10px; }
.field label{
  font-size:11px; letter-spacing:0.24em; text-transform:uppercase;
  color:var(--ink-mute);
}
.field input,
.field select,
.field textarea{
  width:100%;
  padding:14px 0;
  background:transparent;
  border:0;
  border-bottom:1px solid var(--line-strong);
  color:var(--ink);
  border-radius:0;
  font-size:15px;
  transition:border-color .3s var(--ease);
}
.field textarea{ resize:vertical; min-height:120px; padding:14px 0; }
.field select{
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%23c8a96a' stroke-width='1.4' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 4px center;
  padding-right:28px;
}
.field select option{ background:var(--bg-soft); color:var(--ink); }
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:none;
  border-bottom-color:var(--brass);
}
.field input::placeholder,
.field textarea::placeholder{ color:var(--ink-mute); }

.form-foot{
  display:flex; justify-content:space-between; align-items:center; gap:24px;
  margin-top:8px;
}
.form-note{
  font-size:12px; color:var(--ink-mute); margin:0;
  max-width:380px; line-height:1.5;
}

.hp-field{ position:absolute; left:-9999px; opacity:0; pointer-events:none; }

.btn-spinner{
  width:14px; height:14px; border-radius:50%;
  border:1.5px solid rgba(21,20,15,.25);
  border-top-color:#15140f;
  display:none;
  animation:spin .8s linear infinite;
}
.btn.is-loading .btn-label{ opacity:.6; }
.btn.is-loading .btn-spinner{ display:inline-block; }
@keyframes spin{ to{ transform:rotate(360deg); } }

.form-status{
  grid-column:1 / -1;
  margin-top:8px;
  padding:0;
  font-size:13px;
  letter-spacing:0.06em;
  min-height:1em;
}
.form-status.is-success{ color:var(--brass); }
.form-status.is-error{ color:#d98b78; }

/* ---------- FOOTER ---------- */
.site-footer{
  padding:80px 0 32px;
  border-top:1px solid var(--line);
  background:#100f0b;
  color:var(--ink-soft);
}
.footer-inner{
  display:grid;
  grid-template-columns: 1.1fr 2fr;
  gap:60px;
  padding-bottom:60px;
  border-bottom:1px solid var(--line);
}
.footer-brand .brand-word{
  font-size:18px; letter-spacing:0.36em;
  display:block; margin-bottom:16px;
}
.footer-brand p{ font-size:14px; color:var(--ink-mute); }
.footer-nav{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:32px;
}
.footer-nav .footer-h{
  font-size:11px; letter-spacing:0.24em; text-transform:uppercase;
  color:var(--brass);
  margin:0 0 16px;
}
.footer-nav a, .footer-nav span{
  display:block;
  padding:6px 0;
  font-size:14px;
  color:var(--ink-soft);
}
.footer-nav a:hover{ color:var(--brass); }
.footer-bottom{
  padding-top:24px;
  display:flex; justify-content:space-between; gap:16px;
  color:var(--ink-mute);
  font-size:12px; letter-spacing:0.06em;
}

/* ---------- REVEAL (jemné) ---------- */
.reveal{ opacity:0; transform:translateY(14px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }

/* ---------- RESPONSIVE ---------- */
/* TABLET: 700-1100 — 2 sloupce kolekce/vybraná/galerie, hamburger nav */
@media (max-width: 1100px){
  .primary-nav, .header-tools .btn, .lang-switch{ display:none; }
  .nav-toggle{ display:block; }
  .hero{ min-height:82vh; }
  .hero-figure{ opacity:0.45; }
  .section-head-split{ flex-direction:column; align-items:flex-start; }
  .section-head-note{ text-align:left; max-width:none; }
  .trade-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-inner{ grid-template-columns:1fr; gap:48px; }
  .footer-nav{ grid-template-columns:repeat(3, 1fr); }
  .contact-form{ grid-template-columns:1fr; }
  .form-foot{ flex-direction:column; align-items:flex-start; }
}
@media (min-width: 701px) and (max-width: 1100px){
  .collections-grid{ grid-template-columns:repeat(2, 1fr); gap:40px; }
  .works-grid{ grid-template-columns:repeat(2, 1fr); gap:56px 40px; }
  .works-grid .work:nth-child(3){ grid-column: span 2; max-width:520px; margin:0 auto; }
  .gallery-grid{ grid-template-columns:repeat(2, 1fr); gap:40px; }
  /* 12-item gallery: no special span on 3rd child */
  .brief-grid{ grid-template-columns:repeat(2, 1fr); gap:28px; }
  .split{ grid-template-columns:1fr; gap:56px; }
  .hero-figure{ right:0; }
  .hero-vignette{
    background:
      linear-gradient(180deg, rgba(15,14,10,.25) 0%, rgba(15,14,10,0) 20%, rgba(15,14,10,0) 60%, rgba(15,14,10,.90) 100%),
      linear-gradient(90deg, rgba(15,14,10,.96) 0%, rgba(15,14,10,.90) 30%, rgba(15,14,10,.60) 52%, rgba(15,14,10,0) 72%);
  }
}
@media (max-width: 800px){
  .hero-cta{ flex-direction:column; align-items:stretch; gap:14px; max-width:320px; }
  .hero-cta .btn-primary{ justify-content:center; }
  .hero-cta .btn-link{ text-align:center; justify-content:center; padding:12px 0; border-bottom:1px solid var(--line-strong); }
}
@media (max-width: 700px){
  .collections-grid{ grid-template-columns:1fr; gap:56px; }
  .works-grid{ grid-template-columns:1fr; gap:56px; }
  .split{ grid-template-columns:1fr; gap:48px; }
  .brief-grid{ grid-template-columns:1fr; gap:20px; }
}
@media (max-width: 560px){
  .header-inner{ height:64px; }
  .brand-word{ font-size:13px; letter-spacing:0.28em; }
  .brand-mark{ width:32px; height:32px; font-size:18px; }
  .hero-title{ font-size:clamp(44px, 12vw, 72px); }
  .footer-nav{ grid-template-columns:1fr 1fr; }
  .footer-bottom{ flex-direction:column; }
  .contact-list li{ flex-direction:column; gap:6px; }
  .contact-list li > span{ flex:initial; }
  .trade-grid{ grid-template-columns:1fr; }
}

/* ---------- COOKIE BANNER ---------- */
.cookie-banner{
  position:fixed; left:16px; right:16px; bottom:16px; z-index:200;
  background:rgba(15,14,10,.96);
  border:1px solid rgba(200,169,106,.35);
  border-radius:6px;
  padding:18px 22px;
  box-shadow:0 12px 40px rgba(0,0,0,.6);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  max-width:640px; margin:0 auto;
}
.cookie-inner{
  display:flex; gap:18px; align-items:center;
  flex-wrap:wrap;
}
.cookie-inner p{
  flex:1 1 320px;
  font-size:13px; line-height:1.55;
  color:var(--ink-soft); margin:0;
}
.cookie-inner p a{ color:var(--brass); text-decoration:underline; text-underline-offset:3px; }
.btn-sm{ padding:10px 18px; font-size:11px; letter-spacing:0.18em; }
@media (max-width: 480px){
  .cookie-inner{ flex-direction:column; align-items:stretch; }
  .cookie-inner p{ flex:1 1 auto; }
  .btn-sm{ width:100%; }
}

/* ---------- FOOTER LEGAL ---------- */
.footer-legal{
  display:flex; gap:24px; flex-wrap:wrap;
}
.footer-legal a{
  font-size:12px; color:var(--ink-mute);
  text-decoration:none; transition:color .2s;
}
.footer-legal a:hover{ color:var(--brass); }
@media (max-width: 560px){
  .footer-legal{ gap:14px; }
  .footer-legal a{ font-size:11px; }
}

/* ---------- DROBNÉ RESPONZIVNÍ OPRAVY ---------- */
@media (max-width: 380px){
  .container{ padding:0 16px; }
  .hero-title{ font-size:42px; line-height:1.05; }
  .hero-text{ font-size:15px; }
  .btn{ padding:14px 22px; font-size:11px; }
  .section-head h2{ font-size:32px; }
}

/* ---------- FILM — procházka dílem ---------- */
.section-film{ background:#0a0907; }
.film-frame{
  position:relative;
  max-width:1320px; margin:0 auto;
  aspect-ratio: 16 / 9;
  background:#000;
  border:1px solid var(--line);
  overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,0.6);
}
.film-video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  display:block;
}
.film-corner{
  position:absolute; left:24px; bottom:22px;
  display:flex; flex-direction:column; gap:4px;
  padding:14px 18px;
  background:rgba(12, 11, 8, 0.55);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-left:1px solid var(--brass);
}
.film-corner-label{
  font-family:var(--sans); font-size:10px;
  letter-spacing:0.32em; text-transform:uppercase;
  color:var(--brass);
}
.film-corner-meta{
  font-family:var(--serif); font-style:italic;
  font-size:14px; color:var(--ink-soft);
}
@media (max-width: 700px){
  .film-corner{ left:14px; bottom:14px; padding:10px 14px; }
  .film-corner-meta{ font-size:12px; }
}

/* ---------- GALERIE ---------- */
.section-gallery{
  background:var(--bg);
}
#galerie .container{ max-width:1320px; }
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:56px;
  margin-top:72px;
}
.gallery-item{
  margin:0; padding:0;
  display:flex; flex-direction:column;
  gap:14px;
  position:relative;
}
.gallery-item > button{
  background:none; border:none; padding:0; margin:0;
  cursor:pointer; overflow:hidden;
  position:relative;
  border-radius:2px;
  display:block; width:100%;
}
.gallery-item img{
  width:100%; height:100%; aspect-ratio:3/4;
  object-fit:cover;
  display:block;
  transition:transform .6s ease, filter .4s ease;
  filter:brightness(.95);
}
.gallery-item:hover img,
.gallery-item:focus-within img{
  transform:scale(1.03);
  filter:brightness(1.08);
}
.gallery-item > button:focus-visible{
  outline:1px solid var(--brass);
  outline-offset:4px;
}
.gallery-item figcaption{
  display:flex; flex-direction:column; gap:4px;
  padding-top:4px;
  text-align:left;
}
.gallery-item .work-no{
  font-family:var(--sans); font-size:10px;
  letter-spacing:0.28em; text-transform:uppercase;
  color:var(--brass);
}
.gallery-item .work-name{
  font-family:var(--serif); font-style:italic;
  font-size:22px; color:var(--ink);
  line-height:1.2;
}
.gallery-item .work-tag{
  font-family:var(--sans); font-size:11px;
  letter-spacing:0.16em; text-transform:uppercase;
  color:var(--ink-mute);
}
/* ── Photo card backgrounds ── */
.gallery-item > button{
  background:
    radial-gradient(ellipse at 50% 90%, rgba(200,169,106,.07) 0%, transparent 60%),
    linear-gradient(170deg, #18160d 0%, #0e0d09 60%, #0c0b08 100%);
}
.gallery-item--360-main > button{
  background:
    radial-gradient(ellipse at 50% 85%, rgba(200,169,106,.13) 0%, transparent 55%),
    linear-gradient(170deg, #1e1b0f 0%, #131009 60%, #0c0b08 100%);
  box-shadow:inset 0 -1px 0 rgba(200,169,106,.15);
}
.gallery-item--360-main:hover > button,
.gallery-item--360-main:focus-within > button{
  box-shadow:
    inset 0 -1px 0 rgba(200,169,106,.25),
    0 12px 48px rgba(200,169,106,.07);
}

/* ── 360° pair: obě sochy vedle sebe, centrováno ── */
.gallery-360-pair{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  max-width:820px;
  margin:0 auto;
  width:100%;
}

/* ── 360° header divider ── */
.gallery-360-header{
  grid-column:1 / -1;
  display:flex; align-items:center; gap:20px;
  padding:40px 0 8px;
  border-top:1px solid var(--line);
  margin-top:24px;
}
.gallery-360-header .v360-label{
  font-family:var(--sans); font-size:10px;
  letter-spacing:0.3em; text-transform:uppercase;
  color:var(--brass); white-space:nowrap;
}
.gallery-360-header .v360-line{
  flex:1; height:1px; background:var(--line);
}

@media (max-width: 900px){
  .gallery-grid{ grid-template-columns:repeat(2, 1fr); gap:32px; }
  .gallery-item .work-name{ font-size:18px; }
}
@media (max-width: 560px){
  .gallery-grid{ grid-template-columns:1fr; gap:40px; }
}

/* ---------- BRIEF (Co lze zadat) ---------- */
.section-brief{ background:var(--bg-soft); }
.brief-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:32px;
  margin-top:56px;
}
.brief-card{
  padding:36px 28px;
  background:rgba(20,17,14,.6);
  border:1px solid rgba(184,146,90,.14);
  border-radius:2px;
  display:flex; flex-direction:column; gap:12px;
  position:relative;
  transition:border-color .3s, background .3s;
}
.brief-card:hover{
  border-color:rgba(184,146,90,.35);
  background:rgba(26,21,16,.7);
}
.brief-card-accent{
  background:linear-gradient(135deg, rgba(184,146,90,.08) 0%, rgba(20,17,14,.6) 100%);
  border-color:rgba(184,146,90,.3);
}
.brief-no{
  font-family:var(--sans); font-size:11px;
  letter-spacing:0.3em; color:var(--brass);
}
.brief-card h3{
  font-family:var(--serif); font-style:italic;
  font-size:24px; color:var(--ink); margin:0;
  font-weight:400;
}
.brief-card p{
  font-family:var(--sans); font-size:14px;
  line-height:1.6; color:var(--ink-soft); margin:0;
}
@media (max-width: 900px){
  .brief-grid{ grid-template-columns:repeat(2, 1fr); gap:16px; }
}
@media (max-width: 560px){
  .brief-grid{ grid-template-columns:1fr; }
  .brief-card{ padding:28px 22px; }
}

/* ---------- LIGHTBOX ---------- */
.lightbox[hidden]{ display:none !important; }
.lightbox{
  position:fixed; inset:0;
  background:rgba(8,7,6,.96);
  z-index:1000;
  display:flex; align-items:center; justify-content:center;
  animation:lbFade .3s ease;
}
@keyframes lbFade{
  from{ opacity:0; }
  to{ opacity:1; }
}
.lightbox-stage{
  max-width:90vw; max-height:85vh;
  display:flex; align-items:center; justify-content:center;
}
.lightbox-stage img{
  max-width:100%; max-height:85vh;
  object-fit:contain;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
}
.lightbox-close, .lightbox-prev, .lightbox-next{
  position:absolute;
  background:rgba(20,18,16,.8);
  border:1px solid rgba(184,146,90,.3);
  color:var(--ink);
  width:48px; height:48px;
  border-radius:50%;
  font-size:24px; line-height:1;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s;
  font-family:inherit;
}
.lightbox-close:hover, .lightbox-prev:hover, .lightbox-next:hover{
  background:var(--brass);
  border-color:var(--brass);
}
.lightbox-close{ top:24px; right:24px; font-size:28px; }
.lightbox-prev{ left:24px; top:50%; transform:translateY(-50%); font-size:32px; }
.lightbox-next{ right:24px; top:50%; transform:translateY(-50%); font-size:32px; }
.lightbox-meta{
  position:absolute; bottom:24px; left:50%; transform:translateX(-50%);
  color:var(--ink-mute);
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  font-family:var(--sans);
}
@media (max-width: 600px){
  .lightbox-close{ top:12px; right:12px; width:40px; height:40px; }
  .lightbox-prev{ left:8px; width:40px; height:40px; }
  .lightbox-next{ right:8px; width:40px; height:40px; }
}

/* ---------- PRINT / REDUCED MOTION ---------- */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
  html{ scroll-behavior:auto; }
}
