:root{--bg: #ffffff;--surface: #ffffff;--surface-alt: #f9fafb;--text: #000000;--muted: #4b5563;--accent: #0092d6;--accent-soft: rgba(0, 146, 214, .1);--border: #e5e7eb;--code-bg: #f3f4f6;--keyword: #8b5cf6;--font-mono: "Fira Code", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;--container: 1180px;--radius: 8px}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--text);font-family:var(--font-mono);line-height:1.6;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}@media(max-width:720px){html,body{overflow-x:clip}}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;color:inherit;background:none;border:none;padding:0}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.page{min-height:100vh;display:flex;flex-direction:column}.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 2rem}@media(max-width:720px){.container{padding:0 1.25rem}}.site-header{padding:1.25rem 0;border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:50}.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand{font-weight:600;font-size:1rem;letter-spacing:-.01em;color:var(--text)}.brand .prompt{color:var(--accent);margin-right:.4rem}.nav-toggle{display:none;width:40px;height:40px;border-radius:var(--radius);align-items:center;justify-content:center;color:var(--text);border:1px solid var(--border)}.nav-toggle:hover{background:var(--code-bg)}.nav-links{display:flex;align-items:center;gap:1.5rem;font-size:.95rem}.nav-links a,.nav-links button{color:var(--muted);transition:color .15s;font-size:.95rem}.nav-links a:hover,.nav-links button:hover,.nav-links a.active,.nav-links .nav-dropdown-toggle.active{color:var(--accent)}.nav-dropdown{position:relative}.nav-dropdown-toggle{display:inline-flex;align-items:center;gap:.3rem}.nav-dropdown-toggle .chev{font-size:.7rem;opacity:.7}.nav-dropdown-menu{position:absolute;top:calc(100% + .5rem);right:0;min-width:220px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.4rem 0;box-shadow:0 8px 24px #1f293714;display:flex;flex-direction:column}.nav-dropdown-menu a{padding:.55rem 1rem;color:var(--text);font-size:.9rem}.nav-dropdown-menu a{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.nav-dropdown-menu a:hover,.nav-dropdown-menu a.active{background:var(--accent-soft);color:var(--accent)}.menu-badge{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:.1rem .45rem;border-radius:999px;background:#16a34a;color:#fff}.main{flex:1;padding:3rem 0 4rem}@media(max-width:720px){.main{padding:1.5rem 0 3rem}}.site-footer{border-top:1px solid var(--border);padding:2rem 0;color:var(--muted);font-size:.85rem}.footer-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.footer-links{display:flex;gap:1rem}.footer-links a:hover{color:var(--accent)}.section{margin-bottom:3.5rem}.section-heading{font-size:1.1rem;font-weight:600;margin-bottom:1.25rem;color:var(--text);display:flex;align-items:baseline;gap:.5rem}.section-heading .prompt{color:var(--accent)}.section-intro{color:var(--muted);margin-bottom:1.75rem;max-width:640px}.hero{display:grid;grid-template-columns:88px 1fr;grid-template-areas:"portrait name" "portrait submob" "tagline tagline" "meta meta";grid-template-rows:auto auto auto auto;gap:.15rem 1rem;align-items:center;margin-bottom:2rem}.hero h1{grid-area:name;align-self:end;margin-bottom:0}.hero .subtitle-mobile{grid-area:submob;align-self:start;color:var(--muted);font-size:.8rem;line-height:1.3;margin:0;min-width:0}.hero .tagline{grid-area:tagline;margin-top:.75rem;min-width:0}.hero .meta{grid-area:meta}.hero .portrait{grid-area:portrait;align-self:center}@media(min-width:720px){.hero{grid-template-columns:1fr 220px;grid-template-areas:"name portrait" "submob portrait" "tagline portrait" "meta portrait";gap:.4rem 2rem;align-items:center;margin-bottom:3rem}.hero h1{align-self:end}.hero .subtitle-mobile{font-size:.95rem}.hero .tagline{margin-top:.75rem}.hero .meta{align-self:start;margin-top:.5rem}.hero .portrait{align-self:center}}.hero h1{font-size:clamp(1.75rem,6vw,2.75rem);font-weight:700;line-height:1.15;letter-spacing:-.02em;margin-bottom:0;color:var(--text)}.hero .tagline{color:var(--muted);font-size:clamp(.95rem,2vw,1rem);margin-bottom:1.25rem;max-width:560px}.hero .meta{display:flex;gap:.5rem;flex-wrap:wrap;font-size:.85rem;color:var(--muted)}.hero .meta .chip{border:1px solid var(--border);padding:.25rem .6rem;border-radius:999px;background:var(--surface)}.portrait{width:88px;height:88px;border-radius:50%;overflow:hidden;border:1px solid var(--border);background:var(--code-bg);justify-self:start}@media(min-width:720px){.portrait{width:220px;height:220px;justify-self:end}}.portrait img{width:100%;height:100%;object-fit:cover}.currently{display:inline-block;padding:.5rem .95rem;background:var(--accent-soft);border-radius:var(--radius);font-size:.9rem;color:var(--text);margin-bottom:3rem;max-width:100%;line-height:1.55}.currently .label{color:var(--accent);font-weight:600}.currently a{color:var(--accent);border-bottom:1px dashed var(--accent)}.currently a:hover{border-bottom-style:solid}@media(max-width:720px){.currently{display:block;border-radius:var(--radius);margin-bottom:2rem}}.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem 1rem;margin-bottom:3.5rem;padding:1.5rem 1.25rem;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius)}@media(min-width:720px){.stats{grid-template-columns:repeat(4,1fr);padding:1.75rem 1.5rem}}.stat .number{font-size:clamp(1.4rem,4vw,2rem);font-weight:700;color:var(--accent);line-height:1.1;letter-spacing:-.02em}.stat .label{color:var(--muted);font-size:.85rem;margin-top:.25rem}.card-grid{display:grid;gap:1rem;grid-template-columns:1fr}@media(min-width:640px){.card-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:960px){.card-grid.three{grid-template-columns:repeat(3,1fr)}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:.6rem;transition:border-color .15s,transform .15s}a.card:hover,.card.linked:hover{border-color:var(--accent)}.card h3,.card .card-title{font-size:1rem;font-weight:600;color:var(--text)}.card .desc{color:var(--muted);font-size:.9rem;flex:1}.card .chips{display:flex;flex-wrap:wrap;gap:.4rem;font-size:.75rem;color:var(--muted)}.card .chips span{border:1px solid var(--border);border-radius:999px;padding:.15rem .55rem}.card .card-actions{display:flex;gap:.75rem;margin-top:auto;padding-top:.25rem}.btn{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;font-weight:500;color:var(--accent);border:1px solid var(--accent);background:transparent;padding:.5rem .9rem;border-radius:var(--radius);transition:background .15s,color .15s}.btn:hover{background:var(--accent);color:var(--surface)}.btn.ghost{border-color:var(--border);color:var(--muted)}.btn.ghost:hover{background:var(--code-bg);color:var(--text)}.app-card{flex-direction:row;gap:1rem;align-items:flex-start}.app-card .logo{width:60px;height:60px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.app-card .logo img{max-width:100%;max-height:100%;object-fit:contain}.app-card .app-body{display:flex;flex-direction:column;gap:.5rem;flex:1}.app-card .btn{font-size:.8rem;padding:.3rem .7rem}.playlist-card{padding:0;overflow:hidden}.playlist-card .thumb{aspect-ratio:16 / 9;background:var(--code-bg);border-bottom:1px solid var(--border)}.playlist-card .thumb img{width:100%;height:100%;object-fit:cover}.playlist-card .pad{padding:1rem 1.25rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.playlist-embed{position:relative;width:100%;aspect-ratio:16 / 9;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--code-bg)}.playlist-embed iframe{width:100%;height:100%;border:0;display:block}.video-card{padding:0;overflow:hidden}button.video-card{appearance:none;font:inherit;color:inherit;text-align:left;cursor:pointer;width:100%}.video-card:hover{border-color:var(--accent)}.video-card .thumb{aspect-ratio:16 / 9;background:var(--code-bg);position:relative}.video-card .thumb img{width:100%;height:100%;object-fit:cover}.video-card .play-badge{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;background:#00000040;opacity:0;transition:opacity .15s;pointer-events:none}.video-card:hover .play-badge,.video-card:focus-visible .play-badge{opacity:1}.video-card .body{padding:.75rem 1rem 1rem;display:flex;flex-direction:column;gap:.5rem}.video-card h4{font-size:.9rem;font-weight:600;color:var(--text)}.video-modal{position:fixed;inset:0;z-index:100;background:#000000b3;display:flex;align-items:center;justify-content:center;padding:1rem}.video-modal-content{position:relative;width:min(960px,100%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 20px 60px #0006}.video-modal-close{position:absolute;top:.5rem;right:.5rem;z-index:2;width:2rem;height:2rem;border-radius:50%;border:1px solid var(--border);background:#0009;color:#fff;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.video-modal-close:hover{border-color:var(--accent)}.video-modal-frame{position:relative;width:100%;aspect-ratio:16 / 9;background:#000}.video-modal-frame iframe{width:100%;height:100%;border:0;display:block}.video-modal-meta{padding:.85rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.video-modal-meta h3{font-size:.95rem;font-weight:600;color:var(--text);margin:0}.video-modal-yt-link{font-size:.85rem;color:var(--muted);white-space:nowrap}.video-modal-yt-link:hover{color:var(--accent)}.about p{color:var(--text);max-width:640px;margin-bottom:1rem}.about .links{color:var(--accent)}.about .links a{border-bottom:1px dashed var(--accent)}.about .links a:hover{border-bottom-style:solid}.keyword{color:var(--keyword)}.code-block{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1rem;overflow-x:auto;font-family:var(--font-mono);font-size:.9rem;line-height:1.6;color:var(--text);max-width:100%}.code-block code{display:block;white-space:pre}.code-block .str{color:#16a34a}.code-block .key{color:var(--accent)}.skill-pills{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.skill-pills span{background:var(--surface-alt);border:1px solid var(--border);padding:.35rem .8rem;border-radius:999px;font-size:.85rem;color:var(--text)}.platform-logo{display:block;height:48px;width:auto;max-width:280px;margin-bottom:1.25rem;object-fit:contain}.platform-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media(min-width:720px){.platform-grid{grid-template-columns:repeat(4,1fr)}}.platform-tile{display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem 1rem;min-height:110px;transition:border-color .15s,box-shadow .15s}.platform-tile:hover{border-color:var(--accent);box-shadow:0 4px 14px #0092d614}.platform-tile .platform-logo{margin:0;max-width:100%}.contact .email{display:inline-block;font-size:1.1rem;color:var(--accent);border-bottom:1px dashed var(--accent);margin-bottom:1rem}.contact .email.plain{color:var(--text);border-bottom:none}.contact .email.plain:hover{color:var(--accent)}.contact .socials{display:flex;flex-direction:column;gap:.4rem;color:var(--muted)}.contact .socials a:hover{color:var(--accent)}.back-link{display:inline-block;color:var(--muted);font-size:.85rem;margin-bottom:1.5rem}.back-link:hover{color:var(--accent)}@media(max-width:720px){.nav-toggle{display:inline-flex}.nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:0 8px 24px #1f29370f;padding:.5rem 0}.nav-links.open{display:flex}.nav-links>a,.nav-links>.nav-dropdown>.nav-dropdown-toggle{padding:.75rem 1.25rem}.nav-dropdown-menu{position:static;box-shadow:none;border:none;border-top:1px solid var(--border);border-radius:0;background:var(--code-bg);padding:0}.nav-dropdown-menu a{padding-left:2.25rem}.site-header{position:relative}}.quiz-section{max-width:720px;margin-left:auto;margin-right:auto}.quiz-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem 1.75rem;display:flex;flex-direction:column;gap:1.25rem}@media(max-width:720px){.quiz-card{padding:1.5rem 1.25rem}}.quiz-eyebrow{font-size:.8rem;color:var(--muted);text-transform:lowercase;letter-spacing:.02em}.quiz-topic{color:var(--accent)}.quiz-title,.quiz-question{font-size:1.2rem;font-weight:600;color:var(--text);line-height:1.4}.quiz-sub{color:var(--muted);font-size:.95rem}.quiz-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin:.5rem 0 .25rem}.quiz-stat{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;text-align:center}.quiz-stat .num{font-size:1.15rem;font-weight:700;color:var(--accent)}.quiz-stat .lbl{font-size:.75rem;color:var(--muted);margin-top:.15rem}.quiz-top-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.quiz-exit{font-size:.8rem;color:var(--muted);padding:.25rem .5rem;border-radius:var(--radius);transition:color .15s,background .15s}.quiz-exit:hover{color:var(--accent);background:var(--accent-soft)}.quiz-progress{display:flex;gap:.4rem;font-size:.95rem}.quiz-dot{display:inline-block}.quiz-options{display:flex;flex-direction:column;gap:.6rem}.quiz-option{display:flex;align-items:center;gap:.85rem;width:100%;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;font-size:.95rem;color:var(--text);transition:border-color .15s,background .15s,transform .05s}.quiz-option:not(:disabled):hover{border-color:var(--accent);background:var(--accent-soft)}.quiz-option:not(:disabled):active{transform:translateY(1px)}.quiz-option-letter{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--code-bg);color:var(--muted);font-size:.8rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.quiz-option-text{flex:1;line-height:1.4}.quiz-option.correct{border-color:#16a34a;background:#16a34a14;color:var(--text)}.quiz-option.correct .quiz-option-letter{background:#16a34a;color:#fff}.quiz-option.wrong{border-color:#dc2626;background:#dc262614}.quiz-option.wrong .quiz-option-letter{background:#dc2626;color:#fff}.quiz-option.dim{opacity:.55}.quiz-option:disabled{cursor:default}.quiz-feedback{font-size:.95rem;padding:.7rem .9rem;border-radius:var(--radius);border:1px solid var(--border)}.quiz-feedback.good{background:#16a34a14;border-color:#16a34a59;color:#15803d}.quiz-feedback.bad{background:#dc262614;border-color:#dc262659;color:#b91c1c}.quiz-cta{align-self:flex-start;font-size:.95rem}.quiz-actions{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center}.quiz-actions .quiz-cta{align-self:auto}.quiz-actions .btn:disabled{opacity:.5;cursor:not-allowed}.quiz-result-emoji{font-size:4rem;line-height:1;text-align:center}.quiz-result-title{font-size:1.35rem;font-weight:700;color:var(--text);text-align:center;line-height:1.3}.quiz-result-message{color:var(--muted);text-align:center;font-size:.95rem}.quiz-score{text-align:center;color:var(--text);font-size:1rem}.quiz-score strong{color:var(--accent);font-size:1.1rem}.quiz-new-best{color:#16a34a;font-weight:600}.quiz-best-note{color:var(--muted)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.cta-card{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.25rem;padding:1.5rem;background:var(--accent-soft);border:1px solid var(--border);border-radius:var(--radius)}.cta-card-body{flex:1 1 320px;min-width:0}.cta-card-title{font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:.35rem}.cta-card-text{color:var(--muted);font-size:.9rem;margin:0;max-width:60ch}.cta-card-actions{flex-shrink:0}.offerings-table-wrap{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden}.offerings-table{width:100%;border-collapse:collapse;font-size:.9rem}.offerings-table thead th{text-align:left;font-weight:600;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;padding:.85rem 1rem;background:var(--surface-alt);border-bottom:1px solid var(--border)}.offerings-table tbody td{padding:.9rem 1rem;border-top:1px solid var(--border);color:var(--text);vertical-align:middle}.offerings-table tbody tr:first-child td{border-top:none}.offerings-table .offerings-action-col{text-align:right;width:1%;white-space:nowrap}.offerings-table .btn{font-size:.8rem;padding:.35rem .75rem}@media(max-width:720px){.offerings-table-wrap{border:none;background:transparent;overflow:visible}.offerings-table,.offerings-table thead,.offerings-table tbody,.offerings-table tr,.offerings-table td{display:block;width:100%}.offerings-table thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.offerings-table tbody tr{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;margin-bottom:.85rem}.offerings-table tbody tr:last-child{margin-bottom:0}.offerings-table tbody td{border-top:none;padding:.2rem 0}.offerings-table tbody td[data-label]:before{content:attr(data-label);display:block;color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.1rem}.offerings-table tbody td[data-label=""]:before{content:none}.offerings-table .offerings-action-col{text-align:left;width:auto;padding-top:.6rem}}.faq-list{display:flex;flex-direction:column;gap:.6rem}.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.4rem 1rem}.faq-item summary{cursor:pointer;padding:.65rem 0;font-size:.95rem;font-weight:600;color:var(--text);list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1rem}.faq-item summary::-webkit-details-marker{display:none}.faq-item summary:after{content:"+";color:var(--accent);font-weight:700;font-size:1.1rem;flex-shrink:0}.faq-item[open] summary:after{content:"−"}.faq-item p{color:var(--muted);font-size:.9rem;padding:0 0 .85rem;margin:0;max-width:70ch}
