.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:root,:host{--font-sans:"Inter", ui-sans-serif, system-ui, sans-serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--ease-out:cubic-bezier(0, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.relative{position:relative}.flex{display:flex}.uppercase{text-transform:uppercase}.italic{font-style:italic}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}@font-face{font-family:Fraunces;font-style:normal;font-weight:300 700;font-display:swap;src:url(/fonts/fraunces-normal-latin.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fraunces;font-style:normal;font-weight:300 700;font-display:swap;src:url(/fonts/fraunces-normal-latin-ext.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces;font-style:italic;font-weight:300 600;font-display:swap;src:url(/fonts/fraunces-italic-latin.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fraunces;font-style:italic;font-weight:300 600;font-display:swap;src:url(/fonts/fraunces-italic-latin-ext.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:300 700;font-display:swap;src:url(/fonts/inter-normal-latin.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:300 700;font-display:swap;src:url(/fonts/inter-normal-latin-ext.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}:root{--paper:#f7f2e7;--paper-raised:#fcf8ef;--paper-sunken:#efe8d8;--paper-edge:#e4dac6;--ink:#2b2622;--ink-soft:#4a433b;--ink-muted:#857c6e;--ink-faint:#b8ae9c;--ok:#15803d;--warn:#b45309;--err:#b91c1c;--focus:#1e3a8a;--app-accent:#1e3a8a;--app-accent-2:#dc2626;--app-ink:#f7f2e7;--app-bg:beige;--r-sm:8px;--r-md:14px;--r-lg:22px;--r-pill:999px;--e-sm:0 1px 2px #2b26220f, 0 1px 1px #2b26220a;--e-md:0 4px 12px #2b262214, 0 2px 4px #2b26220d;--e-lg:0 12px 32px #2b26221f, 0 4px 8px #2b26220f;--e-xl:0 24px 60px #2b262229;--container:1200px;--ease-out:cubic-bezier(.22, 1, .36, 1)}[data-app=us-presidents]{--app-accent:#1e3a8a;--app-accent-2:#dc2626;--app-ink:#f7f2e7;--app-bg:beige}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-family:Inter,system-ui,sans-serif;font-size:16px;line-height:1.65}.wrap{max-width:var(--container);margin:0 auto;padding:0 32px}a{color:inherit;text-decoration:none}:focus-visible{outline:2px solid var(--focus);outline-offset:2px}h1,h2,h3,.serif{font-optical-sizing:auto;font-family:Fraunces,Georgia,serif}.eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);font:600 .75rem/1 Inter,sans-serif}.display{letter-spacing:-.02em;font-family:Fraunces,serif;font-size:clamp(2.75rem,6vw,4.5rem);font-weight:600;line-height:1.02}.lead{color:var(--ink-soft);max-width:56ch;font-size:clamp(1.125rem,1.6vw,1.375rem);line-height:1.5}.site-header{z-index:50;-webkit-backdrop-filter:saturate(140%)blur(8px);backdrop-filter:saturate(140%)blur(8px);background:#f7f2e7d9;border-bottom:1px solid #0000;position:sticky;top:0}.site-header.scrolled{border-bottom-color:var(--paper-edge)}.site-header .wrap{justify-content:space-between;align-items:center;height:76px;display:flex}.logo{align-items:center;font-family:Fraunces,serif;display:flex}.logo .logo-mark{border-radius:7px;width:30px;height:30px;margin-right:11px;display:block}.logo .q{letter-spacing:-.02em;color:var(--ink);font-size:1.6rem;font-weight:600}.logo .by{color:var(--ink-muted);letter-spacing:.02em;margin-left:10px;font:500 .78rem/1 Inter,sans-serif}.logo .dot{color:#ff4d2e;font-weight:700}.nav{align-items:center;gap:32px;display:flex}.nav .links{gap:32px;display:flex}.nav a{color:var(--ink-soft);padding:4px 0;font:500 .95rem/1 Inter,sans-serif;position:relative}.nav a:after{content:"";background:var(--ink);width:0;height:1.5px;transition:width .18s var(--ease-out);position:absolute;bottom:-2px;left:0}.nav a:hover{color:var(--ink)}.nav a:hover:after{width:100%}.nav .cta{background:var(--ink);color:var(--paper);border-radius:var(--r-pill);padding:9px 18px;font-size:.9rem;font-weight:600}.nav .cta:after{display:none}.site-footer{background:var(--paper-sunken);border-top:1px solid var(--paper-edge);margin-top:96px;padding:64px 0 40px}.footer-grid{grid-template-columns:2fr 1fr 1fr 1.4fr;gap:40px;display:grid}.footer-grid h4{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:16px;font:600 .8rem/1 Inter,sans-serif}.footer-grid ul{gap:10px;list-style:none;display:grid}.footer-grid a{color:var(--ink-soft);font-size:.95rem}.footer-grid a:hover{color:var(--ink)}.footer-tag{color:var(--ink-soft);max-width:30ch;margin-top:14px;font-size:.95rem}.powered{color:var(--ink-muted);align-items:center;gap:8px;margin-top:18px;font-size:.85rem;display:inline-flex}.powered b{color:var(--ink-soft);font-weight:600}.footer-base{border-top:1px solid var(--paper-edge);color:var(--ink-muted);flex-wrap:wrap;justify-content:space-between;gap:24px;margin-top:48px;padding-top:24px;font-size:.82rem;display:flex}.features{gap:80px;padding:88px 0 32px;display:grid}.feature{grid-template-columns:1fr 1fr;align-items:center;gap:56px;display:grid}.feature:nth-child(2n) .ficon-col{order:2}.feature .num{color:var(--app-accent);font-family:Fraunces,serif;font-size:3rem;font-weight:300;line-height:1}.feature h3{margin:10px 0 12px;font-size:1.6rem}.feature p{color:var(--ink-soft);max-width:46ch}.feature-media{aspect-ratio:4/3;border-radius:var(--r-lg);background:var(--paper-sunken);border:1px solid var(--paper-edge);box-shadow:var(--e-md);justify-content:center;align-items:center;display:flex}.feature-media .big{color:var(--app-accent);font-family:Fraunces,serif;font-size:clamp(2rem,5vw,3.4rem);font-weight:600}.feature-media .sub{color:var(--ink-muted);margin-top:6px;font-size:.85rem}.feature-media .center{text-align:center}.attribution{padding:72px 0}.attribution .box{background:var(--paper-raised);border:1px solid var(--paper-edge);border-radius:var(--r-md);box-shadow:var(--e-sm);padding:32px 36px}.attribution .powered{margin:0 0 14px;font-size:1.05rem}.attribution h4{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:12px;font:600 .8rem/1 Inter,sans-serif}.attribution ul{columns:2;gap:40px;list-style:none}.attribution li{color:var(--ink-muted);margin-bottom:8px;font-family:ui-monospace,Menlo,monospace;font-size:.85rem}.attribution li b{color:var(--ink-soft);font-family:Inter}.device{width:286px;height:600px;box-shadow:var(--e-xl),0 0 0 2px #ffffff0f inset;background:#0d0d10;border-radius:46px;padding:11px;position:relative}.device .notch{border-radius:var(--r-pill);z-index:3;background:#0d0d10;width:96px;height:26px;position:absolute;top:22px;left:50%;transform:translate(-50%)}.screen{background:beige;border-radius:36px;width:100%;height:100%;position:relative;overflow:hidden}.app-screen{color:#1f2937;flex-direction:column;width:100%;height:100%;font-family:Inter;display:flex}.app-screen .top{justify-content:space-between;align-items:center;padding:40px 18px 10px;display:flex}.app-screen .top .streak{color:#dc2626;font:600 .8rem/1 Inter}.app-screen .top .hint{color:#1e3a8a;font:600 .8rem/1 Inter}.app-screen .qwrap{flex-direction:column;flex:1;padding:6px 18px;display:flex}.app-screen .qnum{letter-spacing:.1em;text-transform:uppercase;color:#857c6e;margin-bottom:10px;font:600 .7rem/1 Inter}.app-screen .qtext{color:#1e3a8a;margin-bottom:18px;font-family:Fraunces,serif;font-size:1.18rem;font-weight:600;line-height:1.25}.app-screen .opt{background:#fff;border:1.5px solid #e4dac6;border-radius:12px;margin-bottom:10px;padding:12px 14px;font-size:.92rem}.app-screen .opt.correct{color:beige;background:#1e3a8a;border-color:#1e3a8a}.app-screen .opt.wrong{color:#dc2626;border-color:#dc2626}.app-screen .ring{border:3px solid #e5c547;border-radius:50%;width:34px;height:34px;position:absolute;top:36px;right:16px}.app-screen .foot{text-align:center;color:#857c6e;padding:12px 18px 22px;font:500 .62rem/1 Inter}.v2-hero{padding-top:40px;position:relative;overflow:hidden}.v2-hero .wrap{grid-template-columns:1fr 1.05fr;align-items:center;gap:32px;min-height:660px;display:grid}.v2-hero .copy{padding:40px 0}.v2-hero .eyebrow{color:var(--app-accent);margin-bottom:18px}.v2-hero .display{max-width:13ch;margin-bottom:14px}.v2-hero .display em{color:var(--app-accent);font-style:italic}.v2-hero .tagline{color:var(--ink-soft);margin-bottom:16px;font-family:Fraunces,serif;font-size:1.4rem;font-style:italic}.v2-hero .lead{margin-bottom:28px}.v2-hero .bg-wash{opacity:.1;pointer-events:none;background-position:50%;background-repeat:no-repeat;background-size:contain;width:62%;height:120%;position:absolute;top:-10%;right:-8%}.v2-hero .meta{color:var(--ink-muted);flex-wrap:wrap;gap:22px;margin-top:18px;font-size:.85rem;display:flex}.v2-hero .meta b{color:var(--ink);font-weight:600}.badges{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.badge{border-radius:var(--r-md);background:var(--ink);color:var(--paper);border:none;align-items:center;gap:10px;padding:11px 18px;font-family:Inter;display:flex}.badge.disabled{background:var(--paper-sunken);color:var(--ink-muted)}.badge .glyph{font-size:1.3rem}.badge small{letter-spacing:.08em;text-transform:uppercase;opacity:.85;font-size:.62rem;display:block}.badge b{font-size:1rem;font-weight:600}.pcluster{justify-content:center;align-items:flex-end;display:flex;position:relative}.pcluster .device{border-radius:38px;width:226px;height:474px}.pcluster .device .notch{width:78px;height:22px;top:18px}.pcluster .device .screen{border-radius:29px}.pcluster .device.left{z-index:1;box-shadow:var(--e-lg);margin-right:-34px;transform:translateY(-26px)}.pcluster .device.center{z-index:3;box-shadow:var(--e-xl);transform:scale(1.08)}.pcluster .device.right{z-index:1;box-shadow:var(--e-lg);margin-left:-34px;transform:translateY(-26px)}.showcase{padding:88px 0 32px}.showcase .head{text-align:center;margin-bottom:44px}.showcase .head h2{font-size:clamp(1.6rem,3vw,2.2rem)}.showcase .head p{color:var(--ink-muted);margin-top:8px}.prow{scroll-snap-type:x mandatory;justify-content:center;gap:26px;padding:8px 4px 24px;display:flex;overflow-x:auto}.prow .device{scroll-snap-align:center;width:220px;height:462px;box-shadow:var(--e-lg);flex:none}.prow .device .notch{width:78px;height:22px;top:18px}.prow .device .screen{border-radius:29px}.pitem{flex-direction:column;align-items:center;display:flex}.pitem .cap{text-align:center;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted);margin-top:14px;font:600 .78rem/1 Inter}.next{background:var(--paper-sunken);border-top:1px solid var(--paper-edge);border-bottom:1px solid var(--paper-edge);margin-top:72px;padding:56px 0}.next .inner{text-align:center}.next h3{margin-bottom:8px;font-size:1.6rem}.next p{color:var(--ink-soft);max-width:52ch;margin:0 auto 28px}.next .chips{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.next .nchip{background:var(--paper-raised);border:1px solid var(--paper-edge);border-radius:var(--r-pill);box-shadow:var(--e-sm);align-items:center;gap:12px;padding:8px 18px 8px 8px;display:flex}.next .nchip .thumb{background-position:50%;background-size:cover;background-color:var(--app-accent);border-radius:50%;width:40px;height:40px}.next .nchip b{font-family:Fraunces,serif;font-size:.98rem}.next .nchip small{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);font-size:.68rem;display:block}.about-person{align-items:flex-start;gap:32px;display:flex}.about-photo{border-radius:var(--r-lg);object-fit:cover;width:200px;height:200px;box-shadow:var(--e-md);border:1px solid var(--paper-edge);flex:none}@media(max-width:720px){.about-person{text-align:center;flex-direction:column;align-items:center}.about-photo{width:160px;height:160px}}html.js .reveal{opacity:0;transition:opacity .36s var(--ease-out),transform .36s var(--ease-out);transform:translateY(16px)}html.js .reveal.in{opacity:1;transform:none}@media(max-width:900px){body{overflow-x:hidden}.v2-hero .wrap{grid-template-columns:1fr;gap:8px;min-height:auto}.v2-hero .copy{text-align:center;padding-bottom:8px}.v2-hero .display,.v2-hero .lead{margin-left:auto;margin-right:auto}.v2-hero .badges,.v2-hero .meta{justify-content:center}.pcluster .device.left,.pcluster .device.right{display:none}.pcluster .device.center{margin:0 0 8px;transform:none}.feature,.feature:nth-child(2n) .ficon-col{order:0;grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.nav .links{display:none}}@media(prefers-reduced-motion:reduce){*,:before,:after{transition:none!important;animation:none!important}.reveal{opacity:1;transform:none}html{scroll-behavior:auto}}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
