/* ACL Deck — shared design system
   Same palette + type system as the locked-in Atelier landing page.
   Slides are 1920×1080. Type scales accordingly. */

:root {
  /* Palette */
  --linen:    #F7F3EA;
  --linen2:   #EFE9DB;
  --paper:    #FBF8F1;
  --ink:      #1A1814;
  --ink2:     #403C34;
  --ink3:     #6E6957;
  --mute:     #A39E8C;
  --brass:    #A87C1F;
  --brass-hi: #C9A24B;
  --brass-dim:rgba(168,124,31,0.10);
  --rule:     rgba(26,24,20,0.08);
  --rule2:    rgba(26,24,20,0.16);
  --warn:     #B45236;
  --warn-bg:  #FBF1EC;
  --go:       #52A06B;
  --go-dark:  #3F8456;
  --go-bg:    rgba(82,160,107,0.10);

  /* Type */
  --sans:    "Söhne", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --display: "Söhne", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --serif:   "Newsreader", "Source Serif 4", Georgia, serif;
  --mono:    "JetBrains Mono", "IBM Plex Mono", ui-monospace, monospace;
}

/* Page reset within deck-stage */
deck-stage section,
deck-stage section *,
deck-stage section *::before,
deck-stage section *::after {
  box-sizing: border-box;
}

deck-stage section {
  width: 1920px;
  height: 1080px;
  background: var(--linen);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 22px;
  padding: 80px 96px;
  position: relative;
  overflow: hidden;
}

deck-stage section.dark {
  background: var(--ink);
  color: var(--linen);
}

deck-stage section.paper {
  background: var(--paper);
}

deck-stage section.linen2 {
  background: var(--linen2);
}

/* Shared elements */
.eyebrow {
  font-family: var(--mono);
  font-size: 16px;
  font-weight: 500;
  color: var(--brass);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 32px;
}
.eyebrow::before {
  content: '';
  width: 24px;
  height: 1px;
  background: var(--brass);
  display: block;
}

.dark .eyebrow { color: var(--brass-hi); }
.dark .eyebrow::before { background: var(--brass-hi); }

.eyebrow.warn { color: var(--warn); }
.eyebrow.warn::before { background: var(--warn); }

/* Display headline */
.h-display {
  font-family: var(--display);
  font-weight: 600;
  font-size: 124px;
  line-height: 0.98;
  letter-spacing: -0.04em;
  color: var(--ink);
  margin: 0;
}

.h-1 {
  font-family: var(--display);
  font-weight: 600;
  font-size: 92px;
  line-height: 1.02;
  letter-spacing: -0.035em;
  color: var(--ink);
  margin: 0;
}

.h-2 {
  font-family: var(--display);
  font-weight: 600;
  font-size: 72px;
  line-height: 1.04;
  letter-spacing: -0.03em;
  color: var(--ink);
  margin: 0;
}

.h-3 {
  font-family: var(--display);
  font-weight: 600;
  font-size: 36px;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0;
}

.dark .h-display,
.dark .h-1,
.dark .h-2,
.dark .h-3 { color: var(--linen); }

/* Italic brass accent — used in nearly every headline */
.italic {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  color: var(--brass);
}

.dark .italic { color: var(--brass-hi); }

/* Subhead / lede paragraph */
.lede {
  font-family: var(--sans);
  font-size: 28px;
  line-height: 1.45;
  color: var(--ink2);
  font-weight: 400;
  max-width: 1100px;
  margin: 32px 0 0;
}

.dark .lede { color: #C5BFB0; }

.body {
  font-family: var(--sans);
  font-size: 22px;
  line-height: 1.55;
  color: var(--ink2);
}

.dark .body { color: #C5BFB0; }

/* Footer chrome — slide number + label */
.slide-foot {
  position: absolute;
  bottom: 40px;
  left: 96px;
  right: 96px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--mono);
  font-size: 14px;
  color: var(--ink3);
  letter-spacing: 0.08em;
}
.dark .slide-foot { color: var(--mute); }

.slide-foot img { height: 22px; opacity: 0.75; }

/* Card — used for pillars, specs, etc */
.card {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 18px;
  padding: 36px 32px 32px;
  display: flex;
  flex-direction: column;
}

.dark .card {
  background: rgba(247,243,234,0.04);
  border-color: rgba(247,243,234,0.12);
}

.card .tag {
  font-family: var(--mono);
  font-size: 14px;
  color: var(--brass);
  letter-spacing: 0.12em;
  margin-bottom: 24px;
}

.card .head {
  font-family: var(--display);
  font-size: 30px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.015em;
  line-height: 1.15;
  margin: 0 0 16px;
}
.dark .card .head { color: var(--linen); }

.card .body {
  font-size: 18px;
  line-height: 1.5;
  flex: 1;
}

/* Pill / chip */
.chip {
  display: inline-flex;
  align-items: center;
  padding: 8px 16px;
  border-radius: 999px;
  background: var(--brass-dim);
  color: var(--brass);
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Browser frame for product shots */
.browser {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 40px 100px -40px rgba(26,24,20,0.30), 0 4px 14px rgba(26,24,20,0.04);
}
.browser .chrome {
  padding: 16px 22px;
  background: var(--linen2);
  border-bottom: 1px solid var(--rule);
  display: flex;
  align-items: center;
  gap: 18px;
}
.browser .dots { display: flex; gap: 8px; }
.browser .dot { width: 14px; height: 14px; border-radius: 50%; }
.browser .dot.a { background: #E2C8A0; }
.browser .dot.b { background: #D9CFB5; }
.browser .dot.c { background: #C8BC9E; }
.browser .url {
  flex: 1;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 10px;
  padding: 6px 16px;
  font-family: var(--mono);
  font-size: 16px;
  color: var(--ink3);
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Compliance banner — recurring marketing moment */
.compliance {
  background: linear-gradient(135deg, rgba(82,160,107,0.14), rgba(82,160,107,0.05));
  border: 1px solid rgba(82,160,107,0.3);
  border-radius: 14px;
  padding: 22px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.compliance .left { display: flex; align-items: center; gap: 16px; }
.compliance .badge {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--go); color: var(--paper);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; font-weight: 700;
}
.compliance .title { font-family: var(--sans); font-size: 18px; font-weight: 700; color: var(--ink); }
.compliance .sub   { font-family: var(--sans); font-size: 14px; color: var(--ink3); margin-top: 2px; }
.compliance .pct {
  font-family: var(--display);
  font-size: 56px;
  font-weight: 700;
  color: var(--go-dark);
  letter-spacing: -0.03em;
  line-height: 1;
}
.compliance .pct small { font-size: 22px; }

/* Mono / code-ish element */
.mono { font-family: var(--mono); }

/* Section header (top of each non-title slide) */
.slide-header {
  margin-bottom: 56px;
}

/* Logo block top-left of non-title slides */
.brand-mark {
  position: absolute;
  top: 48px;
  left: 96px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.brand-mark img { height: 32px; }
.brand-mark .name {
  font-family: var(--sans);
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.dark .brand-mark .name { color: var(--linen); }
