:root {
  --ink: #142a4c;
  --brand-navy: #142a4c;
  --muted: #667069;
  --cream: #f3f0e7;
  --paper: #fbfaf5;
  --lime: #c9ff3d;
  --green: #278254;
  --yellow: #e7b729;
  --orange: #dc7836;
  --red: #ca4d3b;
  --line: #d9dbd2;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--cream); font-family: "DM Sans", sans-serif; }
button, input { font: inherit; }
button { cursor: pointer; }
.noise { position: fixed; inset: 0; opacity: .035; pointer-events: none; z-index: 20; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.topbar { height: 82px; max-width: 1180px; margin: auto; padding: 0 28px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid rgba(17,24,20,.16); }
.brand { display: flex; align-items: center; gap: 14px; color: inherit; text-decoration: none; font: 700 18px "Manrope"; letter-spacing: -.5px; }
.brand strong { color: var(--green); }
.brand-logo-crop { width: 168px; height: 47px; display: grid; align-items: center; position: relative; overflow: hidden; background: white; }
.brand-logo-crop img { display: block; width: 100%; height: auto; position: relative; z-index: 2; }
.brand-logo-fallback { position: absolute; z-index: 1; left: 0; color: var(--ink); font: 800 15px/1 "Manrope"; letter-spacing: .3px; }
.brand-logo-fallback small { font-size: 8px; letter-spacing: 1.6px; }
.product-wordmark { padding-left: 14px; border-left: 1px solid var(--line); white-space: nowrap; }
.top-actions { display: flex; gap: 10px; }
.icon-button, .avatar { width: 42px; height: 42px; display: grid; place-items: center; border: 1px solid var(--line); background: rgba(255,255,255,.4); border-radius: 50%; color: var(--ink); }
.book-button { display: inline-flex; align-items: center; justify-content: center; padding: 15px 21px; background: var(--ink); color: white; text-decoration: none; font-size: 12px; font-weight: 700; }
.book-button.compact { min-height: 42px; padding: 0 17px; border-radius: 24px; }
.icon-button svg { width: 19px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.avatar { background: var(--ink); color: var(--lime); border-color: var(--ink); font-weight: 700; }
main { overflow: hidden; }
.hero { max-width: 1180px; margin: auto; padding: 94px 28px 52px; }
.eyebrow { display: flex; align-items: center; gap: 10px; font-size: 11px; font-weight: 700; letter-spacing: 2.2px; }
.eyebrow > span { width: 25px; height: 2px; background: var(--green); }
.peak100-lockup { display: flex; align-items: baseline; gap: 11px; margin: 23px 0 13px; color: var(--brand-navy); font-family: "Manrope"; }
.peak100-lockup small { font-size: 13px; font-weight: 800; letter-spacing: 2px; writing-mode: vertical-rl; transform: rotate(180deg); }
.peak100-lockup strong { font-size: clamp(34px, 5vw, 58px); line-height: .9; letter-spacing: -3px; }
.peak100-lockup span { max-width: 100px; color: var(--green); font-size: 10px; font-weight: 800; line-height: 1.25; letter-spacing: 1px; }
.hero h1 { max-width: 760px; margin: 18px 0 20px; font: 800 clamp(60px, 9vw, 112px)/.86 "Manrope"; letter-spacing: -7px; text-transform: uppercase; }
.hero h1 em { font-style: normal; color: var(--green); }
.hero p { max-width: 520px; margin: 0; color: var(--muted); font-size: 18px; line-height: 1.65; }
.score-shell { max-width: 1180px; margin: 0 auto 110px; padding: 0 28px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 14px; }
.score-card, .weakest-card { min-height: 225px; border-radius: 4px; }
.score-card { display: flex; align-items: center; justify-content: space-between; padding: 36px 44px; background: var(--ink); color: white; }
.label { display: block; color: #8d978f; font-size: 10px; font-weight: 700; letter-spacing: 1.8px; }
.score-number { margin-top: 4px; display: flex; align-items: baseline; }
.score-number strong { font: 800 74px "Manrope"; letter-spacing: -5px; }
.score-number span { color: #778078; font: 700 21px "Manrope"; }
.rank { color: var(--lime); font-size: 12px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase; }
.score-ring { --score: 0; width: 138px; aspect-ratio: 1; display: grid; place-items: center; border-radius: 50%; background: conic-gradient(var(--lime) calc(var(--score) * 1%), #303932 0); position: relative; }
.score-ring::before { content: ""; position: absolute; inset: 9px; background: var(--ink); border-radius: inherit; }
.score-ring div { position: relative; text-align: center; }
.score-ring strong { display: block; font: 800 34px "Manrope"; line-height: 1; }
.score-ring span { color: #8c968e; font-size: 8px; font-weight: 700; letter-spacing: 1.3px; }
.weakest-card { display: flex; align-items: center; gap: 24px; padding: 36px; background: #e9e4d8; border: 1px solid #d6d0c4; }
.weak-icon { flex: 0 0 54px; height: 54px; display: grid; place-items: center; color: var(--orange); border: 1px solid currentColor; border-radius: 50%; }
.weak-icon svg { width: 24px; fill: none; stroke: currentColor; stroke-width: 1.6; }
.weakest-card strong { display: block; margin: 7px 0 3px; font: 700 25px "Manrope"; }
.weakest-card p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.5; }
.assessment-section, .pillars-section, .exercise-section, .progress-section, .save-section { max-width: 1180px; margin: auto; padding-left: 28px; padding-right: 28px; }
.assessment-section { padding-bottom: 118px; }
.section-heading { display: flex; align-items: flex-end; justify-content: space-between; border-bottom: 1px solid #bbbdb5; padding-bottom: 17px; }
.section-heading > div { display: flex; align-items: baseline; gap: 16px; }
.section-number { color: var(--green); font: 700 11px "Manrope"; letter-spacing: 1.8px; }
h2 { margin: 0; font: 700 35px "Manrope"; letter-spacing: -1.5px; }
.text-button { border: 0; padding: 5px 0; background: none; color: var(--muted); font-size: 12px; text-decoration: underline; text-underline-offset: 4px; }
.section-intro { color: var(--muted); margin: 20px 0 35px; }
.test-tabs { display: grid; grid-template-columns: repeat(5, 1fr); gap: 7px; margin-bottom: 10px; scrollbar-width: none; }
.test-tabs::-webkit-scrollbar { display: none; }
.test-tab { min-height: 60px; padding: 12px; border: 1px solid #d2d4cc; background: rgba(255,255,255,.25); color: #707870; text-align: left; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; transition: .2s; }
.test-tab span { display: block; color: #a3aaa3; font-size: 9px; margin-bottom: 3px; }
.test-tab.active { background: var(--ink); color: white; border-color: var(--ink); }
.test-tab.complete:not(.active) { border-color: var(--green); color: var(--green); }
.test-stage { min-height: 415px; background: var(--paper); border: 1px solid var(--line); display: grid; grid-template-columns: 1.25fr .75fr; }
.challenge-copy { padding: 52px; display: flex; flex-direction: column; justify-content: center; }
.challenge-kicker { color: var(--green); font-size: 11px; font-weight: 700; letter-spacing: 1.6px; }
.challenge-copy h3 { margin: 10px 0 8px; font: 700 38px "Manrope"; letter-spacing: -1.5px; }
.challenge-copy > p { max-width: 500px; min-height: 42px; color: var(--muted); line-height: 1.6; }
.goal-row { display: flex; gap: 26px; margin: 16px 0 27px; }
.goal-row div { padding-right: 26px; border-right: 1px solid var(--line); }
.goal-row div:last-child { border: 0; }
.goal-row span { display: block; color: #8a928b; font-size: 9px; font-weight: 700; letter-spacing: 1.3px; }
.goal-row strong { font: 700 17px "Manrope"; }
.entry-row { display: flex; align-items: stretch; gap: 10px; }
.bilateral-inputs { display: flex; gap: 12px; }
.result-input { max-width: 230px; display: flex; align-items: center; border-bottom: 2px solid var(--ink); }
.result-input input { width: 155px; padding: 8px 0; border: 0; outline: 0; background: transparent; font: 700 42px "Manrope"; }
.result-input span { color: var(--muted); font-size: 12px; font-weight: 700; text-transform: uppercase; }
.side-result { width: 145px; position: relative; padding-top: 13px; }
.side-result small { position: absolute; top: 0; left: 0; color: var(--green); font-size: 8px; font-weight: 800; letter-spacing: 1.2px; }
.side-result input { width: 96px; }
.next-button { padding: 0 25px; border: 0; background: var(--lime); color: var(--ink); font-weight: 700; }
.challenge-score { display: grid; place-items: center; position: relative; overflow: hidden; background: #e6e9e0; border-left: 1px solid var(--line); }
.challenge-score::before { content: ""; position: absolute; width: 300px; height: 300px; border: 1px solid rgba(17,24,20,.1); border-radius: 50%; box-shadow: 0 0 0 45px rgba(17,24,20,.025), 0 0 0 90px rgba(17,24,20,.025); }
.challenge-score div { position: relative; text-align: center; }
.challenge-score strong { display: block; font: 800 90px "Manrope"; letter-spacing: -6px; line-height: .9; }
.challenge-score span { color: var(--muted); font-size: 10px; font-weight: 700; letter-spacing: 1.5px; }
.test-dots { display: flex; justify-content: center; gap: 8px; margin-top: 18px; }
.test-dots span { width: 6px; height: 6px; background: #c3c7bf; border-radius: 50%; }
.test-dots span.active { width: 20px; background: var(--ink); border-radius: 4px; }
.pillars-section { padding-bottom: 110px; }
.goal-pill { padding: 8px 12px; color: var(--green); border: 1px solid var(--green); border-radius: 30px; font-size: 9px; font-weight: 700; letter-spacing: 1.4px; }
.pillar-grid { display: grid; grid-template-columns: repeat(5, 1fr); margin-top: 25px; border: 1px solid var(--line); }
.pillar-card { min-height: 210px; padding: 25px 20px; background: rgba(255,255,255,.3); border-right: 1px solid var(--line); position: relative; transition: .25s; }
.pillar-card:last-child { border: 0; }
.pillar-card .pillar-icon { width: 38px; height: 38px; display: grid; place-items: center; border: 1px solid currentColor; border-radius: 50%; font-weight: 700; }
.pillar-card h3 { margin: 27px 0 2px; font: 700 17px "Manrope"; }
.pillar-card p { margin: 0; color: var(--muted); font-size: 11px; }
.pillar-card .mini-score { position: absolute; left: 20px; bottom: 20px; font: 700 16px "Manrope"; }
.pillar-card .status-dot { position: absolute; right: 20px; bottom: 25px; width: 8px; height: 8px; border-radius: 50%; background: #c8ccc5; }
.pillar-card.green { color: var(--green); background: #e2eee4; }
.pillar-card.yellow { color: #a97800; background: #f3ead1; }
.pillar-card.orange { color: var(--orange); background: #f1e1d6; }
.pillar-card.red { color: var(--red); background: #efdbd6; }
.pillar-card.green .status-dot, .pillar-card.yellow .status-dot, .pillar-card.orange .status-dot, .pillar-card.red .status-dot { background: currentColor; }
.exercise-section { padding-bottom: 110px; }
.exercise-note { color: var(--muted); font-size: 9px; font-weight: 700; letter-spacing: 1.3px; }
.exercise-tabs { display: flex; gap: 7px; overflow-x: auto; margin-bottom: 10px; scrollbar-width: none; }
.exercise-tabs::-webkit-scrollbar { display: none; }
.exercise-tab { min-width: 130px; padding: 14px 16px; border: 1px solid var(--line); background: rgba(255,255,255,.28); color: var(--muted); text-align: left; font-size: 11px; font-weight: 700; text-transform: uppercase; }
.exercise-tab.active { background: var(--ink); border-color: var(--ink); color: white; }
.exercise-tab.recommended::after { content: "YOUR FOCUS"; display: block; margin-top: 5px; color: var(--lime); font-size: 7px; letter-spacing: 1px; }
.exercise-panel { display: grid; grid-template-columns: .65fr 1.35fr; min-height: 355px; background: var(--paper); border: 1px solid var(--line); }
.exercise-intro { padding: 43px 38px; background: var(--ink); color: white; }
.exercise-intro .label { color: var(--lime); }
.exercise-intro h3 { margin: 12px 0 12px; font: 700 31px "Manrope"; }
.exercise-intro p { color: #aab4ad; line-height: 1.65; }
.exercise-intro strong { display: block; margin-top: 28px; color: var(--lime); font-size: 11px; letter-spacing: 1px; }
.exercise-list { display: grid; grid-template-columns: 1fr 1fr; }
.exercise-card { min-height: 175px; padding: 25px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.exercise-card:nth-child(even) { border-right: 0; }
.exercise-card:nth-last-child(-n+2) { border-bottom: 0; }
.exercise-card b { display: grid; place-items: center; width: 27px; height: 27px; border: 1px solid var(--green); border-radius: 50%; color: var(--green); font-size: 10px; }
.exercise-card h4 { margin: 16px 0 6px; font: 700 16px "Manrope"; }
.exercise-card p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.55; }
.exercise-card span { display: block; margin-top: 10px; color: var(--green); font-size: 9px; font-weight: 700; letter-spacing: .7px; text-transform: uppercase; }
.exercise-disclaimer { color: var(--muted); font-size: 10px; text-align: right; }
.progress-section { padding-bottom: 110px; }
.progress-dashboard { margin-top: 25px; }
.progress-empty { min-height: 250px; padding: 48px; display: grid; place-items: center; text-align: center; border: 1px dashed #b9bdb5; background: rgba(255,255,255,.18); }
.progress-empty strong { display: block; font: 700 22px "Manrope"; margin-bottom: 7px; }
.progress-empty p { max-width: 410px; margin: 0; color: var(--muted); line-height: 1.6; }
.progress-grid { display: grid; grid-template-columns: .7fr 1.3fr; gap: 12px; }
.progress-stat { min-height: 275px; padding: 32px; display: flex; flex-direction: column; justify-content: space-between; background: var(--ink); color: white; }
.progress-stat .latest-score { font: 800 72px "Manrope"; letter-spacing: -5px; line-height: 1; }
.progress-stat .latest-score span { color: #69736c; font-size: 22px; letter-spacing: -1px; }
.trend-badge { align-self: flex-start; padding: 7px 11px; border-radius: 20px; background: rgba(201,255,61,.12); color: var(--lime); font-size: 11px; font-weight: 700; }
.trend-badge.down { color: #ff8f7d; background: rgba(255,90,70,.12); }
.trend-badge.flat { color: #b6beb7; background: rgba(255,255,255,.08); }
.progress-chart-card { min-width: 0; padding: 28px 30px; background: var(--paper); border: 1px solid var(--line); }
.chart-head { display: flex; justify-content: space-between; align-items: center; }
.chart-head strong { font: 700 16px "Manrope"; }
.chart-head span { color: var(--muted); font-size: 11px; }
.score-chart { height: 150px; margin-top: 24px; padding-top: 8px; display: flex; align-items: flex-end; gap: 12px; border-bottom: 1px solid #bfc3bc; background: repeating-linear-gradient(to top, transparent 0, transparent 36px, rgba(17,24,20,.06) 37px); }
.chart-column { min-width: 20px; flex: 1; height: 100%; display: flex; align-items: flex-end; justify-content: center; position: relative; }
.chart-bar { width: min(30px, 75%); min-height: 3px; height: calc(var(--value) * 1%); background: var(--green); transition: height .4s; position: relative; }
.chart-column:last-child .chart-bar { background: var(--lime); outline: 1px solid var(--ink); }
.chart-bar::before { content: attr(data-score); position: absolute; left: 50%; top: -19px; transform: translateX(-50%); color: var(--ink); font-size: 9px; font-weight: 700; }
.chart-date { position: absolute; top: calc(100% + 7px); color: var(--muted); white-space: nowrap; font-size: 8px; }
.pillar-trends { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(5, 1fr); border: 1px solid var(--line); }
.pillar-trend { padding: 20px; background: rgba(255,255,255,.28); border-right: 1px solid var(--line); }
.pillar-trend:last-child { border: 0; }
.pillar-trend span { color: var(--muted); font-size: 10px; }
.pillar-trend strong { display: block; margin-top: 5px; font: 700 19px "Manrope"; }
.pillar-trend strong.up { color: var(--green); }
.pillar-trend strong.down { color: var(--red); }
.progress-save-card { margin-top: 14px; padding: 25px 28px; display: grid; grid-template-columns: auto 1fr auto; gap: 19px; align-items: center; background: #e7e4da; border: 1px solid #d1d3ca; }
.progress-save-icon { width: 46px; height: 46px; display: grid; place-items: center; border-radius: 50%; background: var(--ink); color: var(--lime); }
.progress-save-icon svg { width: 21px; fill: none; stroke: currentColor; stroke-width: 1.7; }
.progress-save-card strong { display: block; font: 700 16px "Manrope"; }
.progress-save-card p { margin: 3px 0; color: var(--muted); font-size: 12px; }
.progress-save-card small { color: #899089; font-size: 9px; }
.save-section { margin-bottom: 110px; padding-top: 38px; padding-bottom: 38px; display: flex; align-items: center; justify-content: space-between; border-top: 1px solid #bbbdb5; border-bottom: 1px solid #bbbdb5; }
.save-section h2 { margin-top: 8px; }
.save-section p { margin: 6px 0 0; color: var(--muted); }
.progress-section .save-section { margin: 28px 0 14px; padding-left: 0; padding-right: 0; }
.primary-button, .light-button { display: inline-flex; align-items: center; justify-content: center; gap: 35px; padding: 16px 22px; border: 0; font-weight: 700; }
.primary-button { background: var(--ink); color: white; }
.primary-button svg { width: 18px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.squat-section { max-width: 1124px; min-height: 490px; margin: 0 auto 110px; display: grid; grid-template-columns: 1fr 1fr; background: var(--ink); color: white; }
.squat-copy { padding: 70px 64px; }
.squat-copy .eyebrow { color: var(--lime); }
.squat-copy .eyebrow > span { background: var(--lime); }
.squat-copy h2 { margin: 24px 0 18px; font-size: 44px; line-height: 1.05; }
.squat-copy p { color: #9da79f; line-height: 1.7; }
.light-button { margin-top: 20px; background: var(--lime); color: var(--ink); }
.squat-book-link { display: block; width: fit-content; margin-top: 18px; color: #b5c0b7; font-size: 12px; text-underline-offset: 4px; }
.squat-visual { position: relative; overflow: hidden; background: radial-gradient(circle at 50% 40%, #354137 0, #1a231d 45%, #111814 74%); }
.squat-visual::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(201,255,61,.07) 1px, transparent 1px), linear-gradient(90deg, rgba(201,255,61,.07) 1px, transparent 1px); background-size: 40px 40px; }
.scan-line { position: absolute; z-index: 2; left: 8%; right: 8%; top: 55%; height: 1px; background: var(--lime); box-shadow: 0 0 12px var(--lime); }
.body-figure { position: absolute; left: 50%; top: 50%; width: 180px; height: 300px; transform: translate(-50%,-50%); }
.body-figure span { position: absolute; display: block; background: #657266; border: 1px solid #96a397; box-shadow: inset 0 0 20px rgba(201,255,61,.1); }
.head { width: 48px; height: 57px; left: 66px; top: 5px; border-radius: 48%; }
.torso { width: 74px; height: 110px; left: 54px; top: 62px; border-radius: 35% 35% 22% 22%; transform: rotate(-7deg); }
.arm { width: 30px; height: 130px; top: 75px; border-radius: 20px; transform-origin: top; }
.arm-a { left: 48px; transform: rotate(55deg); }
.arm-b { left: 103px; transform: rotate(61deg); }
.leg { width: 37px; height: 145px; top: 159px; border-radius: 20px; transform-origin: top; }
.leg-a { left: 61px; transform: rotate(42deg); }
.leg-b { left: 90px; transform: rotate(-44deg); }
.scan-label { position: absolute; z-index: 3; padding: 4px 7px; background: var(--lime); color: var(--ink); font-size: 8px; font-weight: 800; letter-spacing: 1px; }
.label-a { left: 12%; top: 35%; }
.label-b { right: 12%; bottom: 20%; }
.corner { position: absolute; width: 35px; height: 35px; border-color: var(--lime); border-style: solid; opacity: .6; }
.corner-a { left: 9%; top: 9%; border-width: 1px 0 0 1px; }.corner-b { right: 9%; top: 9%; border-width: 1px 1px 0 0; }.corner-c { left: 9%; bottom: 9%; border-width: 0 0 1px 1px; }.corner-d { right: 9%; bottom: 9%; border-width: 0 1px 1px 0; }
footer { padding: 45px 28px; background: #0b100d; color: white; text-align: center; }
footer > span { color: var(--lime); font: 800 22px "Manrope"; }
footer p { margin: 7px; color: #8d978f; }
footer small { color: #505952; }
.footer-brand { margin: 13px 0 17px; color: #8190a8; font-size: 9px; font-weight: 700; letter-spacing: 2px; }
.footer-book { display: block; width: fit-content; margin: 0 auto 22px; color: var(--lime); font-size: 12px; font-weight: 700; text-underline-offset: 4px; }
dialog { width: min(560px, calc(100% - 28px)); padding: 0; color: var(--ink); background: var(--paper); border: 0; border-radius: 3px; box-shadow: 0 30px 80px rgba(0,0,0,.35); }
dialog::backdrop { background: rgba(9,14,11,.75); backdrop-filter: blur(4px); }
.dialog-head { display: flex; align-items: center; justify-content: space-between; padding: 28px 30px 22px; border-bottom: 1px solid var(--line); }
.dialog-head h2 { margin-top: 5px; font-size: 27px; }
.close-button { width: 38px; height: 38px; border: 1px solid var(--line); border-radius: 50%; background: transparent; font-size: 25px; font-weight: 300; }
.history-list { max-height: 460px; overflow: auto; padding: 20px 30px 30px; }
.history-empty { padding: 45px 10px; color: var(--muted); text-align: center; }
.history-item { display: grid; grid-template-columns: 1fr auto auto; gap: 18px; align-items: center; padding: 16px 0; border-bottom: 1px solid var(--line); }
.history-item strong { font: 700 20px "Manrope"; }
.history-item span { color: var(--muted); font-size: 12px; }
.history-score { min-width: 55px; text-align: right; color: var(--green) !important; font: 800 21px "Manrope" !important; }
.delete-history { border: 0; background: none; color: var(--red); }
#profileForm { padding-bottom: 30px; }
#profileForm label { display: grid; gap: 8px; margin: 25px 30px; font-size: 12px; font-weight: 700; }
#profileForm input { padding: 14px; border: 1px solid var(--line); background: white; outline: none; font-size: 17px; }
#profileForm .primary-button { margin: 0 30px; width: calc(100% - 60px); }
.squat-steps { padding: 20px 30px 5px; }
.squat-steps > div { display: flex; gap: 14px; margin-bottom: 18px; }
.squat-steps b { flex: 0 0 30px; height: 30px; display: grid; place-items: center; background: var(--lime); border-radius: 50%; }
.squat-steps p { display: grid; margin: 0; }
.squat-steps span { color: var(--muted); font-size: 13px; margin-top: 2px; }
.share-box { margin: 5px 30px 15px; padding: 16px; background: #e9e7df; color: var(--muted); font-size: 13px; line-height: 1.6; }
.video-picker { display: block; margin: 0 30px 12px; padding: 15px 17px; border: 1px dashed #9ca49d; background: white; cursor: pointer; }
.video-picker span { display: block; color: var(--ink); font-size: 13px; font-weight: 700; }
.video-picker small { display: block; margin-top: 3px; color: var(--muted); font-size: 10px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.visually-hidden { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); clip-path: inset(50%); white-space: nowrap; }
#squatDialog .primary-button { width: calc(100% - 60px); margin: 0 30px 10px; }
.contact-options { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; margin: 0 30px 11px; }
.contact-option { min-width: 0; padding: 13px 14px; border: 1px solid var(--line); background: white; color: var(--ink); text-decoration: none; }
.contact-option span { display: block; margin-bottom: 4px; color: var(--green); font-size: 8px; font-weight: 800; letter-spacing: 1px; }
.contact-option strong { display: block; overflow-wrap: anywhere; font-size: 12px; }
.share-fallback-note { margin: 0 30px 27px; color: #899089; font-size: 9px; line-height: 1.45; text-align: center; }
.toast { position: fixed; z-index: 50; left: 50%; bottom: 25px; padding: 13px 20px; background: var(--ink); color: white; border-left: 3px solid var(--lime); transform: translate(-50%, 100px); opacity: 0; transition: .3s; font-size: 13px; }
.toast.show { transform: translate(-50%,0); opacity: 1; }
@media (max-width: 800px) {
  .hero { padding-top: 70px; }
  .hero h1 { font-size: clamp(54px, 16vw, 80px); letter-spacing: -4px; }
  .score-shell, .squat-section, .progress-grid, .exercise-panel { grid-template-columns: 1fr; }
  .score-shell { margin-bottom: 80px; }
  .test-tabs { display: flex; overflow-x: auto; }
  .test-tab { min-width: 145px; }
  .test-stage { grid-template-columns: 1fr; }
  .challenge-copy { padding: 35px 26px; }
  .challenge-score { min-height: 210px; border-left: 0; border-top: 1px solid var(--line); }
  .pillar-grid { grid-template-columns: 1fr 1fr; }
  .pillar-card { border-bottom: 1px solid var(--line); }
  .pillar-card:last-child { grid-column: span 2; }
  .pillar-trends { grid-template-columns: repeat(2, 1fr); }
  .pillar-trend { border-bottom: 1px solid var(--line); }
  .pillar-trend:last-child { grid-column: span 2; }
  .progress-save-card { grid-template-columns: auto 1fr; }
  .progress-save-card .primary-button { grid-column: 1 / -1; width: 100%; }
  .save-section { align-items: flex-start; flex-direction: column; gap: 25px; }
  .squat-section { margin-left: 14px; margin-right: 14px; }
  .squat-copy { padding: 50px 30px; }
  .squat-visual { min-height: 430px; }
}
@media (max-width: 520px) {
  .topbar { height: 70px; padding: 0 18px; }
  .brand-logo-crop { width: 112px; height: 38px; }
  .brand-logo-crop img { width: 112px; }
  .product-wordmark { display: none; }
  .hero { padding: 55px 18px 40px; }
  .hero h1 { font-size: 52px; letter-spacing: -3px; }
  .peak100-lockup strong { font-size: 35px; letter-spacing: -2px; }
  .hero p { font-size: 16px; }
  .score-shell, .assessment-section, .pillars-section, .exercise-section, .progress-section, .save-section { padding-left: 18px; padding-right: 18px; }
  .score-card { padding: 28px 23px; }
  .score-ring { width: 105px; }
  .score-number strong { font-size: 58px; }
  .weakest-card { padding: 27px 23px; }
  .section-heading { align-items: center; }
  .section-heading > div { gap: 9px; }
  h2 { font-size: 26px; }
  .challenge-copy h3 { font-size: 30px; }
  .entry-row { flex-direction: column; }
  .bilateral-inputs { width: 100%; }
  .side-result { flex: 1; width: auto; }
  .side-result input { width: calc(100% - 35px); }
  .next-button { min-height: 50px; }
  .pillar-grid { grid-template-columns: 1fr; }
  .exercise-list { grid-template-columns: 1fr; }
  .exercise-card { border-right: 0; border-bottom: 1px solid var(--line) !important; }
  .exercise-card:last-child { border-bottom: 0 !important; }
  .book-button.compact { padding: 0 13px; }
  .progress-save-card { grid-template-columns: 1fr; text-align: center; }
  .progress-save-icon { margin: auto; }
  .contact-options { grid-template-columns: 1fr; }
  .pillar-card:last-child { grid-column: auto; }
  .pillar-card { min-height: 170px; border-right: 0; }
}
