/* =========================================================
   ALEX BOGOMOLOV — Design tokens
   Personal brand for an independent film producer.
   Monochrome cinema. Three-family typographic trinity.
   One muted-gold accent, used once per view. No bold. No shadows.
   ========================================================= */

/* ---- Webfonts ------------------------------------------- */
/* Space Grotesk — local brand files (variable + static cuts) */
@font-face {
  font-family: "Space Grotesk";
  src: url("fonts/SpaceGrotesk-VariableFont_wght.woff2") format("woff2") tech(variations);
  font-weight: 300 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Space Grotesk";
  src: url("fonts/SpaceGrotesk-Light.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Space Grotesk";
  src: url("fonts/SpaceGrotesk-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Space Grotesk";
  src: url("fonts/SpaceGrotesk-Medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Space Grotesk";
  src: url("fonts/SpaceGrotesk-SemiBold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Space Grotesk";
  src: url("fonts/SpaceGrotesk-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* EB Garamond — local brand files (variable + statics + italic variable) */
@font-face {
  font-family: "EB Garamond";
  src: url("fonts/EBGaramond-VariableFont_wght.woff2") format("woff2") tech(variations);
  font-weight: 400 800;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "EB Garamond";
  src: url("fonts/EBGaramond-Italic-VariableFont_wght.woff2") format("woff2") tech(variations);
  font-weight: 400 800;
  font-style: italic;
  font-display: swap;
}
@font-face { font-family: "EB Garamond"; src: url("fonts/EBGaramond-Regular.woff2") format("woff2");        font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: "EB Garamond"; src: url("fonts/EBGaramond-Italic.woff2") format("woff2");         font-weight: 400; font-style: italic; font-display: swap; }
@font-face { font-family: "EB Garamond"; src: url("fonts/EBGaramond-Medium.woff2") format("woff2");         font-weight: 500; font-style: normal; font-display: swap; }
@font-face { font-family: "EB Garamond"; src: url("fonts/EBGaramond-MediumItalic.woff2") format("woff2");   font-weight: 500; font-style: italic; font-display: swap; }
@font-face { font-family: "EB Garamond"; src: url("fonts/EBGaramond-SemiBold.woff2") format("woff2");       font-weight: 600; font-style: normal; font-display: swap; }
@font-face { font-family: "EB Garamond"; src: url("fonts/EBGaramond-SemiBoldItalic.woff2") format("woff2"); font-weight: 600; font-style: italic; font-display: swap; }
@font-face { font-family: "EB Garamond"; src: url("fonts/EBGaramond-Bold.woff2") format("woff2");           font-weight: 700; font-style: normal; font-display: swap; }
@font-face { font-family: "EB Garamond"; src: url("fonts/EBGaramond-BoldItalic.woff2") format("woff2");     font-weight: 700; font-style: italic; font-display: swap; }
@font-face { font-family: "EB Garamond"; src: url("fonts/EBGaramond-ExtraBold.woff2") format("woff2");      font-weight: 800; font-style: normal; font-display: swap; }
@font-face { font-family: "EB Garamond"; src: url("fonts/EBGaramond-ExtraBoldItalic.woff2") format("woff2"); font-weight: 800; font-style: italic; font-display: swap; }

/* JetBrains Mono — local brand files */
@font-face {
  font-family: "JetBrains Mono";
  src: url("fonts/JetBrainsMono-VariableFont_wght.woff2") format("woff2") tech(variations);
  font-weight: 100 800;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "JetBrains Mono";
  src: url("fonts/JetBrainsMono-Italic-VariableFont_wght.woff2") format("woff2") tech(variations);
  font-weight: 100 800;
  font-style: italic;
  font-display: swap;
}
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-Thin.woff2") format("woff2");          font-weight: 100; font-style: normal; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-ThinItalic.woff2") format("woff2");    font-weight: 100; font-style: italic; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-ExtraLight.woff2") format("woff2");    font-weight: 200; font-style: normal; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-ExtraLightItalic.woff2") format("woff2"); font-weight: 200; font-style: italic; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-Light.woff2") format("woff2");         font-weight: 300; font-style: normal; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-LightItalic.woff2") format("woff2");   font-weight: 300; font-style: italic; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-Regular.woff2") format("woff2");       font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-Italic.woff2") format("woff2");        font-weight: 400; font-style: italic; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-Medium.woff2") format("woff2");        font-weight: 500; font-style: normal; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-MediumItalic.woff2") format("woff2");  font-weight: 500; font-style: italic; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-SemiBold.woff2") format("woff2");      font-weight: 600; font-style: normal; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-SemiBoldItalic.woff2") format("woff2"); font-weight: 600; font-style: italic; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-Bold.woff2") format("woff2");          font-weight: 700; font-style: normal; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-BoldItalic.woff2") format("woff2");    font-weight: 700; font-style: italic; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-ExtraBold.woff2") format("woff2");     font-weight: 800; font-style: normal; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("fonts/JetBrainsMono-ExtraBoldItalic.woff2") format("woff2"); font-weight: 800; font-style: italic; font-display: swap; }

:root {
  /* ===== COLORS ========================================== */

  /* Surfaces — pure black down to near-black. No mid-grays as backgrounds. */
  --canvas:            #000000;   /* dominant background */
  --surface-soft:      #0D0D0D;   /* dense data sections */
  --surface-card:      #141414;   /* the only "card" surface */
  --surface-elevated:  #1F1F1F;   /* nested cards on dense pages */
  --hairline:          #262626;   /* 1px dividers — quiet */
  --hairline-strong:   #3A3A3A;   /* heavier divider, input underline */

  /* Text */
  --ink:               #FFFFFF;   /* headlines, primary CTAs, wordmark */
  --body-strong:       #E6E6E6;   /* lead paragraphs */
  --body:              #CCCCCC;   /* default running serif */
  --muted:             #999999;   /* footer links, dates, captions */
  --muted-soft:        #666666;   /* legal, copyright */

  /* The single accent — used ONCE per view. */
  --accent:            #C9A961;   /* muted gold */
  --accent-hover:      #D9B975;
  --link:              #C3D9F3;   /* desaturated ice-blue, inline anchors only */

  /* ===== TYPOGRAPHY ====================================== */
  /* The Trinity — never cross the lines. */
  --font-display: "Space Grotesk", "Helvetica Neue", Arial, sans-serif;
  --font-serif:   "EB Garamond", "Cormorant Garamond", Georgia, serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Weights — never go heavier. */
  --w-body: 400;
  --w-display: 500;

  /* ===== SPACING (4px base) ============================== */
  --sp-xxs: 4px;
  --sp-xs:  8px;
  --sp-sm:  12px;
  --sp-md:  16px;
  --sp-lg:  24px;
  --sp-xl:  40px;
  --sp-xxl: 64px;
  --sp-section: 120px;   /* non-negotiable rhythm between bands */

  /* ===== RADII =========================================== */
  --r-none: 0px;          /* cards, inputs, photos all stay sharp */
  --r-pill: 9999px;       /* buttons only */

  /* ===== LAYOUT ========================================== */
  --max-content: 1280px;
  --nav-height: 56px;

  /* ===== MOTION ========================================== */
  /* Cinema-slow; never bouncy. */
  --ease-out: cubic-bezier(.2, .7, .2, 1);
  --dur-fast: 160ms;
  --dur-med:  280ms;
  --dur-slow: 600ms;
}

/* =========================================================
   SEMANTIC TYPE STYLES
   ========================================================= */

/* Display — uppercase Space Grotesk, positive tracking */
.type-display-xl,
.h1 {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 64px;
  line-height: 1.1;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--ink);
}
.type-display-lg,
.h2 {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 48px;
  line-height: 1.15;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--ink);
}
.type-display-md,
.h3 {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 32px;
  line-height: 1.2;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--ink);
}
.type-display-sm,
.h4 {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 24px;
  line-height: 1.3;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--ink);
}

/* Wordmark — the brand signature */
.type-wordmark {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 14px;
  line-height: 1;
  letter-spacing: 6px;
  text-transform: uppercase;
  color: var(--ink);
}

.type-title-md {
  font-family: var(--font-display);
  font-weight: var(--w-display);
  font-size: 20px;
  line-height: 1.3;
  letter-spacing: 1px;
  color: var(--ink);
}

/* Body — serif, sentence case, zero tracking */
.type-body-md,
.p {
  font-family: var(--font-serif);
  font-weight: var(--w-body);
  font-size: 17px;
  line-height: 1.6;
  letter-spacing: 0;
  color: var(--body);
}
.type-body-sm,
.small {
  font-family: var(--font-serif);
  font-weight: var(--w-body);
  font-size: 15px;
  line-height: 1.55;
  letter-spacing: 0;
  color: var(--body);
}
.type-lead {
  font-family: var(--font-serif);
  font-weight: var(--w-body);
  font-size: 21px;
  line-height: 1.5;
  letter-spacing: 0;
  color: var(--body-strong);
}

/* Utility — JetBrains Mono, uppercase, wide tracking */
.type-caption,
.caption {
  font-family: var(--font-mono);
  font-weight: var(--w-body);
  font-size: 11px;
  line-height: 1.4;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
}
.type-button,
.button-label {
  font-family: var(--font-mono);
  font-weight: var(--w-body);
  font-size: 14px;
  line-height: 1;
  letter-spacing: 2.5px;
  text-transform: uppercase;
}
.type-nav {
  font-family: var(--font-mono);
  font-weight: var(--w-body);
  font-size: 12px;
  line-height: 1.4;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--ink);
}

/* Inline anchor — ONLY usage of --link */
a.inline-link {
  color: var(--link);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  transition: color var(--dur-fast) var(--ease-out);
}
a.inline-link:hover { color: var(--ink); }

/* =========================================================
   PRIMITIVES — buttons, inputs, hairlines
   ========================================================= */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  padding: 0 32px;
  border-radius: var(--r-pill);
  background: transparent;
  border: 1px solid var(--ink);
  color: var(--ink);
  font-family: var(--font-mono);
  font-weight: var(--w-body);
  font-size: 14px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
}
.btn:hover { background: var(--ink); color: var(--canvas); }

.btn--accent {
  border-color: var(--accent);
  color: var(--accent);
}
.btn--accent:hover {
  background: transparent;
  border-color: var(--accent-hover);
  color: var(--accent-hover);
}

.btn--icon {
  width: 40px;
  height: 40px;
  padding: 0;
  border-radius: var(--r-pill);
}

/* Inputs — engraved, never boxed */
.input {
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--hairline-strong);
  border-radius: 0;
  padding: 12px 0;
  height: 44px;
  width: 100%;
  color: var(--ink);
  font-family: var(--font-serif);
  font-size: 17px;
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.input::placeholder { color: var(--muted-soft); }
.input:focus { border-bottom-color: var(--ink); }

/* Hairline divider */
.hairline { border: 0; height: 1px; background: var(--hairline); margin: 0; }
.hairline--strong { background: var(--hairline-strong); }

/* Card — sharp corners, almost-black */
.card {
  background: var(--surface-card);
  border-radius: var(--r-none);
  padding: var(--sp-lg);
}

/* Base body reset for surfaces using these tokens */
.bg-canvas    { background: var(--canvas); color: var(--body); }
.bg-soft      { background: var(--surface-soft); color: var(--body); }
.bg-card      { background: var(--surface-card); color: var(--body); }
.bg-elevated  { background: var(--surface-elevated); color: var(--body); }
