/* Shared styles for Alibee LLC legal pages (privacy.html, terms.html).
   Mirrors the design tokens and chrome used in index.html. */

@font-face {
  font-family: 'Instrument Serif';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/InstrumentSerif-Regular.ttf') format('truetype');
}
@font-face {
  font-family: 'Instrument Serif';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/InstrumentSerif-Italic.ttf') format('truetype');
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:          #FAF5EE;
  --bg-sunk:     #F2EBE0;
  --surface:     #FFFFFF;
  --ink:         #2A241D;
  --ink2:        #5A4F42;
  --ink3:        #8A7F70;
  --hairline:    #E4DCCE;
  --terra:       #C26542;
  --terra-deep:  #9F4F31;
  --terra-tint:  #F6E3D7;
  --copper:      #D8924F;
  --sage:        #6E7F5B;
  --plum:        #7A4B5E;

  --radius-sm:   10px;
  --radius-md:   16px;
  --radius-lg:   24px;
  --radius-pill: 999px;

  --shadow-card: 0 4px 24px rgba(42,36,29,0.08);
  --shadow-btn:  0 2px 12px rgba(194,101,66,0.25);

  --serif: 'Instrument Serif', Georgia, serif;
  --sans:  system-ui, -apple-system, 'SF Pro Text', Helvetica, Arial, sans-serif;

  --max-w: 1080px;
  --px: clamp(20px, 5vw, 60px);
  --content-w: 760px;
}

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }

.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--px);
}

/* ---------- Nav ---------- */
nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(250,245,238,0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--hairline);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 60px;
  gap: 20px;
}
.nav-logo { display: flex; align-items: center; gap: 10px; min-width: 0; }
.brand-mark {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.38), rgba(255,255,255,0) 42%),
    linear-gradient(135deg, var(--terra), var(--copper));
  display: grid;
  place-items: center;
  color: #fff;
  font-family: var(--serif);
  font-size: 24px;
  line-height: 1;
  box-shadow: 0 6px 16px rgba(194,101,66,0.22);
  flex: 0 0 auto;
}
.nav-wordmark { font-family: var(--serif); font-size: 22px; color: var(--ink); white-space: nowrap; }
.nav-links {
  display: flex;
  align-items: center;
  gap: 24px;
  color: var(--ink2);
  font-size: 14px;
  font-weight: 550;
}
.nav-links a { transition: color 0.15s; }
.nav-links a:hover { color: var(--terra-deep); }

/* ---------- Legal content ---------- */
.legal-main { padding: clamp(48px, 8vw, 96px) 0 clamp(56px, 8vw, 104px); }

.legal-header { max-width: var(--content-w); margin-bottom: 40px; }
.label-caps {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--terra);
}
.legal-title {
  font-family: var(--serif);
  font-size: clamp(38px, 6vw, 60px);
  line-height: 1.12;
  color: var(--ink);
  margin: 12px 0 16px;
}
.legal-meta { font-size: 14px; color: var(--ink3); }

.legal-content { max-width: var(--content-w); }
.legal-content .intro {
  font-size: 18px;
  color: var(--ink2);
  line-height: 1.7;
  margin-bottom: 8px;
}
.legal-content h2 {
  font-family: var(--serif);
  font-size: clamp(24px, 3.4vw, 30px);
  line-height: 1.2;
  color: var(--ink);
  margin: 38px 0 12px;
}
.legal-content h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--ink);
  margin: 22px 0 6px;
}
.legal-content p { color: var(--ink2); margin: 0 0 14px; }
.legal-content ul { color: var(--ink2); margin: 0 0 14px; padding-left: 22px; }
.legal-content li { margin: 0 0 7px; }
.legal-content a { color: var(--terra-deep); text-decoration: underline; text-underline-offset: 2px; }
.legal-content a:hover { color: var(--terra); }
.legal-content strong { color: var(--ink); }

.legal-divider { height: 1px; background: var(--hairline); border: 0; margin: 34px 0; }

/* ---------- Footer ---------- */
footer {
  background: var(--ink);
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 32px var(--px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
}
.footer-logo-row { display: flex; align-items: center; gap: 8px; }
.footer-logo-row .brand-mark { width: 24px; height: 24px; border-radius: 6px; font-size: 17px; opacity: 0.78; }
.footer-wordmark { font-family: var(--serif); font-size: 18px; color: rgba(255,255,255,0.6); }
.footer-copy { font-size: 12px; color: rgba(255,255,255,0.35); }
.footer-links { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.footer-links a { font-size: 12px; color: rgba(255,255,255,0.42); transition: color 0.15s; }
.footer-links a:hover { color: rgba(255,255,255,0.78); }

@media (max-width: 640px) {
  .nav-links { gap: 16px; font-size: 13px; }
  footer { justify-content: center; text-align: center; }
}
