/* Shared styles for individual downloadable assets */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,700&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --navy: #111122;
  --navy-deep: #0A0A1A;
  --red: #C92438;
  --red-bright: #F04655;
  --ink: #14141C;
  --gray-700: #4A4A55;
  --gray-500: #8A8A95;
  --gray-300: #C8C8CF;
  --gray-200: #E4E4E8;
  --gray-100: #F1F1F3;
  --paper: #FAF9F6;
  --border: #E6E5E0;
  --serif: 'Playfair Display', 'Times New Roman', serif;
  --serif-soft: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  font-family: var(--sans);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background: #2A2A2C;
}

/* The asset stage — centers the asset on a workshop background.
   When printing, the workshop disappears and only the asset prints. */
.stage {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px;
}

.asset {
  /* override per file */
  background: white;
  position: relative;
  box-shadow: 0 30px 80px -30px rgba(0,0,0,.6);
}

/* Bleed marker (only visible on screen) */
.asset::after {
  content: attr(data-size);
  position: absolute;
  left: 0; top: -28px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
}

/* ===== LOGO PRIMITIVES (re-usable across files) ===== */
.lm-logo {
  font-family: var(--serif);
  font-weight: 500;
  color: var(--navy);
  letter-spacing: -0.04em;
  line-height: 0.85;
  display: inline-flex;
  align-items: baseline;
  white-space: nowrap;
}
.lm-logo .lm-dot {
  width: 0.15em; height: 0.15em;
  border-radius: 50%;
  background: var(--red);
  display: inline-block;
  margin-left: 0.04em;
  flex-shrink: 0;
}
.lm-logo.on-dark { color: #fff; }
.lm-logo.on-dark .lm-dot { background: var(--red-bright); }

.lm-iso {
  --iso-bg: var(--navy);
  --iso-letter: #fff;
  --iso-dot: var(--red);
  --iso-ring: transparent;
  --iso-ring-w: 0;
  display: inline-block;
  position: relative;
  width: 1em; height: 1em;
  border-radius: 50%;
  background: var(--iso-bg);
  box-shadow: inset 0 0 0 calc(var(--iso-ring-w) * 1em) var(--iso-ring);
  flex-shrink: 0;
  vertical-align: middle;
}
.lm-iso::before,
.lm-iso::after {
  content: "";
  position: absolute;
  inset: 0;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}
.lm-iso > svg.lm-iso-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  overflow: visible;
  pointer-events: none;
}
.lm-iso > svg.lm-iso-svg .lm-iso-letter { fill: var(--iso-letter); }
.lm-iso > svg.lm-iso-svg .lm-iso-dot    { fill: var(--iso-dot); }
.lm-iso .lm-iso-L,
.lm-iso .lm-iso-dot { display: none; }
.lm-iso.inverted   { --iso-bg: #fff; --iso-letter: var(--navy); --iso-dot: var(--red); }

/* PRINT — clean asset only */
@media print {
  html, body { background: white !important; }
  .stage { padding: 0; min-height: auto; display: block; }
  .asset { box-shadow: none !important; margin: 0 auto; }
  .asset::after { display: none !important; }
  .toolbar, .help { display: none !important; }
}

/* Floating hint (top-right) — non-printing */
.help {
  position: fixed;
  top: 20px; right: 20px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  background: rgba(0,0,0,.4);
  padding: 8px 12px;
  border-radius: 4px;
  border: 1px solid rgba(255,255,255,.1);
  line-height: 1.6;
  text-align: right;
}
.help b { color: white; font-weight: 500; }
.help kbd {
  display: inline-block;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.2);
  padding: 1px 5px;
  border-radius: 3px;
  font-family: inherit;
  font-size: inherit;
  margin: 0 2px;
}
