/* =========================================================================
   Classical Arts — Components
   ========================================================================= */

/* ---- Buttons ---- */
.btn {
  --btn-bg: var(--ink);
  --btn-fg: var(--paper);
  display: inline-flex; align-items: center; gap: var(--space-xs);
  padding: 0.85em 1.4em;
  font-family: var(--font-body);
  font-size: var(--step--1);
  font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase;
  background: var(--btn-bg); color: var(--btn-fg);
  border: 1px solid var(--btn-bg);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: transform var(--dur-fast) var(--ease-out),
              background-color var(--dur) var(--ease-out),
              color var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out);
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); text-decoration: none; }
.btn:active { transform: translateY(0); }
.btn .btn__arrow { transition: transform var(--dur) var(--ease-out); }
.btn:hover .btn__arrow { transform: translateX(4px); }

.btn--accent { --btn-bg: var(--brass-deep); --btn-fg: var(--paper); }
.on-lacquer .btn--accent { --btn-bg: var(--brass); --btn-fg: var(--lacquer); }

.btn--ghost {
  --btn-bg: transparent; --btn-fg: var(--fg);
  border-color: var(--line-strong);
}
.btn--ghost:hover { --btn-bg: var(--ink); --btn-fg: var(--paper); }
.on-lacquer .btn--ghost { --btn-fg: var(--on-lacquer); border-color: var(--line-on-dark); }
.on-lacquer .btn--ghost:hover { --btn-bg: var(--on-lacquer); --btn-fg: var(--lacquer); }

.link-arrow {
  display: inline-flex; align-items: center; gap: var(--space-xs);
  font-weight: 600; font-size: var(--step--1);
  letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--accent); text-decoration: none;
}
.link-arrow svg { transition: transform var(--dur) var(--ease-out); }
.link-arrow:hover svg { transform: translateX(4px); }
.link-arrow:hover { text-decoration: none; }

/* ---- Header / Nav ---- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in oklch, var(--paper) 86%, transparent);
  backdrop-filter: saturate(1.4) blur(10px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur) var(--ease-out),
              background-color var(--dur) var(--ease-out);
}
.site-header[data-scrolled="true"] { border-bottom-color: var(--line); }
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-lg);
  min-height: 4.75rem;
}
.brand { display: inline-flex; align-items: center; gap: var(--space-sm); text-decoration: none; flex-shrink: 0; }
.brand__mark { height: 2.5rem; width: auto; }
.brand__wordmark {
  font-family: var(--font-display); font-weight: 600;
  font-size: var(--step-1); letter-spacing: 0.01em; line-height: 1;
  color: var(--ink);
}
.brand__wordmark small {
  display: block; font-family: var(--font-body); font-weight: 600;
  font-size: 0.6rem; letter-spacing: var(--tracking-caps);
  text-transform: uppercase; color: var(--ink-3); margin-top: 0.25em;
}

.primary-nav { display: flex; align-items: center; gap: var(--space-lg); }
.primary-nav ul { display: flex; align-items: center; gap: clamp(0.75rem, 1.6vw, 1.6rem); list-style: none; padding: 0; }
.primary-nav a {
  font-size: var(--step--1); font-weight: 500; letter-spacing: 0.01em;
  text-decoration: none; color: var(--ink-2);
  padding-block: 0.4rem; position: relative;
  transition: color var(--dur) var(--ease-out);
}
.primary-nav a::after {
  content: ""; position: absolute; left: 0; bottom: 0;
  width: 100%; height: 1px; background: var(--brass-deep);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur) var(--ease-out);
}
.primary-nav a:hover, .primary-nav .current-menu-item > a { color: var(--ink); }
.primary-nav a:hover::after, .primary-nav .current-menu-item > a::after { transform: scaleX(1); }

/* Submenus */
.primary-nav .menu-item-has-children { position: relative; }
.primary-nav .sub-menu {
  position: absolute; top: 100%; left: -0.75rem; min-width: 13rem;
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius-md); box-shadow: var(--shadow-md);
  padding: var(--space-xs); display: grid; gap: 2px;
  opacity: 0; visibility: hidden; transform: translateY(6px);
  transition: opacity var(--dur) var(--ease-out), transform var(--dur) var(--ease-out), visibility var(--dur);
}
.primary-nav .menu-item-has-children:hover > .sub-menu,
.primary-nav .menu-item-has-children:focus-within > .sub-menu {
  opacity: 1; visibility: visible; transform: translateY(0);
}
.primary-nav .sub-menu a { display: block; padding: 0.5rem 0.75rem; border-radius: var(--radius-sm); }
.primary-nav .sub-menu a::after { display: none; }
.primary-nav .sub-menu a:hover { background: var(--paper-2); }

.nav-toggle { display: none; }

/* Mobile nav */
@media (max-width: 60rem) {
  .nav-toggle {
    display: inline-flex; flex-direction: column; gap: 5px;
    padding: 0.6rem; border: 1px solid var(--line-strong); border-radius: var(--radius-md);
  }
  .nav-toggle span { display: block; width: 22px; height: 2px; background: var(--ink); transition: transform var(--dur) var(--ease-out), opacity var(--dur-fast); }
  .nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  .primary-nav {
    position: fixed; inset: 4.75rem 0 auto 0;
    background: var(--paper); border-bottom: 1px solid var(--line);
    flex-direction: column; align-items: stretch; gap: 0;
    padding: var(--space-md) var(--gutter) var(--space-xl);
    box-shadow: var(--shadow-lg);
    transform: translateY(-130%);
    transition: transform var(--dur-slow) var(--ease-out);
    max-height: calc(100dvh - 4.75rem); overflow-y: auto;
  }
  .primary-nav[data-open="true"] { transform: translateY(0); }
  .primary-nav ul { flex-direction: column; align-items: stretch; gap: 0; width: 100%; }
  .primary-nav > ul > li { border-bottom: 1px solid var(--line); }
  .primary-nav a { display: block; padding: var(--space-md) 0; font-size: var(--step-1); }
  .primary-nav .sub-menu {
    position: static; opacity: 1; visibility: visible; transform: none;
    box-shadow: none; border: 0; padding: 0 0 var(--space-sm) var(--space-md);
    background: transparent;
  }
  .primary-nav .header-cta { margin-top: var(--space-md); }
}

/* ---- Hero ---- */
.hero { position: relative; isolation: isolate; overflow: hidden; }
.hero--lacquer { background: var(--lacquer); color: var(--on-lacquer); }
.hero__media { position: absolute; inset: 0; z-index: -2; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; }
.hero__media::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, oklch(0.185 0.012 50 / 0.55) 0%, oklch(0.185 0.012 50 / 0.78) 70%, oklch(0.185 0.012 50 / 0.92) 100%);
}
.hero__inner { position: relative; z-index: 1; padding-block: clamp(5rem, 12vh, 11rem); }
.hero__title { font-size: var(--step-5); max-width: 16ch; }
.hero__sub { font-size: var(--step-1); max-width: 46ch; color: var(--on-lacquer-2); line-height: 1.5; }
.hero__meta {
  display: flex; flex-wrap: wrap; gap: var(--space-lg) var(--space-2xl);
  margin-top: var(--space-2xl); padding-top: var(--space-lg);
  border-top: 1px solid var(--line-on-dark);
}
.hero__stat .display-num { font-size: var(--step-3); display: block; line-height: 1; }
.hero__stat span { font-size: var(--step--1); color: var(--on-lacquer-2); text-transform: uppercase; letter-spacing: 0.08em; }

/* ---- Section heading ---- */
.section-head { max-width: 60ch; margin-bottom: var(--space-2xl); }
.section-head--center { margin-inline: auto; text-align: center; }

/* ---- Feature row (alternating image/text) ---- */
.feature {
  display: grid; gap: clamp(2rem, 5vw, 4rem); align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width: 56rem) {
  .feature { grid-template-columns: 1.05fr 0.95fr; }
  .feature--reverse .feature__media { order: 2; }
}
.feature__media { position: relative; }
.feature__media img { width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); aspect-ratio: 4/3; object-fit: cover; }
.feature__tag {
  position: absolute; left: var(--space-md); bottom: var(--space-md);
  background: var(--paper); color: var(--ink);
  font-size: var(--step--1); font-weight: 600; letter-spacing: 0.04em;
  padding: 0.4rem 0.8rem; border-radius: var(--radius-sm); box-shadow: var(--shadow-sm);
}

/* ---- Programme list (numbered services) ---- */
.programme { display: grid; gap: 0; counter-reset: prog; }
.programme__item {
  display: grid; grid-template-columns: auto 1fr auto; gap: var(--space-lg);
  align-items: baseline; padding: var(--space-xl) 0;
  border-top: 1px solid var(--border);
  transition: padding-left var(--dur) var(--ease-out);
}
.programme__item:last-child { border-bottom: 1px solid var(--border); }
.programme__item:hover { padding-left: var(--space-sm); }
.programme__num { font-family: var(--font-display); font-size: var(--step-2); color: var(--accent); font-weight: 500; min-width: 2.5ch; }
.programme__body h3 { font-size: var(--step-2); margin-bottom: var(--space-xs); }
.programme__body p { color: var(--fg-muted); max-width: 56ch; }
.programme__link { align-self: center; color: var(--accent); }
@media (max-width: 44rem) {
  .programme__item { grid-template-columns: auto 1fr; }
  .programme__link { display: none; }
}

/* ---- Cards (references / portfolio) ---- */
.cards { display: grid; gap: var(--space-xl); grid-template-columns: repeat(auto-fill, minmax(min(300px,100%), 1fr)); }
.card {
  display: flex; flex-direction: column;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius-lg); overflow: hidden;
  text-decoration: none; color: inherit;
  transition: transform var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out), border-color var(--dur);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--line-strong); text-decoration: none; }
.card__media { aspect-ratio: 3/2; overflow: hidden; background: var(--paper-3); }
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease-out); }
.card:hover .card__media img { transform: scale(1.04); }
.card__body { padding: var(--space-lg); display: flex; flex-direction: column; gap: var(--space-xs); flex: 1; }
.card__kicker { font-size: var(--step--1); letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); font-weight: 600; }
.card__title { font-family: var(--font-display); font-size: var(--step-1); line-height: 1.2; }
.card__excerpt { color: var(--fg-muted); font-size: var(--step--1); }

/* ---- Logo wall (partners/references) ---- */
.logo-wall { display: grid; gap: var(--space-xl); grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); align-items: center; }
.logo-wall img { width: 100%; height: 60px; object-fit: contain; opacity: 0.55; filter: grayscale(1); transition: opacity var(--dur), filter var(--dur); }
.logo-wall img:hover { opacity: 1; filter: grayscale(0); }
.on-lacquer .logo-wall img { filter: grayscale(1) brightness(0) invert(1); opacity: 0.45; }
.on-lacquer .logo-wall img:hover { opacity: 0.9; }

/* ---- Demo player ---- */
.demo-grid { display: grid; gap: var(--space-md); grid-template-columns: repeat(auto-fill, minmax(min(320px,100%),1fr)); }
.track {
  display: grid; grid-template-columns: auto 1fr; gap: var(--space-md); align-items: center;
  padding: var(--space-md); border: 1px solid var(--line); border-radius: var(--radius-md);
  background: var(--surface);
}
.track__btn {
  width: 3rem; height: 3rem; border-radius: 50%;
  display: grid; place-items: center; flex-shrink: 0;
  background: var(--ink); color: var(--paper);
  transition: transform var(--dur-fast) var(--ease-out), background-color var(--dur);
}
.track__btn:hover { transform: scale(1.06); }
.track[data-playing="true"] .track__btn { background: var(--brass-deep); }
.track__meta strong { display: block; font-family: var(--font-display); font-size: var(--step-0); }
.track__meta span { font-size: var(--step--1); color: var(--fg-muted); }
.track audio { display: none; }

/* ---- FAQ (accordion) ---- */
.faq { display: grid; gap: 0; }
.faq__item { border-top: 1px solid var(--border); }
.faq__item:last-child { border-bottom: 1px solid var(--border); }
.faq__q {
  width: 100%; text-align: left; display: flex; justify-content: space-between; gap: var(--space-md);
  align-items: center; padding: var(--space-lg) 0;
  font-family: var(--font-display); font-size: var(--step-1); font-weight: 600; color: var(--fg);
}
.faq__q .faq__icon { flex-shrink: 0; transition: transform var(--dur) var(--ease-out); color: var(--accent); }
.faq__q[aria-expanded="true"] .faq__icon { transform: rotate(45deg); }
.faq__a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows var(--dur-slow) var(--ease-out); }
.faq__q[aria-expanded="true"] + .faq__a { grid-template-rows: 1fr; }
.faq__a > div { overflow: hidden; }
.faq__a p { padding-bottom: var(--space-lg); color: var(--fg-muted); }

/* ---- Forms ---- */
.form { display: grid; gap: var(--space-lg); }
.form__row { display: grid; gap: var(--space-lg); grid-template-columns: 1fr; }
@media (min-width: 40rem) { .form__row--2 { grid-template-columns: 1fr 1fr; } }
.field { display: grid; gap: var(--space-2xs); }
.field label { font-size: var(--step--1); font-weight: 600; letter-spacing: 0.02em; }
.field .req { color: var(--oxblood); }
.field input, .field textarea, .field select {
  width: 100%; padding: 0.8em 0.9em;
  background: var(--paper); color: var(--ink);
  border: 1px solid var(--line-strong); border-radius: var(--radius-md);
  transition: border-color var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out);
}
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none; border-color: var(--brass-deep);
  box-shadow: 0 0 0 3px var(--selection);
}
.field textarea { min-height: 9rem; resize: vertical; }
.field--invalid input, .field--invalid textarea { border-color: var(--oxblood); }
.field__error { font-size: var(--step--1); color: var(--oxblood); min-height: 1.2em; }
/* Honeypot — visually & programmatically hidden from humans */
.hp-field { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
.form__note { font-size: var(--step--1); color: var(--fg-muted); }
.form__status { padding: var(--space-md); border-radius: var(--radius-md); font-size: var(--step--1); }
.form__status[data-state="success"] { background: color-mix(in oklch, var(--brass) 22%, var(--paper)); color: var(--ink); }
.form__status[data-state="error"] { background: color-mix(in oklch, var(--oxblood) 14%, var(--paper)); color: var(--oxblood); }

/* ---- Contact info block ---- */
.contact-list { display: grid; gap: var(--space-lg); }
.contact-list dt { font-size: var(--step--1); text-transform: uppercase; letter-spacing: 0.1em; color: var(--accent); font-weight: 600; margin-bottom: 0.2em; }
.contact-list dd { font-size: var(--step-1); font-family: var(--font-display); }
.contact-list a { text-decoration: none; }
.contact-list a:hover { text-decoration: underline; text-decoration-color: var(--accent); }

/* ---- Footer ---- */
.site-footer { background: var(--lacquer); color: var(--on-lacquer); padding-block: var(--space-4xl) var(--space-xl); }
.site-footer a { color: var(--on-lacquer-2); text-decoration: none; }
.site-footer a:hover { color: var(--on-lacquer); }
.footer-grid { display: grid; gap: var(--space-2xl); grid-template-columns: 1.4fr 1fr 1fr; }
@media (max-width: 52rem) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 32rem) { .footer-grid { grid-template-columns: 1fr; } }
.footer-grid h4 { font-family: var(--font-body); font-size: var(--step--1); text-transform: uppercase; letter-spacing: 0.12em; color: var(--brass); font-weight: 600; margin-bottom: var(--space-md); }
.footer-grid ul { list-style: none; padding: 0; display: grid; gap: var(--space-xs); }
.footer-brand__mark { height: 3rem; width: auto; margin-bottom: var(--space-md); }
.footer-bottom {
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--space-md);
  margin-top: var(--space-3xl); padding-top: var(--space-lg);
  border-top: 1px solid var(--line-on-dark);
  font-size: var(--step--1); color: var(--on-lacquer-2);
}
.footer-bottom nav { display: flex; flex-wrap: wrap; gap: var(--space-md); }

/* ---- Breadcrumbs ---- */
.breadcrumbs { font-size: var(--step--1); color: var(--ink-3); padding-block: var(--space-md); }
.breadcrumbs ol { list-style: none; display: flex; flex-wrap: wrap; gap: 0.4rem; padding: 0; }
.breadcrumbs li::after { content: "›"; margin-left: 0.4rem; color: var(--line-strong); }
.breadcrumbs li:last-child::after { content: ""; }
.breadcrumbs a { color: var(--ink-3); text-decoration: none; }
.breadcrumbs a:hover { color: var(--accent); }

/* ---- Prose (legal pages / posts) ---- */
.prose { max-width: var(--measure); }
.prose > * + * { margin-top: var(--space-md); }
.prose h2 { font-size: var(--step-2); margin-top: var(--space-2xl); }
.prose h3 { font-size: var(--step-1); margin-top: var(--space-xl); }
.prose a { color: var(--brass-deep); }
.prose ul, .prose ol { padding-left: 1.3em; display: grid; gap: var(--space-2xs); }
.prose img { border-radius: var(--radius-md); margin-block: var(--space-lg); }
.prose blockquote {
  font-family: var(--font-display); font-size: var(--step-1); font-style: italic;
  padding-left: var(--space-lg); border-left: 1px solid var(--brass-deep); color: var(--ink-2);
}

/* ---- Reveal on scroll ---- */
[data-reveal] { opacity: 0; transform: translateY(18px); transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out); }
[data-reveal].is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { [data-reveal] { opacity: 1; transform: none; } }
