@font-face {
  font-family: 'TabFont';
  src: url('/tabfont/TabFont-Regular.woff2') format('woff2');
  font-display: swap;
}

@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
@keyframes marquee-rev {
  from { transform: translateX(-50%); }
  to { transform: translateX(0); }
}
@keyframes bob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(7px); }
}
@keyframes chord-punch {
  0%   { transform: scale(.6); opacity: 0; }
  15%  { opacity: 1; }
  70%  { opacity: 1; }
  100% { transform: scale(4); opacity: 0; }
}

#tabfont { background: transparent; color: #f2efe9; font-family: 'Newsreader', serif; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
#tabfont * { box-sizing: border-box; }
#tabfont a { color: inherit; text-decoration: none; }
#tabfont input { font-family: inherit; }
#tabfont ::selection { background: #c8ff00; color: #0b0b0c; }

#tabfont .mono { font-family: 'JetBrains Mono', monospace; }

#tabfont .section-label { font-size: 11px; letter-spacing: .3em; text-transform: uppercase; color: #c8ff00; margin-bottom: 24px; }
#tabfont .hidden{display:none}
#tabfont .hero {position: relative; display: flex; flex-direction: column;
  justify-content: center; align-items: center; min-height: 50vh;padding: 10px clamp(20px, 5vw, 64px) 20px; overflow: hidden; }
#tabfont .hero-bg-glyph { position: absolute; left: -3vw; bottom: -12vh; font-family: 'TabFont'; font-size: min(86vh, 72vw); line-height: .8; color: rgba(242, 239, 233, .035); pointer-events: none; user-select: none; z-index: 0; }
#tabfont .hero-inner { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; text-align: center; max-width: 1500px; }
#tabfont .hero-subtitle { font-size: 12px; letter-spacing: .32em; text-transform: uppercase; color: rgba(242, 239, 233, .5); margin-bottom: 34px; }
#tabfont .hero h1 { font-weight: 500; font-size: clamp(34px, 5.6vw, 176px); line-height: 1.02; letter-spacing: -.022em; margin-bottom: clamp(40px, 6vh, 72px); }
#tabfont .hero h1 em { font-style: italic; color: #c8ff00; }

#tabfont .scroll-cue { margin-top: clamp(40px, 6vh, 80px); color: rgba(242, 239, 233, .4); animation: bob 2s ease-in-out infinite; }

#tabfont .demo-section { display: flex; align-items: center; justify-content: center; min-height: 80vh; width: 100%; padding: clamp(40px, 6vh, 80px) clamp(20px, 5vw, 64px); gap: 0; }
#tabfont .demo-half { flex: 1; display: flex; align-items: center; justify-content: center; min-height: 60vh; }
#tabfont .demo-left { justify-content: flex-end; padding-right: clamp(24px, 4vw, 64px); }
#tabfont .demo-right { justify-content: flex-start; padding-left: clamp(24px, 4vw, 64px); }

#tabfont .demo-input-wrap { display: flex; flex-direction: column; align-items: center; gap: 14px; }
#tabfont .demo-input { background: transparent; border: none; border-bottom: 2px solid rgba(200, 255, 0, .55); outline: none; color: #f2efe9; caret-color: #c8ff00; font-family: 'JetBrains Mono', monospace; font-weight: 500; font-size: clamp(48px, 7vw, 110px); letter-spacing: -.03em; width: 7.2ch; padding: 0 .06em 12px; text-align:center}
#tabfont .demo-input-label { font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: rgba(242, 239, 233, .4); }
#tabfont .demo-hint { position: absolute; display: flex; flex-direction: column; gap: 6px; pointer-events: none; }
#tabfont .demo-hint-text {margin:0 auto; font-size: clamp(16px, 1.8vw, 14px); color: #927A53; white-space: nowrap; }
#tabfont .demo-hint-arrow { flex-shrink: 0; }
#tabfont .demo-hint-left { top: -20px; left: clamp(10px, 8vw, 120px); align-items: flex-end; }
#tabfont .demo-hint-right { bottom: -60px; right: clamp(10px, 8vw, 120px); align-items: flex-start; }
#tabfont .tylerwolf{font-family: 'tylerwolf', cursive; }
#tabfont .demo-arrow { font-size: clamp(28px, 4vw, 56px); color: rgba(242, 239, 233, .3); font-weight: 300; }

#tabfont .chips { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-top: clamp(40px, 6vh, 64px); max-width: 680px; }
#tabfont .chip { font-family: 'JetBrains Mono', monospace; font-size: 13px; letter-spacing: .02em; color: rgba(242, 239, 233, .75); background: transparent; box-shadow: inset 0 0 0 1px rgba(242, 239, 233, .16); border: none; border-radius: 999px; padding: 9px 16px; cursor: pointer; transition: all .22s ease; }
#tabfont .chip:hover { box-shadow: inset 0 0 0 1px #c8ff00; color: #c8ff00; }

#tabfont .hero-footer { position: absolute; left: 0; right: 0; bottom: 0; display: flex; justify-content: space-between; align-items: flex-end; padding: 0 clamp(20px, 5vw, 64px) 28px; font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: rgba(242, 239, 233, .4); z-index: 3; }
#tabfont .hero-footer .scroll-hint { display: flex; flex-direction: column; align-items: center; gap: 8px; }
#tabfont .hero-footer .scroll-arrow { display: inline-block; animation: bob 2s ease-in-out infinite; }

#tabfont section.modes { padding: clamp(90px, 14vh, 180px) clamp(20px, 5vw, 64px);  }
#tabfont .modes-intro { max-width: 900px; margin-bottom: clamp(56px, 8vh, 96px); }
#tabfont .modes-intro h2 { font-weight: 500; font-size: clamp(30px, 5vw, 64px); line-height: 1.05; letter-spacing: -.02em; }
#tabfont .modes-intro h2 em { font-style: italic; }

#tabfont .modes-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 1px; }
#tabfont .mode-label { font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: rgba(242, 239, 233, .45); margin-bottom: 18px; }
#tabfont .mode-title { font-weight: 500; font-size: clamp(30px, 4.4vw, 52px); letter-spacing: -.02em; margin-bottom: 18px; }
#tabfont .mode-desc { font-size: clamp(16px, 1.4vw, 20px); line-height: 1.5; color: rgba(242, 239, 233, .62); margin-bottom: clamp(30px, 4vh, 44px); }
#tabfont .mode-desc .hl { color: #f2efe9; }
#tabfont .mode-examples-grid { background-color:rgba(10,10,10,.9);padding:4rem 2rem 2rem 2rem;border-radius:3rem;display: grid; grid-template-columns: auto repeat(3, clamp(160px, 18vw, 240px)); gap: 12px clamp(20px, 3vw, 40px); align-items: center; justify-items: center; }
#tabfont .mode-examples-grid .glyph { font-family: 'TabFont'; font-size: clamp(152px, 18vw, 208px); line-height: 1; color: #f2efe9; }
#tabfont .mode-examples-grid .row-label {font-family:'JetBrains Mono';justify-self: end; font-size: 16px; color: rgba(255,255,255,1); letter-spacing: .06em; }
#tabfont .mode-examples-grid .label { font-size: 24px; color: rgba(242, 239, 233, .4); letter-spacing: .06em; }

#tabfont .editable-tab { background: transparent; border: none; border-bottom: 1px dashed rgba(200, 255, 0, .3); outline: none; font-size: 24px; color: rgba(242, 239, 233, .4); letter-spacing: .06em; width: 7ch; text-align: center; cursor: text; transition: border-color .15s ease, color .15s ease; }
#tabfont .editable-tab:hover { border-bottom-color: #c8ff00; color: rgba(242, 239, 233, .7); }
#tabfont .editable-tab:focus { border-bottom-color: #c8ff00; color: #f2efe9; }

#tabfont .typeahead-wrap { position: relative; display: inline-flex; flex-direction: column; align-items: center; }
#tabfont .typeahead-list { display: none; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); z-index: 10; background: rgba(16, 16, 16, .96); border: 1px solid rgba(200, 255, 0, .18); border-radius: 12px; padding: 6px; margin-top: 8px; min-width: 130px; max-height: 200px; overflow-y: auto; backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px); scrollbar-width: thin; scrollbar-color: rgba(200, 255, 0, .2) transparent; }
#tabfont .typeahead-list::-webkit-scrollbar { width: 4px; }
#tabfont .typeahead-list::-webkit-scrollbar-track { background: transparent; }
#tabfont .typeahead-list::-webkit-scrollbar-thumb { background: rgba(200, 255, 0, .2); border-radius: 4px; }
#tabfont .typeahead-list::-webkit-scrollbar-thumb:hover { background: rgba(200, 255, 0, .4); }
#tabfont .typeahead-item { padding: 7px 14px; font-size: 15px; color: rgba(242, 239, 233, .55); cursor: pointer; letter-spacing: .08em; border-radius: 7px; transition: background .12s ease, color .12s ease; }
#tabfont .typeahead-item:hover,
#tabfont .typeahead-item.active { background: rgba(200, 255, 0, .12); color: #c8ff00; }
#tabfont .mode-edit-hint { position: absolute; top: -44px; right: -50px; display: flex; align-items: flex-end; gap: 4px; color: #c8ff00; font-size: clamp(12px, 1.2vw, 16px); white-space: nowrap; pointer-events: none; }
#tabfont .mode-edit-hint .squiggle-arrow { width: 44px; height: auto; }
#tabfont .squiggle-arrow.flipped { transform: scaleX(-1); }

#tabfont section.scale { position: relative; padding: clamp(90px, 14vh, 180px) 0; overflow: hidden; }
#tabfont .scale-river-wrap { position: absolute; top: 0; left: 0; right: 0; bottom: 0; display: flex; flex-direction: column; justify-content: center; gap: clamp(8px, 2vw, 24px); pointer-events: none; z-index: 0; opacity: 0.4; }
#tabfont .scale-river-wrap .chord-river { padding: 0; width: 100%; max-width: none; }
#tabfont .scale-label { margin-bottom: clamp(4rem, 10vh, 8rem); }
#tabfont .scale-header { position: relative; z-index: 1; text-align: center; padding: 0 clamp(20px, 5vw, 64px); margin-bottom: clamp(56px, 8vh, 90px); }
#tabfont .scale-number { font-weight: 600; font-size: clamp(120px, 24vw, 320px); line-height: .82; letter-spacing: -.04em; }
#tabfont .scale-number .accent { color: #c8ff00; }
#tabfont .scale-tagline { font-style: italic; font-size: clamp(20px, 2.4vw, 32px); color: rgba(242, 239, 233, .7); margin-top: 24px; }

#tabfont .marquee-wrap { display: flex; flex-direction: column; gap: clamp(8px, 1.5vw, 20px); }
#tabfont .marquee-row { display: flex; width: max-content; }
#tabfont .marquee-row.forward { animation: marquee 38s linear infinite; }
#tabfont .marquee-row.reverse { animation: marquee-rev 44s linear infinite; }
#tabfont .marquee-track { display: flex; gap: clamp(14px, 2vw, 30px); padding-right: clamp(14px, 2vw, 30px); font-family: 'TabFont'; font-size: clamp(64px, 7vw, 96px); line-height: 1; color: rgba(242, 239, 233, .9); }
#tabfont .marquee-track .accent { color: #c8ff00; }

#tabfont section.cta { min-height: 88vh; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; padding: clamp(90px, 14vh, 180px) clamp(20px, 5vw, 64px);  }
#tabfont h3{font-family:'JetBrains Mono'}
#tabfont .cta-inner h2 { font-weight: 500; font-size: clamp(36px, 7vw, 108px); line-height: 1; letter-spacing: -.025em; max-width: 14ch; margin-bottom: clamp(40px, 6vh, 60px); }
#tabfont .cta-inner h2 em { font-style: italic; color: #c8ff00; }
#tabfont .cta-btn { display: inline-block; font-family: 'JetBrains Mono', monospace; font-weight: 700; font-size: clamp(15px, 1.6vw, 18px); letter-spacing: .02em; color: #0b0b0c; background: #c8ff00; padding: 20px 40px; border-radius: 999px; transition: transform .25s ease, box-shadow .25s ease; }
#tabfont .cta-btn:hover { transform: translateY(-3px); box-shadow: 0 16px 40px rgba(200, 255, 0, .25); }
#tabfont .cta-sub { font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: rgba(242, 239, 233, .4); margin-top: 34px; }

#tabfont .tabfont-download { min-height: 60vh; }
#tabfont .tabfont-commercial { display: flex; justify-content: center; padding: clamp(40px, 6vh, 80px) clamp(20px, 5vw, 64px); }
#tabfont .commercial-eyebrow { display: flex; align-items: center; gap: 8px; font-size: clamp(12px, 1.4vw, 15px); letter-spacing: .18em; text-transform: uppercase; color: rgba(242, 239, 233, .4); }
#tabfont .commercial-eyebrow svg { animation: bob 2s ease-in-out infinite; }

#tabfont .chord-zoom-wrap { position: relative; overflow: hidden; height: 70vh; display: flex; align-items: center; justify-content: center;   }
#tabfont .chord-zoom-glyph { position: absolute; font-family: 'TabFont'; font-size: clamp(120px, 22vw, 280px); line-height: 1; color: #f2efe9; opacity: 0; transform: scale(.6); pointer-events: none; }
#tabfont .chord-zoom-glyph.active { animation: chord-punch .5s cubic-bezier(.16, 1, .3, 1) forwards; }
#tabfont .chord-zoom-glyph.accent { color: #c8ff00; }

#tabfont .picker { padding: clamp(90px, 14vh, 180px) clamp(20px, 5vw, 64px);  }
#tabfont .picker-header { max-width: 900px; margin-bottom: clamp(40px, 6vh, 64px); }
#tabfont .picker-header h2 { font-weight: 500; font-size: clamp(30px, 5vw, 64px); line-height: 1.05; letter-spacing: -.02em; }
#tabfont .picker-header h2 em { font-style: italic; }

#tabfont button { width: auto; background: none; padding: 0; border-radius: 0; background-image: none; background-size: auto; }
#tabfont button:hover { background-size: auto; color: unset !important; }

#tabfont .picker-row { margin-bottom: clamp(24px, 4vh, 40px); }
#tabfont .picker-row-label { font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: rgba(242, 239, 233, .45); margin-bottom: 12px; }

#tabfont .picker-roots, #tabfont .picker-pills { display: flex; flex-wrap: nowrap; gap: 10px; }

#tabfont .card,
#tabfont .root-tile,
#tabfont .pick,
#tabfont .root-acc,
#tabfont .chord-card { position: relative; display: inline-flex; align-items: center; justify-content: center; background: rgba(42, 48, 43, .6); border: none; border-radius: 18px; color: #f2efe9; font-family: 'JetBrains Mono', monospace; font-weight: 700; white-space: nowrap; line-height: 1; box-shadow: none; backdrop-filter: blur(60px); -webkit-backdrop-filter: blur(10px); transition: all .15s ease; }

#tabfont .root-tile:hover,
#tabfont .pick:hover,
#tabfont .root-acc:hover { cursor: pointer; transform: scale(1.04); }

#tabfont .root-tile.active,
#tabfont .pick.active { box-shadow: none; background: rgba(200, 255, 0, .3); color: #c8ff00; }

#tabfont .root-acc.active { background: rgba(200, 255, 0, .5); color: #c8ff00; }

#tabfont .root-tile:active,
#tabfont .pick:active,
#tabfont .root-acc:active { transform: scale(0.96); }

#tabfont .root-tile { width: 144px; height: 144px; cursor: pointer; background: rgba(42, 48, 43, .3); color: #ffffff; }
#tabfont .root-tile.active { background: rgba(200, 255, 0, .3); color: #c8ff00; }
#tabfont .pick { flex: 1; height: 144px; font-size: 28px; padding: 0 12px; letter-spacing: .02em; }
#tabfont .picker-pills button{ max-height:80px;}

#tabfont .tylerwolf-text{font-family:tylerwolf;font-size:1.2rem}
#tabfont .hero-tagline { font-size: clamp(14px, 2vw, 18px); color: rgba(242, 239, 233, .6); margin-top: 0; }
#tabfont .root-letter { font-size: 60px; line-height: 1; margin-right: auto; padding-left: 24px; }
#tabfont .root-tile.active .root-letter { color: #c8ff00;}
#tabfont .root-accs { position: absolute; right: 9px; top: 50%; transform: translateY(-50%); display: flex; flex-direction: column; gap: 3px; }
#tabfont .root-acc:focus { outline: none; }   
#tabfont .root-acc { font-size: 24px; width: 36px; height: 36px; border-radius: 7px; padding: 0; background: rgba(30, 32, 30, .6); color: rgba(242, 239, 233, .9); border: none !important; outline: none !important; box-shadow: 0 0 6px 1px rgba(0, 0, 0, .3); }
#tabfont .root-acc:disabled { background: transparent !important; backdrop-filter: none; -webkit-backdrop-filter: none; box-shadow: none; color: rgba(242, 239, 233, .2); pointer-events: none; }

#tabfont .picker-output { display: flex; flex-direction: column; align-items: center; margin-top: clamp(40px, 6vh, 72px); }
#tabfont .picker-output-card { width: 100%; display: flex; flex-direction: column; align-items: center; background: linear-gradient(160deg, rgba(50, 58, 52, .55) 0%, rgba(24, 28, 24, .4) 50%, rgba(42, 50, 44, .5) 100%); backdrop-filter: blur(60px); -webkit-backdrop-filter: blur(10px); border-radius: 32px; padding: clamp(40px, 6vh, 72px) clamp(40px, 4vw, 72px) clamp(24px, 4vh, 40px); }
#tabfont .picker-output-glyph { font-family: 'TabFont'; font-size: clamp(200px, 30vw, 360px); line-height: 1; color: #f2efe9; }
#tabfont .picker-output-info { display: flex; flex-direction: row; gap: clamp(16px, 3vw, 32px); font-size: 14px; letter-spacing: .06em; color: rgba(242, 239, 233, .45); line-height: 1.4; margin-top: clamp(24px, 4vh, 48px); }
#tabfont .picker-info-label { color: rgba(242, 239, 233, .35); }
#tabfont .picker-info-val { color: rgba(242, 239, 233, .7); }
#tabfont .picker-info-val.accent { color: #c8ff00; }

#tabfont .chord-card { flex-direction: column; border-radius: 32px; padding: clamp(32px, 4vh, 56px) clamp(40px, 4vw, 72px); gap: 12px; width: clamp(280px, 28vw, 420px); height: clamp(360px, 50vh, 560px); overflow: hidden; font-weight: 400; background: linear-gradient(160deg, rgba(50, 58, 52, .65) 0%, rgba(28, 32, 28, .5) 50%, rgba(42, 50, 44, .6) 100%); }
#tabfont .chord-card-name { font-size: clamp(20px, 2vw, 28px); letter-spacing: .1em; color: #c8ff00; }
#tabfont .chord-card-diagram { font-family: 'TabFont'; font-size: clamp(200px, 26vw, 380px); line-height: 1; color: #c8ff00; }
#tabfont .chord-card-fingering { font-size: clamp(16px, 1.4vw, 22px); letter-spacing: .3em; color: rgba(200, 255, 0, .45); min-height: 1.2em; }

#tabfont .demo-card-wrap { position: relative; }
#tabfont .demo-card-annotation { position: absolute; top: -60px; right: 0; display: flex; flex-direction: column; align-items: flex-end; gap: 0; color: rgb(146, 122, 83); font-size: clamp(14px, 1.4vw, 20px); white-space: nowrap; pointer-events: none; z-index: 3; }
#tabfont .demo-card-annotation .squiggle-arrow { width: clamp(50px, 5vw, 80px); height: auto; align-self: flex-start; }

/* Chord River */
.chord-river { padding: clamp(40px, 8vh, 100px) 0; overflow: hidden; -webkit-mask-image: linear-gradient(to right, transparent, black 3%, black 97%, transparent); mask-image: linear-gradient(to right, transparent, black 3%, black 97%, transparent); }
.chord-river-track { display: flex; gap: clamp(40px, 6vw, 80px); width: max-content; will-change: transform; }
.river-glyph { font-family: 'TabFont'; font-size: clamp(80px, 10vw, 140px); line-height: 1; color: rgba(242, 239, 233, .55); flex-shrink: 0; }

@media (max-width: 768px) {
  /* Systematic mobile spacing — kill all min-heights and use consistent padding */
  #tabfont section,
  #tabfont .demo-section,
  #tabfont .demo-half { min-height: auto !important; }
  #tabfont .hero { padding: 32px 16px 16px; }
  #tabfont .demo-section { padding: 32px 16px; }
  #tabfont .picker { padding: 40px 16px; }
  #tabfont section.scale { padding: 40px 0; }
  #tabfont section.modes { padding: 40px 16px; }
  #tabfont section.cta,
  #tabfont .tabfont-download { padding: 48px 16px; min-height: auto; }
  #tabfont .tabfont-commercial { padding: 24px 16px; }
  #tabfont .scale-header { margin-bottom: 24px; }
  #tabfont .picker-output { margin-top: 24px; }
  #tabfont .modes-intro { margin-bottom: 24px; }

  /* Tylerwolf text — unified size */
  #tabfont .tylerwolf-text { font-size: 14px; }

  /* Hero */
  #tabfont .hero h1 { margin-bottom: 16px; }
  #tabfont .scroll-cue { margin-top: 16px; }

  /* Demo */
  #tabfont .demo-section { flex-direction: column; gap: 24px; }
  #tabfont .demo-left { justify-content: center; padding: 0; }
  #tabfont .demo-right { justify-content: center; padding: 0; }
  #tabfont .demo-input { font-size: 32px; width: 8ch; }
  #tabfont .demo-hint-text { display: none; }
  #tabfont .demo-card-annotation { display: none; }
  #tabfont .chord-card { width: clamp(200px, 60vw, 280px); height: clamp(260px, 42vh, 360px); }
  #tabfont .chord-card-diagram { font-size: clamp(140px, 46vw, 240px); }

  /* Picker roots */
  #tabfont .picker-roots { flex-wrap: wrap; gap: 6px; }
  #tabfont .root-tile { flex: 1 1 calc(50% - 6px); min-width: 0; height: auto; padding: 12px; gap: 8px; border-radius: 12px; flex-direction: row; justify-content: space-between; }
  #tabfont .root-letter { font-size: 20px; padding-left: 4px; margin-right: auto; }
  #tabfont .root-accs { position: static; transform: none; flex-direction: row; gap: 4px; }
  #tabfont .root-acc { font-size: 20px; width: 44px; height: 44px; border-radius: 10px; }

  /* Picker pills */
  #tabfont .picker-pills { flex-wrap: wrap; gap: 6px; justify-content: center; }
  #tabfont .pick { flex: 0 0 auto; height: auto; padding: 10px 14px; font-size: 15px; }
  #tabfont .picker-pills button { max-height: none; }

  /* Picker output */
  #tabfont .picker-output-card { padding: 24px 16px 20px; }
  #tabfont .picker-output-glyph { font-size: clamp(120px, 50vw, 220px); }
  #tabfont .picker-output-info { flex-direction: column; align-items: center; text-align: center; gap: 6px; font-size: 12px; margin-top: 16px; }

  /* Scale */
  #tabfont .scale-label { margin-bottom: 1.5rem; }
  #tabfont .scale-number { font-size: clamp(60px, 18vw, 140px); }

  /* Modes — single example */
  #tabfont .mode-examples-grid { grid-template-columns: 1fr; gap: 12px; padding: 1.5rem; border-radius: 1.5rem; justify-items: center; }
  #tabfont .mode-examples-grid .row-label { justify-self: center; font-size: 12px; }
  #tabfont .row-arrow { display: none; }
  #tabfont .mode-examples-grid .typeahead-wrap[data-idx="1"],
  #tabfont .mode-examples-grid .typeahead-wrap[data-idx="2"],
  #tabfont .mode-examples-grid #tab-glyph-1,
  #tabfont .mode-examples-grid #tab-glyph-2 { display: none; }
  #tabfont .mode-examples-grid .glyph { font-size: clamp(100px, 38vw, 160px); }
  #tabfont .editable-tab { font-size: 16px; width: 7ch; }
  #tabfont .mode-edit-hint { display: none; }

  /* CTA */
  #tabfont .cta-btn { padding: 16px 32px; font-size: 14px; }

  /* Chord River */
  .river-glyph { font-size: clamp(56px, 18vw, 90px); }
}

#tabfont [data-reveal] {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1);
  will-change: opacity, transform;
}
#tabfont [data-reveal].visible { opacity: 1; transform: none; }
