@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Inter:wght@300;400;500;600&display=swap');
@import 'tokens.css';
@import 'reset.css';
@import 'header.css';
@import 'footer.css';
@import 'card.css';
@import 'home.css';
@import 'listing.css';
@import 'detail.css';
@import 'news.css';
@import 'static.css';

/* Sticky footer */
body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
#main-content { flex: 1; }

/* Container */
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-md);
  width: 100%;
}
@media (min-width: 900px) {
  .container { padding: 0 var(--space-lg); }
}

/* Section spacing */
.section { padding: var(--space-2xl) 0; }
.section--alt { background: var(--color-surface-2); }
.section--tight { padding: var(--space-xl) 0; }

/* Gold rule */
.rule-gold { border: none; border-top: 1px solid var(--color-gold); }

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: 0.95rem 1.75rem;
  font: 500 var(--text-xs) / 1 var(--font-body);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  transition: background var(--transition), color var(--transition), transform var(--transition), box-shadow var(--transition);
  cursor: pointer;
  border: none;
  position: relative;
  overflow: hidden;
}
.btn--gold {
  background: var(--color-primary);
  color: white;
  box-shadow: var(--shadow-sm);
}
.btn--gold:hover {
  background: var(--color-ink-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.btn--outline {
  border: 1px solid var(--color-primary);
  color: var(--color-primary);
  background: transparent;
}
.btn--outline:hover { background: var(--color-primary); color: white; }

/* Inline arrow link — reusable */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font: 500 var(--text-xs) / 1 var(--font-body);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-primary);
  transition: color var(--transition);
}
.link-arrow::after {
  content: '→';
  transition: transform var(--transition);
  font-size: 1.1em;
  line-height: 0.9;
}
.link-arrow:hover { color: var(--color-ink-dark); }
.link-arrow:hover::after { transform: translateX(4px); }

/* Accessibility */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border-width: 0;
}

/* Reveal on scroll (progressive enhancement) */
@media (prefers-reduced-motion: no-preference) {
  @supports (animation-timeline: view()) {
    .reveal {
      animation: reveal-in linear both;
      animation-timeline: view();
      animation-range: entry 0% cover 22%;
    }
  }
  @keyframes reveal-in {
    from { opacity: 0; transform: translateY(28px); }
    to   { opacity: 1; transform: translateY(0); }
  }
}
