/* ========================================
   TOOLVINE MENTORS INITIATIVE
   Brand Guidelines · Stylesheet
   Prepared by BA CourtHouse
   ======================================== */

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

:root {
  /* Teal */
  --tv-deep:        #0F766E;
  --tv-teal:        #14B8A6;
  --tv-mint:        #5EEAD4;
  --tv-pale:        #CCFBF1;
  /* Amber */
  --tv-amber:       #D97706;
  --tv-amber-light: #FCD34D;
  --tv-amber-soft:  #FEF3C7;
  /* Canvases */
  --tv-app:         #F8FAFC;
  --tv-brand:       #FAFAF9;
  /* Neutrals */
  --tv-slate:       #0F172A;
  --tv-slate-2:     #1E293B;
  --tv-text:        #1A1A1A;
  --tv-text-2:      #475569;
  --tv-text-3:      #64748B;
  --tv-border:      #E2E8F0;
  --tv-border-2:    #CBD5E1;
  --tv-surface:     #FFFFFF;
  --tv-inner:       #F1F5F9;
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-weight: 400;
  color: var(--tv-text);
  background: var(--tv-brand);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
a { text-decoration: none; color: inherit; }

.container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 40px;
}


/* ========================================
   COVER
   ======================================== */

.cover {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--tv-brand);
  position: relative;
  overflow: hidden;
}

.cover::before {
  content: '';
  position: absolute;
  top: -25%; left: -10%;
  width: 700px; height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--tv-pale) 0%, transparent 70%);
  opacity: 0.55;
  z-index: 0;
}

.cover::after {
  content: '';
  position: absolute;
  bottom: -25%; right: -15%;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--tv-amber-soft) 0%, transparent 70%);
  opacity: 0.5;
  z-index: 0;
}

.cover-accent-bar {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 6px;
  display: flex;
  z-index: 2;
}
.bar-teal  { flex: 0 0 55%; background: var(--tv-deep); }
.bar-amber { flex: 1; background: var(--tv-amber); }

.cover-inner {
  text-align: center;
  position: relative;
  z-index: 1;
  padding: 0 24px;
}

.cover-mark {
  width: 140px; height: 140px;
  margin: 0 auto 36px;
}

.cover h1 {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(46px, 8vw, 88px);
  font-weight: 700;
  color: var(--tv-slate);
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin-bottom: 18px;
}

.cover-sub {
  font-size: 15px;
  color: var(--tv-text-2);
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-bottom: 48px;
}

.cover-meta {
  display: flex;
  gap: 32px;
  justify-content: center;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--tv-text-3);
}
.cover-meta span:not(:last-child)::after {
  content: ''; display: inline-block;
  width: 4px; height: 4px;
  background: var(--tv-amber);
  border-radius: 50%;
  margin-left: 32px;
  vertical-align: middle;
}


/* ========================================
   TOC
   ======================================== */

.toc {
  background: var(--tv-surface);
  padding: 80px 0;
  border-top: 1px solid var(--tv-border);
  border-bottom: 1px solid var(--tv-border);
}

.section-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--tv-deep);
  margin-bottom: 28px;
  font-weight: 500;
}

.toc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0;
  border-top: 1px solid var(--tv-border);
}
.toc-item {
  display: flex;
  align-items: baseline;
  gap: 14px;
  padding: 20px 4px;
  border-bottom: 1px solid var(--tv-border);
  border-right: 1px solid var(--tv-border);
  transition: background 0.2s;
}
.toc-item:hover { background: var(--tv-inner); }
.toc-item:nth-child(4n) { border-right: none; }

.toc-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--tv-amber);
  font-weight: 500;
  letter-spacing: 0.06em;
}
.toc-title {
  font-family: 'Poppins', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--tv-slate);
  letter-spacing: -0.01em;
}


/* ========================================
   SECTIONS
   ======================================== */

.section {
  padding: 120px 0;
  background: var(--tv-brand);
}
.section-alt { background: var(--tv-surface); }

.section-header {
  display: flex;
  align-items: baseline;
  gap: 18px;
  margin-bottom: 18px;
}
.section-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  color: var(--tv-amber);
  font-weight: 500;
  letter-spacing: 0.08em;
}
.section h2 {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 700;
  color: var(--tv-slate);
  letter-spacing: -0.025em;
  line-height: 1.05;
}

.section-intro {
  font-size: 17px;
  color: var(--tv-text-2);
  max-width: 720px;
  margin-bottom: 64px;
  line-height: 1.6;
}


/* ========================================
   01 STORY
   ======================================== */

.story-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 80px;
}
.story-text p { margin-bottom: 18px; color: var(--tv-text-2); }
.story-lead {
  font-size: 21px !important;
  color: var(--tv-slate) !important;
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: 24px !important;
}
.story-values {
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding: 36px 32px;
  background: var(--tv-pale);
  border-radius: 16px;
  align-self: start;
}
.value-item {
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(15,118,110,0.15);
}
.value-item:last-child { border-bottom: none; padding-bottom: 0; }
.value-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--tv-deep);
  letter-spacing: 0.1em;
  font-weight: 500;
}
.value-item h3 {
  font-family: 'Poppins', sans-serif;
  font-size: 19px;
  font-weight: 600;
  color: var(--tv-slate);
  margin: 6px 0 4px;
  letter-spacing: -0.01em;
}
.value-item p { font-size: 14px; color: var(--tv-text-2); }


/* ========================================
   02 PRIMARY LOGO
   ======================================== */

.logo-showcase {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 72px;
}
.logo-card {
  padding: 80px 48px;
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  position: relative;
}
.logo-card-light {
  background: var(--tv-surface);
  border: 1px solid var(--tv-border);
}
.logo-card-dark { background: var(--tv-deep); }
.logo-card img { max-width: 280px; height: auto; }
.logo-card-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--tv-text-3);
}
.logo-card-label.light-text { color: rgba(255,255,255,0.8); }

.dl-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px;
  background: var(--tv-deep);
  color: #fff;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 500;
  transition: background 0.2s;
}
.dl-btn:hover { background: #0D655E; }
.dl-btn-dark { background: #fff; color: var(--tv-deep); }
.dl-btn-dark:hover { background: var(--tv-pale); }

.logo-anatomy h3 {
  font-family: 'Poppins', sans-serif;
  font-size: 24px;
  font-weight: 600;
  color: var(--tv-slate);
  margin-bottom: 28px;
  letter-spacing: -0.02em;
}
.anatomy-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 28px;
}
.anatomy-item {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}
.anatomy-dot {
  flex-shrink: 0;
  width: 18px; height: 18px;
  border-radius: 50%;
  margin-top: 4px;
}
.anatomy-item p {
  font-size: 14px;
  color: var(--tv-text-2);
  line-height: 1.55;
}
.anatomy-item strong {
  color: var(--tv-slate);
  font-weight: 600;
}


/* ========================================
   03 LOGO VARIATIONS
   ======================================== */

.variations-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}
.variation-card {
  background: var(--tv-surface);
  border: 1px solid var(--tv-border);
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.variation-preview {
  background: var(--tv-inner);
  padding: 48px 32px;
  min-height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.variation-preview img { max-width: 140px; max-height: 140px; }
.variation-preview.preview-wide img { max-width: 220px; }
.variation-preview.preview-dark { background: var(--tv-deep); }
.variation-preview.preview-square img { max-width: 130px; border-radius: 22px; }
.variation-preview.preview-small img { width: 64px; height: 64px; image-rendering: pixelated; }
.variation-info {
  padding: 22px 24px 26px;
}
.variation-info h3 {
  font-family: 'Poppins', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--tv-slate);
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}
.variation-info p {
  font-size: 13px;
  color: var(--tv-text-2);
  margin-bottom: 14px;
  line-height: 1.55;
}
.dl-btn-inline {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--tv-deep);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 500;
  padding: 5px 11px;
  border-radius: 6px;
  background: var(--tv-pale);
  transition: background 0.15s;
}
.dl-btn-inline:hover { background: var(--tv-mint); }


/* ========================================
   04 COLOUR PALETTE
   ======================================== */

.palette-group-title {
  font-family: 'Poppins', sans-serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--tv-slate);
  margin: 56px 0 20px;
  letter-spacing: -0.01em;
}
.palette-group-title:first-of-type { margin-top: 0; }

.palette-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.swatch-card {
  background: var(--tv-surface);
  border: 1px solid var(--tv-border);
  border-radius: 12px;
  overflow: hidden;
  transition: transform 0.2s, box-shadow 0.2s;
}
.swatch-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(15,23,42,0.08);
}
.swatch {
  height: 130px;
  width: 100%;
}
.swatch-info {
  padding: 18px 18px 22px;
}
.swatch-info h4 {
  font-family: 'Poppins', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--tv-slate);
  margin-bottom: 8px;
  letter-spacing: -0.01em;
}
.swatch-codes {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--tv-text-3);
  margin-bottom: 8px;
}
.swatch-use {
  font-size: 12px;
  color: var(--tv-text-2);
  line-height: 1.4;
}

/* Canvas comparison */
.canvas-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 12px;
}
.canvas-card {
  background: var(--tv-surface);
  border: 1px solid var(--tv-border);
  border-radius: 14px;
  overflow: hidden;
}
.canvas-swatch {
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.canvas-swatch img { width: 80px; height: 80px; }
.canvas-app { background: var(--tv-app); }
.canvas-brand { background: var(--tv-brand); }
.canvas-info { padding: 22px 24px 26px; }
.canvas-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--tv-text-3);
  margin-bottom: 6px;
}
.canvas-info h4 {
  font-family: 'Poppins', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--tv-slate);
  margin-bottom: 6px;
}
.canvas-info p {
  font-size: 14px;
  color: var(--tv-text-2);
  line-height: 1.55;
}


/* ========================================
   05 TYPOGRAPHY
   ======================================== */

.type-row {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.type-sample {
  background: var(--tv-surface);
  border: 1px solid var(--tv-border);
  border-radius: 14px;
  padding: 32px 36px;
}
.type-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tv-amber);
  font-weight: 500;
  margin-bottom: 18px;
}
.type-display {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(38px, 6vw, 68px);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--tv-slate);
  line-height: 1;
}
.type-heading {
  font-family: 'Poppins', sans-serif;
  font-size: 30px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--tv-slate);
  line-height: 1.1;
}
.type-body {
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  color: var(--tv-text-2);
  line-height: 1.65;
  max-width: 600px;
}
.type-caps {
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.2em;
  color: var(--tv-deep);
}
.type-mono {
  font-family: 'JetBrains Mono', monospace;
  font-size: 14px;
  color: var(--tv-slate);
  background: var(--tv-inner);
  padding: 10px 14px;
  border-radius: 6px;
  display: inline-block;
}
.type-meta {
  font-size: 13px;
  color: var(--tv-text-3);
  margin-top: 14px;
}


/* ========================================
   06 CLEAR SPACE & SIZING
   ======================================== */

.sizing-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.sizing-card {
  background: var(--tv-surface);
  border: 1px solid var(--tv-border);
  border-radius: 14px;
  padding: 32px;
}
.sizing-card h3 {
  font-family: 'Poppins', sans-serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--tv-slate);
  margin-bottom: 22px;
  letter-spacing: -0.01em;
}
.size-list { display: flex; flex-direction: column; gap: 12px; }
.size-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--tv-border);
}
.size-row:last-child { border-bottom: none; padding-bottom: 0; }
.size-label { font-size: 14px; color: var(--tv-text-2); }
.size-value {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--tv-deep);
  font-weight: 500;
}
.donts-list { display: flex; flex-direction: column; gap: 10px; }
.dont-item {
  font-size: 13px;
  color: var(--tv-text-2);
  padding: 10px 14px 10px 32px;
  background: var(--tv-inner);
  border-radius: 8px;
  position: relative;
  line-height: 1.5;
}
.dont-item::before {
  content: '×';
  position: absolute;
  left: 12px; top: 50%;
  transform: translateY(-50%);
  width: 14px; height: 14px;
  display: flex; align-items: center; justify-content: center;
  background: var(--tv-amber);
  color: #fff;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}


/* ========================================
   07 APPLICATIONS
   ======================================== */

.app-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.app-card-wide { grid-column: 1 / -1; }

.app-card {
  background: var(--tv-surface);
  border: 1px solid var(--tv-border);
  border-radius: 14px;
  overflow: hidden;
}
.app-mockup {
  min-height: 280px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px;
  background: var(--tv-inner);
}
.app-info {
  padding: 22px 28px 28px;
}
.app-info h3 {
  font-family: 'Poppins', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--tv-slate);
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}
.app-info p {
  font-size: 14px;
  color: var(--tv-text-2);
  line-height: 1.55;
}

/* Dashboard mockup */
.mockup-dashboard { padding: 28px; }
.dash-window {
  background: #fff;
  border-radius: 10px;
  width: 100%;
  max-width: 720px;
  box-shadow: 0 8px 30px rgba(15,23,42,0.08);
  overflow: hidden;
  border: 1px solid var(--tv-border);
}
.dash-chrome {
  background: var(--tv-inner);
  padding: 8px 14px;
  display: flex;
  align-items: center;
  gap: 6px;
  border-bottom: 1px solid var(--tv-border);
}
.chrome-dot { width: 9px; height: 9px; border-radius: 50%; display: block; }
.chrome-url {
  margin-left: 10px;
  background: #fff;
  border-radius: 4px;
  padding: 3px 12px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: var(--tv-text-3);
  flex: 1;
}
.dash-body { display: grid; grid-template-columns: 180px 1fr; min-height: 240px; }
.dash-side { background: var(--tv-slate); padding: 16px 12px; color: rgba(255,255,255,0.72); }
.dash-side-logo {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 8px; margin-bottom: 22px;
}
.dash-side-logo img { width: 22px; height: 22px; }
.dash-side-logo span {
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: 13px;
  color: #fff;
}
.dash-nav { display: flex; flex-direction: column; gap: 2px; }
.dash-nav-item {
  padding: 7px 10px;
  border-radius: 6px;
  font-size: 11px;
  color: rgba(255,255,255,0.72);
}
.dash-nav-item.active { background: var(--tv-teal); color: #fff; font-weight: 600; }
.dash-main { padding: 20px 24px; background: var(--tv-app); }
.dash-top {
  display: flex; justify-content: space-between; align-items: center;
  background: #fff; border: 1px solid var(--tv-border);
  border-radius: 8px; padding: 12px 16px;
  margin-bottom: 14px;
}
.dash-greet { display: block; font-size: 9px; color: var(--tv-text-3); }
.dash-name {
  display: block;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 13px;
  color: var(--tv-slate);
}
.dash-pill {
  background: var(--tv-pale);
  color: var(--tv-deep);
  font-size: 10px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 999px;
}
.dash-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.dash-stat {
  background: #fff;
  border: 1px solid var(--tv-border);
  border-radius: 8px;
  padding: 12px 14px;
}
.dash-stat-num {
  display: block;
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: 22px;
  color: var(--tv-slate);
  line-height: 1;
}
.dash-stat-lbl {
  display: block;
  font-size: 10px;
  color: var(--tv-text-3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 4px;
}

/* Tabs mockup */
.mockup-tabs { padding: 0; background: #1F2937; flex-direction: column; align-items: stretch; }
.tabs-bar { background: #111827; padding: 10px 10px 0; display: flex; gap: 4px; }
.tab {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  border-radius: 8px 8px 0 0;
  font-size: 12px;
  max-width: 200px;
}
.tab-active { background: #fff; color: var(--tv-slate); }
.tab-inactive { background: #374151; color: #D1D5DB; }
.tab-fav { width: 16px; height: 16px; image-rendering: pixelated; }
.tab-fav-placeholder { width: 16px; height: 16px; background: #4B5563; border-radius: 3px; display: inline-block; }
.tabs-body {
  flex: 1; background: #fff; padding: 30px;
  color: var(--tv-text-3);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: center;
}

/* Phone mockup */
.mockup-phone {
  background: linear-gradient(160deg, #FED7AA 0%, #FB923C 50%, #C2410C 100%);
}
.phone-frame {
  width: 240px;
  background: #000;
  border-radius: 30px;
  padding: 8px;
  box-shadow: 0 20px 50px rgba(15,23,42,0.3);
}
.phone-screen {
  background: linear-gradient(180deg, #FB923C 0%, #DC2626 50%, #7C2D12 100%);
  border-radius: 22px;
  padding: 14px;
  min-height: 320px;
}
.phone-status {
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 6px 14px;
  text-align: left;
}
.phone-icons {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.phone-app {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
}
.phone-app-icon {
  width: 36px; height: 36px;
  background: rgba(255,255,255,0.18);
  backdrop-filter: blur(8px);
  border-radius: 9px;
}
.phone-real-icon { width: 36px; height: 36px; border-radius: 9px; }
.phone-app-name { font-size: 8px; color: #fff; }

/* Share / OG mockup */
.mockup-share { padding: 36px; }
.share-msg {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  width: 100%;
  max-width: 600px;
}
.share-avatar {
  flex-shrink: 0;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--tv-deep);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 13px;
}
.share-bubble { flex: 1; }
.share-text {
  font-size: 14px;
  color: var(--tv-text);
  margin-bottom: 10px;
}
.share-card {
  display: block;
  border: 1px solid var(--tv-border);
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
  cursor: pointer;
}
.share-card img { width: 100%; height: auto; display: block; }
.share-card-meta { padding: 14px 16px; }
.share-card-title {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--tv-slate);
  margin-bottom: 3px;
}
.share-card-desc {
  font-size: 12px;
  color: var(--tv-text-2);
  margin-bottom: 6px;
  line-height: 1.4;
}
.share-card-url {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--tv-text-3);
  letter-spacing: 0.04em;
  text-transform: lowercase;
}

/* Instagram mockup */
.mockup-ig {
  background: #FAFAFA;
  padding: 32px;
  flex-direction: column;
  gap: 24px;
  align-items: center;
}
.ig-profile {
  display: flex;
  gap: 28px;
  align-items: center;
  width: 100%;
  max-width: 560px;
  background: #fff;
  border: 1px solid #DBDBDB;
  border-radius: 10px;
  padding: 22px;
}
.ig-avatar {
  width: 88px; height: 88px;
  border-radius: 50%;
  flex-shrink: 0;
  border: 1px solid #DBDBDB;
}
.ig-handle {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 18px;
  color: var(--tv-slate);
  margin-bottom: 2px;
}
.ig-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--tv-slate);
  margin-bottom: 6px;
}
.ig-bio {
  font-size: 12px;
  color: var(--tv-text-2);
  margin-bottom: 10px;
}
.ig-stats {
  display: flex; gap: 16px;
  font-size: 12px; color: var(--tv-text-2);
}
.ig-stats strong { color: var(--tv-slate); font-weight: 600; }

.ig-post {
  width: 100%; max-width: 360px;
  border: 1px solid #DBDBDB;
  border-radius: 4px;
  overflow: hidden;
  background: #fff;
}
.ig-post img { width: 100%; display: block; }

/* Email signature */
.mockup-email { background: #F4F6F8; }
.email-sig {
  background: #fff;
  border: 1px solid var(--tv-border);
  border-radius: 6px;
  padding: 24px 28px;
  max-width: 560px;
}
.email-divider {
  height: 2px;
  background: linear-gradient(90deg, var(--tv-deep) 0 55%, var(--tv-amber) 55% 100%);
  margin-bottom: 16px;
  border-radius: 1px;
}
.email-sig-content {
  display: flex;
  gap: 22px;
  align-items: center;
}
.email-logo { width: 180px; height: auto; flex-shrink: 0; }
.email-details { display: flex; flex-direction: column; gap: 2px; }
.email-name {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--tv-slate);
}
.email-role { font-size: 12px; color: var(--tv-text-2); }
.email-contact { font-size: 11px; color: var(--tv-text-3); margin-top: 4px; }

/* Sign-in mockup */
.mockup-signin { background: var(--tv-app); padding: 36px; }
.signin-card {
  background: #fff;
  border: 1px solid var(--tv-border);
  border-radius: 14px;
  padding: 36px 32px;
  width: 100%;
  max-width: 340px;
  box-shadow: 0 6px 24px rgba(15,23,42,0.05);
}
.signin-mark {
  width: 56px; height: 56px;
  margin: 0 auto 20px;
}
.signin-title {
  font-family: 'Poppins', sans-serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--tv-slate);
  text-align: center;
  margin-bottom: 4px;
}
.signin-sub {
  font-size: 13px;
  color: var(--tv-text-3);
  text-align: center;
  margin-bottom: 22px;
}
.signin-input {
  background: var(--tv-inner);
  border: 1px solid var(--tv-border);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 12px;
  color: var(--tv-text-3);
  margin-bottom: 10px;
  height: 38px;
  display: flex;
  align-items: center;
}
.signin-input-empty::before {
  content: '••••••••';
  color: var(--tv-border-2);
  letter-spacing: 4px;
}
.signin-btn {
  background: var(--tv-deep);
  color: #fff;
  text-align: center;
  padding: 11px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  margin: 6px 0 14px;
  cursor: pointer;
}
.signin-link {
  font-size: 12px;
  color: var(--tv-deep);
  text-align: center;
  font-weight: 500;
}


/* ========================================
   08 FILE LIBRARY
   ======================================== */

.file-table {
  background: var(--tv-surface);
  border: 1px solid var(--tv-border);
  border-radius: 12px;
  overflow: hidden;
}
.file-row {
  display: grid;
  grid-template-columns: 1.2fr 2fr auto;
  gap: 16px;
  align-items: center;
  padding: 16px 24px;
  border-bottom: 1px solid var(--tv-border);
  font-size: 14px;
}
.file-row:last-child { border-bottom: none; }
.file-row-head {
  background: var(--tv-inner);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--tv-text-3);
  font-weight: 500;
}
.file-name-cell {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  color: var(--tv-slate);
  font-weight: 500;
}


/* ========================================
   FOOTER
   ======================================== */

.footer {
  background: var(--tv-slate);
  color: rgba(255,255,255,0.7);
  padding: 56px 0;
}
.footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.footer-left { display: flex; align-items: center; gap: 14px; }
.footer-mark { width: 40px; height: 40px; }
.footer-left p {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.footer-right {
  text-align: right;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.footer-right p:first-child { color: rgba(255,255,255,0.9); margin-bottom: 4px; }


/* ========================================
   RESPONSIVE
   ======================================== */

@media (max-width: 900px) {
  .container { padding: 0 24px; }
  .section { padding: 80px 0; }
  .cover-mark { width: 100px; height: 100px; }
  .cover-meta { flex-direction: column; gap: 8px; }
  .cover-meta span:not(:last-child)::after { display: none; }
  .toc-grid { grid-template-columns: repeat(2, 1fr); }
  .toc-item:nth-child(4n) { border-right: 1px solid var(--tv-border); }
  .toc-item:nth-child(2n) { border-right: none; }
  .story-grid { grid-template-columns: 1fr; gap: 36px; }
  .logo-showcase { grid-template-columns: 1fr; }
  .logo-card { padding: 48px 28px; }
  .canvas-row { grid-template-columns: 1fr; }
  .sizing-grid { grid-template-columns: 1fr; }
  .app-grid { grid-template-columns: 1fr; }
  .app-card-wide { grid-column: auto; }
  .dash-body { grid-template-columns: 100px 1fr; }
  .dash-side-logo span { display: none; }
}

@media (max-width: 540px) {
  .mockup-dashboard { padding: 14px; }
  .dash-body { grid-template-columns: 70px 1fr; min-height: 0; }
  .dash-side { padding: 12px 6px; }
  .dash-side-logo { padding: 0; margin-bottom: 14px; justify-content: center; }
  .dash-nav-item { padding: 7px 6px; font-size: 10px; text-align: center; }
  .dash-main { padding: 14px; }
  .dash-stats { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .dash-stat { padding: 10px 12px; }
  .dash-stat-num { font-size: 18px; }
  .dash-top { padding: 10px 12px; margin-bottom: 10px; }
  .dash-name { font-size: 12px; }
  .dash-meeting-name { font-size: 11px; }
  .chrome-url { font-size: 9px; padding: 3px 8px; }
  .footer-inner { flex-direction: column; align-items: flex-start; }
  .footer-right { text-align: left; }
}

@media (max-width: 540px) {
  .toc-grid { grid-template-columns: 1fr; }
  .toc-item { border-right: none !important; }
  .email-sig-content { flex-direction: column; align-items: flex-start; gap: 14px; }
  .email-logo { width: 140px; }
  .ig-profile { flex-direction: column; align-items: flex-start; gap: 14px; }
  .file-row { grid-template-columns: 1fr; gap: 6px; padding: 14px 18px; }
  .file-row-head { display: none; }
}


/* ========================================
   NEW MOCKUPS
   ======================================== */

/* Dashboard — meeting row addition */
.dash-row {
  background: #fff;
  border: 1px solid var(--tv-border);
  border-radius: 8px;
  margin-top: 10px;
  padding: 10px 14px;
}
.dash-meeting {
  display: flex;
  align-items: center;
  gap: 12px;
}
.dash-meeting-date {
  width: 42px; height: 42px;
  background: var(--tv-deep);
  color: #fff;
  border-radius: 6px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  flex-shrink: 0;
}
.dash-meeting-date strong {
  font-family: 'Poppins', sans-serif;
  font-size: 15px;
  line-height: 1;
}
.dash-meeting-date span {
  font-size: 8px;
  font-weight: 600;
  letter-spacing: 0.06em;
  margin-top: 2px;
}
.dash-meeting-info { flex: 1; display: flex; flex-direction: column; }
.dash-meeting-name {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 12px;
  color: var(--tv-slate);
}
.dash-meeting-meta {
  font-size: 10px;
  color: var(--tv-text-3);
  margin-top: 1px;
}
.dash-meeting-pill {
  font-size: 10px;
  font-weight: 600;
  color: #3B82F6;
  background: #DBEAFE;
  padding: 3px 9px;
  border-radius: 999px;
}

/* Business card */
.mockup-card {
  background: #E2E1DC;
  padding: 48px 32px;
  gap: 28px;
  flex-wrap: wrap;
}
.biz-card {
  width: 280px;
  aspect-ratio: 1.75;
  border-radius: 8px;
  padding: 22px 24px;
  position: relative;
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.18);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
}
.biz-card-front {
  background: var(--tv-deep);
  color: #fff;
  transform: rotate(-3deg);
}
.biz-card-back {
  background: var(--tv-brand);
  transform: rotate(2deg);
  align-items: center;
  text-align: center;
}
.biz-card-accent {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--tv-deep) 0% 55%, var(--tv-amber) 55% 100%);
}
.biz-card-mark { width: 34px; height: 34px; }
.biz-card-bottom { display: flex; flex-direction: column; }
.biz-card-name {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: -0.01em;
}
.biz-card-role {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tv-mint);
  margin-top: 4px;
}
.biz-card-back-logo { width: 110px; height: auto; margin: auto; }
.biz-card-back-url {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--tv-text-3);
  letter-spacing: 0.06em;
  text-transform: lowercase;
  margin-top: auto;
}

/* Book covers */
.mockup-books {
  background: linear-gradient(180deg, #E5E1D8 0%, #C9C3B5 100%);
  padding: 48px 32px;
  gap: 32px;
  flex-wrap: wrap;
}
.book-cover {
  width: 200px;
  aspect-ratio: 0.7;
  border-radius: 2px 6px 6px 2px;
  padding: 28px 24px 26px;
  display: flex;
  flex-direction: column;
  position: relative;
  box-shadow:
    -2px 0 0 rgba(0,0,0,0.18),
    -4px 0 0 rgba(255,255,255,0.4),
    -6px 0 0 rgba(0,0,0,0.10),
    6px 14px 24px rgba(15,23,42,0.25);
}
.book-teal { background: var(--tv-deep); color: #fff; }
.book-cream { background: var(--tv-brand); color: var(--tv-slate); }
.book-mark { width: 34px; height: 34px; }
.book-divider {
  width: 36px; height: 2px;
  background: var(--tv-mint);
  margin: 18px 0 14px;
}
.book-divider-amber { background: var(--tv-amber); }
.book-title {
  font-family: 'DM Serif Display', 'Poppins', serif;
  font-size: 28px;
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin-bottom: auto;
}
.book-title-dark { color: var(--tv-slate); }
.book-subtitle {
  font-size: 10.5px;
  line-height: 1.5;
  margin-top: 12px;
  opacity: 0.85;
  margin-bottom: 14px;
}
.book-subtitle-dark { color: var(--tv-text-2); opacity: 1; }
.book-author {
  font-family: 'Inter', sans-serif;
  font-size: 8.5px;
  letter-spacing: 0.18em;
  font-weight: 600;
  opacity: 0.75;
}
.book-author-dark { color: var(--tv-deep); opacity: 1; }

/* Welcome email */
.mockup-welcome { background: #F4F6F8; padding: 32px; }
.welcome-window {
  background: #fff;
  border-radius: 10px;
  width: 100%;
  max-width: 540px;
  box-shadow: 0 10px 30px rgba(15,23,42,0.10);
  overflow: hidden;
  border: 1px solid var(--tv-border);
}
.welcome-meta {
  padding: 14px 22px;
  background: #FAFAF9;
  border-bottom: 1px solid var(--tv-border);
}
.welcome-from { display: flex; flex-direction: column; margin-bottom: 4px; }
.welcome-from strong {
  font-family: 'Poppins', sans-serif;
  font-size: 13px;
  color: var(--tv-slate);
}
.welcome-from span {
  font-size: 11px;
  color: var(--tv-text-3);
}
.welcome-subject {
  font-size: 13px;
  font-weight: 600;
  color: var(--tv-slate);
}
.welcome-header {
  background: var(--tv-deep);
  padding: 28px 22px;
  display: flex;
  justify-content: center;
}
.welcome-header img { height: 32px; }
.welcome-content {
  padding: 26px 28px 8px;
}
.welcome-content p {
  font-size: 13.5px;
  color: var(--tv-text-2);
  margin-bottom: 12px;
  line-height: 1.6;
}
.welcome-greet {
  color: var(--tv-slate) !important;
  font-weight: 500 !important;
}
.welcome-btn {
  display: inline-block;
  background: var(--tv-deep);
  color: #fff !important;
  font-weight: 600 !important;
  padding: 10px 22px;
  border-radius: 8px;
  font-size: 13px;
  text-decoration: none;
  margin: 14px 0 18px;
}
.welcome-sign {
  font-size: 12px !important;
  color: var(--tv-text-3) !important;
  font-style: italic;
}
.welcome-footer {
  display: flex;
  gap: 14px;
  justify-content: center;
  padding: 14px 22px 22px;
  border-top: 1px solid var(--tv-border);
  background: #FAFAF9;
}
.welcome-footer span {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: var(--tv-text-3);
  letter-spacing: 0.08em;
}
.welcome-footer span:last-child { color: var(--tv-amber); font-weight: 600; }

/* Certificate */
.mockup-cert {
  background: #DDD8CB;
  padding: 36px 28px;
}
.cert {
  background: var(--tv-brand);
  width: 100%;
  max-width: 600px;
  aspect-ratio: 1.4;
  padding: 36px 40px;
  position: relative;
  box-shadow: 0 16px 40px rgba(15,23,42,0.18);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.cert-border {
  position: absolute;
  inset: 12px;
  border: 1.5px solid var(--tv-amber);
  pointer-events: none;
}
.cert-border::before {
  content: '';
  position: absolute;
  inset: 4px;
  border: 0.5px solid var(--tv-deep);
  opacity: 0.35;
}
.cert-logo {
  width: 78px;
  margin-bottom: 12px;
  position: relative;
  z-index: 1;
}
.cert-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.32em;
  color: var(--tv-deep);
  margin-bottom: 18px;
  position: relative;
  z-index: 1;
}
.cert-presented {
  font-family: 'Inter', sans-serif;
  font-style: italic;
  font-size: 12px;
  color: var(--tv-text-3);
  margin-bottom: 4px;
  position: relative;
  z-index: 1;
}
.cert-name {
  font-family: 'DM Serif Display', serif;
  font-size: 28px;
  color: var(--tv-slate);
  margin-bottom: 16px;
  letter-spacing: -0.01em;
  position: relative;
  z-index: 1;
}
.cert-body {
  font-size: 11.5px;
  color: var(--tv-text-2);
  max-width: 420px;
  line-height: 1.65;
  margin-bottom: auto;
  position: relative;
  z-index: 1;
}
.cert-footer {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-top: 22px;
  position: relative;
  z-index: 1;
}
.cert-sig { display: flex; flex-direction: column; align-items: flex-start; }
.cert-sig-line {
  width: 140px; height: 1px;
  background: var(--tv-slate);
  margin-bottom: 6px;
}
.cert-sig span {
  font-size: 9.5px;
  color: var(--tv-text-3);
  letter-spacing: 0.04em;
}
.cert-stamp { display: flex; flex-direction: column; align-items: center; gap: 4px; opacity: 0.7; }
.cert-stamp img { width: 32px; height: 32px; }
.cert-stamp span {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px;
  color: var(--tv-deep);
  letter-spacing: 0.08em;
}

@media (max-width: 720px) {
  .biz-card { width: 240px; }
  .book-cover { width: 170px; }
  .cert { padding: 24px 22px; }
  .cert-name { font-size: 22px; }
  .cert-body { font-size: 11px; }
  .cert-footer { flex-direction: column; gap: 14px; align-items: center; }
}


/* ========================================
   CROSS-PAGE CTAs (Back to requests)
   ======================================== */

.cover-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 36px;
  padding: 12px 24px;
  background: var(--tv-deep);
  color: #fff !important;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 14px;
  border-radius: 999px;
  letter-spacing: 0.01em;
  transition: background 0.2s, transform 0.2s;
  box-shadow: 0 4px 14px rgba(15,118,110,0.25);
}
.cover-cta:hover {
  background: #0D655E;
  transform: translateY(-1px);
}

.footer-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.92);
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 13px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  letter-spacing: 0.01em;
  transition: background 0.2s, border-color 0.2s;
}
.footer-cta:hover {
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.3);
}

@media (max-width: 900px) {
  .footer-cta { order: 2; align-self: flex-start; }
}
