@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";@layer components;@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--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 utilities{.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.hidden{display:none}.inline{display:inline}.resize{resize:both}}:root{--bg:#fff;--panel:#fff;--text:#111827;--muted:#6b7280;--soft:#f3f4f6;--line:#e5e7eb;--bubble:#f3f4f6;--accent:#6366f1;--logo-bg:#111827;--logo-fg:#fff;--spotify-main-height:352px;--spotify-row-height:79px;--spotify-gap:12px;--edge-start:#fff}:root.dark{--bg:#111827;--panel:#1f2937;--text:#f9fafb;--muted:#9ca3af;--soft:#1f2937;--line:#374151;--bubble:#1f2937;--accent:#818cf8;--logo-bg:#f9fafb;--logo-fg:#111827;--edge-start:#111827;color-scheme:dark}*{box-sizing:border-box}html{color-scheme:light}body{background:var(--bg);color:var(--muted);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5;transition:background-color .18s,color .18s}a{color:inherit;text-decoration:none}button{font:inherit;border:0}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;padding:0;position:absolute;overflow:hidden}.page-shell{width:min(100%,672px);min-height:100vh;margin:0 auto;padding:0 16px 32px}.site-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:space-between;align-items:center;gap:16px;padding:16px 0;display:flex}.logo-link,.theme-button{border-radius:10px;flex:0 0 32px;place-items:center;width:32px;height:32px;display:grid}.logo-mark{background:var(--logo-bg);width:32px;height:32px;color:var(--logo-fg);border-radius:999px;place-items:center;font-size:13px;font-weight:800;display:grid}.main-nav{align-items:center;gap:4px;min-width:0;display:flex;overflow-x:auto}.main-nav a{min-height:36px;color:var(--muted);white-space:nowrap;border-radius:10px;align-items:center;padding:8px 12px;font-size:14px;font-weight:500;transition:color .16s,background .16s;display:inline-flex;position:relative}.main-nav a:hover,.main-nav a.active{background:var(--bubble);color:var(--text)}.theme-button{color:var(--muted);cursor:pointer;background:0 0}.theme-button:hover{background:var(--bubble);color:var(--text)}.theme-icon{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:20px;height:20px}.theme-icon-sun,:root.dark .theme-icon-moon{display:none}:root.dark .theme-icon-sun{display:block}main{padding:24px 0}.intro-section{padding:0 0 28px}h1,h2,h3{color:var(--text);letter-spacing:-.025em;margin:0}h1{font-size:clamp(24px,5vw,30px);font-weight:800;line-height:1.2}.intro-section p{max-width:620px;color:var(--muted);margin:14px 0 0;font-size:clamp(14px,2.5vw,16px);line-height:1.65}.home-section{padding:28px 0}.about-hero{padding:24px 0 34px}.about-hero>p{color:var(--muted);margin:4px 0 0;font-size:16px}.about-photo-stack{perspective:1200px;height:270px;margin:42px calc(50% - 50vw) 38px;position:relative;overflow:visible}.about-photo-card{aspect-ratio:4/5;opacity:0;width:min(210px,31vw);transform-style:preserve-3d;background:0 0;transition:transform .22s,z-index .22s,box-shadow .22s;animation:.82s cubic-bezier(.16,1,.3,1) forwards photoArrive;position:absolute;top:26px;left:50%}.about-photo-inner{width:100%;height:100%;transform-style:preserve-3d;border-radius:10px;transition:transform .52s cubic-bezier(.22,1,.36,1);position:relative;box-shadow:0 22px 44px #0000003d}.about-photo-front,.about-photo-back{backface-visibility:hidden;border-radius:10px;position:absolute;inset:0;overflow:hidden}.about-photo-front{background:var(--soft)}.about-photo-front img{object-fit:cover;width:100%;height:100%}.about-photo-four .about-photo-front img{object-position:center 44%}.about-photo-back{color:#1f2937;background:#f9fafb;flex-direction:column;justify-content:flex-end;gap:5px;padding:16px;display:flex;transform:rotateY(180deg)}:root.dark .about-photo-back{background:linear-gradient(135deg,#111827eb,#312e81e0),var(--text);color:#fff}.about-photo-card:hover,.about-photo-card:focus-within{z-index:20}.about-photo-card:hover .about-photo-inner,.about-photo-card:focus-within .about-photo-inner{transform:rotateY(180deg);box-shadow:0 28px 58px #00000057}.about-photo-back span,.about-photo-back strong,.about-photo-back p{text-shadow:none;margin:0}.about-photo-back span{color:#1f29379e;text-transform:uppercase;font-size:11px;font-weight:600}:root.dark .about-photo-back span{color:#ffffffbd}.about-photo-back strong{font-size:13px;line-height:1.25}.about-photo-back p{color:#1f2937c2;font-size:12px;line-height:1.35}:root.dark .about-photo-back p{color:#ffffffe0}.about-photo-one{z-index:1;--photo-x:-315px;--photo-r:-7deg;--hover-r:-4deg;transform:translate(-315px)rotate(-7deg)}.about-photo-two{z-index:2;--photo-x:-190px;--photo-r:4deg;--hover-r:2deg;animation-delay:.12s;transform:translate(-190px)rotate(4deg)}.about-photo-three{z-index:3;--photo-x:-50%;--photo-r:-2deg;--hover-r:0deg;animation-delay:.24s;top:5px;transform:translate(-50%)rotate(-2deg)}.about-photo-four{z-index:5;--photo-x:55px;--photo-r:5deg;--hover-r:2deg;animation-delay:.36s;transform:translate(55px)rotate(5deg)}.about-photo-five{z-index:6;--photo-x:175px;--photo-r:-4deg;--hover-r:-2deg;animation-delay:.48s;transform:translate(175px)rotate(-4deg)}.about-photo-one:hover,.about-photo-one:focus-within{transform:translate(-315px)rotate(-4deg)translateY(-10px)}.about-photo-two:hover,.about-photo-two:focus-within{transform:translate(-190px)rotate(2deg)translateY(-10px)}.about-photo-three:hover,.about-photo-three:focus-within{transform:translate(-50%)rotate(0)translateY(-10px)}.about-photo-four:hover,.about-photo-four:focus-within{transform:translate(55px)rotate(2deg)translateY(-10px)}.about-photo-five:hover,.about-photo-five:focus-within{transform:translate(175px)rotate(-2deg)translateY(-10px)}.about-timeline{grid-template-columns:140px minmax(0,1fr);gap:28px;padding:18px 0 30px;display:grid}.timeline-list{gap:26px;padding-left:22px;display:grid;position:relative}.timeline-list:before{background:var(--line);content:"";width:1px;position:absolute;top:3px;bottom:3px;left:5px}.timeline-item{grid-template-columns:minmax(0,1fr) auto;gap:18px;display:grid;position:relative}.timeline-item:before{border:2px solid var(--bg);background:var(--accent);content:"";border-radius:999px;width:11px;height:11px;position:absolute;top:5px;left:-22px}.timeline-item h3{font-size:14px;font-weight:500}.timeline-item p{color:var(--muted);margin:4px 0 0;font-size:13px;font-style:italic}.timeline-item ul{color:var(--muted);margin:8px 0 0;padding-left:16px;font-size:13px}.timeline-item li+li{margin-top:4px}.timeline-item>span{color:var(--muted);white-space:nowrap;font-size:13px}.about-projects{grid-template-columns:140px minmax(0,1fr);gap:28px;padding:18px 0 34px;display:grid}.project-list{gap:24px;display:grid}.project-item a{border-radius:8px;outline:none;gap:9px;display:grid;position:relative}.project-copy h3{font-size:14px;font-weight:600}.project-copy p{max-width:440px;color:var(--muted);margin:4px 0 0;font-size:13px;line-height:1.45}.project-techs{flex-wrap:wrap;justify-content:flex-start;gap:7px;display:flex}.tech-pill{background:var(--soft);min-height:22px;color:var(--text);white-space:nowrap;border-radius:999px;align-items:center;padding:3px 8px;font-size:11px;font-weight:500;transition:background .16s,color .16s;display:inline-flex}.tech-angular{color:#b91c1c;background:#fee2e2}.tech-spring-boot,.tech-spring-security,.tech-vue{color:#166534;background:#dcfce7}.tech-postgresql,.tech-tailwind,.tech-ocr{color:#0e7490;background:#cffafe}.tech-rest-apis,.tech-apis,.tech-pwa{color:#1e40af;background:#dbeafe}.tech-vite,.tech-embeddings,.tech-qdrant{color:#6d28d9;background:#ede9fe}.tech-indexeddb,.tech-python,.tech-typescript{color:#92400e;background:#fef3c7}.tech-github-pages{color:#374151;background:#e5e7eb}.tech-daisyui{color:#be185d;background:#fce7f3}.tech-llm-api{color:#4338ca;background:#e0e7ff}.tech-agents{color:#0f766e;background:#ccfbf1}.project-preview{z-index:10;aspect-ratio:16/10;border:1px solid var(--line);background:linear-gradient(135deg,#111827e0,#6366f1ad),var(--soft);color:#fff;opacity:0;pointer-events:none;border-radius:10px;place-items:center;width:190px;transition:opacity .18s,transform .18s;display:grid;position:absolute;top:50%;right:18px;transform:translate(24px,-50%)scale(.96)rotate(2deg);box-shadow:0 22px 46px #0000003d}.project-preview span{text-align:center;padding:0 14px;font-size:12px;font-weight:700}.project-item a:hover .project-preview,.project-item a:focus-visible .project-preview{opacity:1;transform:translate(48px,-50%)scale(1)rotate(2deg)}.about-hobbies{grid-template-columns:140px minmax(0,1fr);gap:28px;padding:18px 0 34px;display:grid}.hobby-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:26px 32px;display:grid}.hobby-item h3{font-size:14px;font-weight:600}.hobby-item p{color:var(--muted);margin:4px 0 0;font-size:13px;line-height:1.45}.hobby-item span{margin-top:5px;font-size:12px;font-weight:600;display:block}.metric-youtube{color:#dc2626}.metric-spotify{color:#16a34a}.metric-cactus{color:#ea580c}.metric-ai{color:#2563eb}.gear-hero{padding:24px 0 22px}.gear-hero>p{color:var(--muted);margin:4px 0 0;font-size:16px}.gear-section{padding:20px 0 28px}.gear-title-row{justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px;display:flex}.gear-title-row span{color:var(--muted);font-size:13px}.gear-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.gear-card{border:1px solid #0000;border-radius:12px;align-items:center;gap:12px;min-width:0;min-height:88px;padding:12px;transition:border-color .16s,background .16s,opacity .16s,transform .16s;display:flex;position:relative}.gear-card:hover{border-color:var(--line);background:var(--panel);transform:translateY(-1px)}.gear-card:after{color:var(--muted);content:"↗";opacity:0;flex:none;font-size:14px;transition:opacity .16s,transform .16s}.gear-card:hover:after{opacity:1;transform:translate(2px)}.gear-image{color:#fff;background:radial-gradient(circle at 72% 24%,#fff3,#0000 28%),linear-gradient(135deg,#111827,#6366f1);border-radius:10px;flex:0 0 64px;place-items:center;width:64px;height:64px;display:grid;position:relative;overflow:hidden}.gear-image img{background:var(--panel);object-fit:contain;width:100%;height:100%;position:absolute;inset:0}.gear-image img+span{opacity:0}.gear-card:nth-child(3n+2) .gear-image{background:radial-gradient(circle at 70% 20%,#ffffff2e,#0000 30%),linear-gradient(135deg,#0f766e,#22c55e)}.gear-card:nth-child(3n) .gear-image{background:radial-gradient(circle at 70% 20%,#ffffff2e,#0000 30%),linear-gradient(135deg,#7c2d12,#f97316)}.gear-card-pending .gear-image{background:repeating-linear-gradient(135deg,#ffffff1a 0 8px,#0000 8px 16px),linear-gradient(135deg,#374151,#6b7280)}.gear-image span{letter-spacing:.04em;font-size:16px;font-weight:800}.gear-card h3{color:var(--text);flex:auto;margin:0;font-size:13px;font-weight:600;line-height:1.35;overflow:hidden}.gear-card p{color:var(--muted);margin:2px 0 0;font-size:12px;line-height:1.35}.contact-hero{padding:24px 0 22px}.contact-hero>p{color:var(--muted);margin:4px 0 0;font-size:16px}.contact-links-section{padding:8px 0 30px}.contact-links-section>p,.book-section>p{color:var(--muted);margin:0 0 14px;font-size:14px;line-height:1.55}.contact-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.contact-card{border:1px solid var(--line);background:0 0;border-radius:10px;align-items:center;gap:12px;min-width:0;min-height:74px;padding:14px;transition:border-color .16s,background .16s,transform .16s;display:flex}.contact-card:hover,.contact-card:focus-visible{border-color:var(--muted);background:var(--panel);transform:translateY(-2px)scale(1.02)}.contact-card>span{width:28px;height:28px;color:var(--muted);background:0 0;border-radius:8px;flex:0 0 28px;place-items:center;font-size:11px;font-weight:800;transition:color .16s,transform .16s;display:grid}.contact-card:hover>span,.contact-card:focus-visible>span{color:var(--text);transform:scale(1.1)rotate(5deg)}.contact-card strong,.contact-card small{min-width:0;display:block}.contact-card strong{color:var(--text);font-size:14px;font-weight:600}.contact-card small{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.book-section{padding:18px 0 34px}.book-section h2{margin-bottom:8px}.call-options{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:30px;display:grid}.call-card{border:1px solid var(--line);min-height:140px;color:inherit;cursor:pointer;text-align:left;background:0 0;border-radius:12px;flex-direction:column;padding:18px;transition:background .16s,border-color .16s,transform .16s;display:flex;position:relative}.call-card:hover,.call-card:focus-visible{border-color:var(--muted);background:var(--panel);transform:translateY(-2px)scale(1.02)}.call-card>div{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px;display:flex}.call-card h3{font-size:15px;font-weight:600}.call-card span{background:var(--soft);color:var(--muted);border-radius:7px;flex:none;padding:4px 9px;font-size:11px}.call-card p{color:var(--muted);flex:auto;margin:0 0 12px;font-size:14px}.call-card small,.calendar-back{color:var(--muted);font-size:12px}.call-card small:after{content:"›";margin-left:6px;transition:transform .16s;display:inline-block}.call-card:hover small:after,.call-card:focus-visible small:after{transform:translate(3px)}.calendar-back{cursor:pointer;background:0 0;margin-bottom:14px;padding:0;display:inline-flex}.calendar-back:hover{color:var(--text)}.calendar-embed{border:1px solid var(--line);border-radius:12px;min-height:620px;overflow:auto}.calendar-embed>p{color:var(--muted);margin:0;padding:18px;font-size:13px}.playbook-hero{grid-template-columns:148px minmax(0,1fr);align-items:start;gap:28px;padding:30px 0 28px;display:grid}.playbook-avatar{aspect-ratio:1;background:var(--soft);border-radius:999px;width:148px;margin-top:4px;overflow:hidden}.playbook-avatar img{object-fit:cover;object-position:center 32%;width:100%;height:100%}.playbook-hero h1{font-size:clamp(25px,4.9vw,32px);line-height:1.18}.playbook-hero p{color:var(--muted);margin:12px 0 0;font-size:16px;line-height:1.65}.playbook-badges{flex-wrap:wrap;gap:8px;margin-top:18px;display:flex}.playbook-badges span{background:var(--accent);border-radius:999px;padding:3px 9px}@supports (color:color-mix(in lab,red,red)){.playbook-badges span{background:color-mix(in srgb,var(--accent) 12%,transparent)}}.playbook-badges span{color:var(--accent);font-size:12px;font-weight:500}.playbook-fit,.playbook-story,.playbook-products,.playbook-note{padding:18px 0}.playbook-fit h2{margin-bottom:12px}.playbook-fit ul,.playbook-card ul{gap:8px;margin:0;padding:0;list-style:none;display:grid}.playbook-fit li,.playbook-card li{color:var(--muted);padding-left:20px;position:relative}.playbook-fit li:before,.playbook-card li:before{color:var(--accent);content:"✓";position:absolute;left:0}.playbook-story{border-left:2px solid var(--accent);margin:12px 0 20px;padding-left:18px}.playbook-story p{color:var(--muted);margin:0 0 12px;line-height:1.7}.playbook-story p:last-child{margin-bottom:0}.playbook-products{gap:28px;display:grid}.playbook-card{border:1px solid var(--line);color:inherit;background:0 0;border-radius:12px;padding:20px;transition:border-color .16s,transform .16s,background .16s;display:block;position:relative;overflow:hidden}.playbook-card:hover,.playbook-card:focus-visible{border-color:var(--accent);background:var(--accent)}@supports (color:color-mix(in lab,red,red)){.playbook-card:hover,.playbook-card:focus-visible{background:color-mix(in srgb,var(--accent) 4%,transparent)}}.playbook-card:hover,.playbook-card:focus-visible{transform:translateY(-2px)}.playbook-card-head{justify-content:space-between;gap:18px;margin-bottom:10px;display:flex}.playbook-card-head span,.bundle-label{color:var(--accent);text-transform:uppercase;font-size:12px;font-weight:600}.playbook-card h2{margin-top:4px;font-size:20px;line-height:1.25}.playbook-card-head strong{color:var(--text);white-space:nowrap;font-size:20px;font-weight:700}.playbook-card p{color:var(--muted);margin:0 0 12px;line-height:1.55}.playbook-card b{color:var(--text);font-weight:600}.playbook-preview{background:var(--text);border-radius:8px;margin-top:20px;padding:14px;position:relative;overflow:hidden}@supports (color:color-mix(in lab,red,red)){.playbook-preview{background:color-mix(in srgb,var(--text) 8%,transparent)}}.playbook-preview:after{background:linear-gradient(to bottom,transparent,var(--bg));content:"";pointer-events:none;height:48px;position:absolute;bottom:0;left:0;right:0}.playbook-preview h3{margin-bottom:12px;font-size:17px}.playbook-preview table{border-collapse:collapse;width:100%;color:var(--muted);font-size:12px}.playbook-preview td{border:1px solid var(--line);padding:9px}@supports (color:color-mix(in lab,red,red)){.playbook-preview td{border:1px solid color-mix(in srgb,var(--line) 72%,transparent)}}.playbook-bundle{border-width:2px;border-color:var(--accent);padding:24px}.bundle-label{margin-bottom:10px;display:inline-flex}.playbook-bundle del{color:var(--muted);margin-left:8px;font-size:14px;font-weight:500;display:inline-block}.playbook-bundle small{background:var(--accent);border-radius:999px;margin-top:2px;padding:3px 8px;display:inline-flex}@supports (color:color-mix(in lab,red,red)){.playbook-bundle small{background:color-mix(in srgb,var(--accent) 14%,transparent)}}.playbook-bundle small{color:var(--accent);font-size:12px;font-weight:600}.playbook-note{color:var(--muted);font-size:13px;line-height:1.65}.playbook-note p{margin:0 0 10px}.playbook-note a{color:var(--text);text-underline-offset:3px;text-decoration:underline}.section-title-row{justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px;display:flex}h2{font-size:20px;font-weight:700;line-height:1.35}.type-cursor{color:var(--text);margin-left:2px;animation:1s step-end infinite cursorBlink;display:inline-block}.channel-stats{color:var(--muted);white-space:nowrap;align-items:center;gap:14px;font-size:13px;display:flex}.video-frame{aspect-ratio:16/9;background:var(--soft);border-radius:12px;overflow:hidden}.video-frame iframe{border:0;width:100%;height:100%}.video-carousel{margin-top:16px;position:relative}.video-carousel-window{position:relative;overflow:hidden}.video-edge{z-index:2;pointer-events:none;opacity:1;width:64px;transition:opacity .18s;position:absolute;top:0;bottom:0}.video-edge-left{background:linear-gradient(to right,var(--edge-start),transparent);left:0}.video-edge-right{background:linear-gradient(to left,var(--edge-start),transparent);right:0}.video-carousel.is-start .video-edge-left,.video-carousel.is-end .video-edge-right{opacity:0}.video-carousel-track{--video-index:0;--video-step: calc(25% + 3px) ;transform:translate(calc(var(--video-index) * var(--video-step) * -1));will-change:transform;gap:12px;transition:transform .32s;display:flex}.video-card{aspect-ratio:16/9;background:linear-gradient(135deg,#111827e0,#6366f1a6),var(--soft);color:#fff;border-radius:10px;flex:0 0 calc(25% - 9px);position:relative;overflow:hidden}.video-card img{object-fit:cover;width:100%;height:100%;transition:transform .32s}.video-card>span{place-items:center;width:100%;height:100%;font-size:13px;font-weight:800;display:grid}.video-card-overlay{opacity:0;visibility:hidden;background:#0000009e;place-items:center;padding:8px;transition:opacity .18s;display:grid;position:absolute;inset:0}.video-card:hover img{transform:scale(1.04)}.video-card:hover .video-card-overlay,.video-card:focus-visible .video-card-overlay{opacity:1;visibility:visible}.video-card h3{color:#fff;text-align:center;margin:0;font-size:11px;font-weight:600;line-height:1.35}.video-arrow{z-index:3;width:32px;height:32px;color:var(--muted);cursor:pointer;background:#ffffffd1;border-radius:999px;place-items:center;padding:0;transition:background .16s,color .16s,opacity .16s;display:grid;position:absolute;top:50%;transform:translateY(-50%)}:root.dark .video-arrow{background:#111827d1}.video-arrow:hover{color:var(--text)}.video-arrow:disabled{opacity:0;pointer-events:none}.video-arrow svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:20px;height:20px}.video-arrow-prev{left:8px}.video-arrow-next{right:8px}.video-thumb strong,.track-item strong{color:var(--text);font-size:12px;font-weight:700;line-height:1.35;display:block;overflow:hidden}.video-thumb strong{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box}.video-thumb small,.track-item small,.now-playing small{color:var(--muted);margin-top:2px;font-size:12px;display:block}.spotify-row{align-items:flex-start}.tab-group{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.tab-group button{min-height:32px;color:var(--muted);cursor:pointer;background:0 0;border-radius:10px;padding:6px 10px;font-size:13px;font-weight:500}.tab-group button.selected,.tab-group button:hover{background:var(--bubble);color:var(--text)}.spotify-layout{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:16px;display:grid}.spotify-main-player{height:var(--spotify-main-height);background:0 0;border-radius:12px;overflow:hidden}.spotify-main-player.loading .spotify-placeholder,.track-embed-placeholder{animation:1.8s cubic-bezier(.4,0,.6,1) infinite pulse}.spotify-main-player iframe,.track-embed iframe{border:0;border-radius:12px;width:100%;display:block}.spotify-main-player iframe{height:var(--spotify-main-height)}.track-list{gap:var(--spotify-gap);display:grid}.track-embed{height:var(--spotify-row-height);background:0 0;border-radius:12px;overflow:hidden}.track-embed iframe{height:var(--spotify-row-height)}.spotify-placeholder,.track-embed-placeholder{height:var(--spotify-main-height);color:#fff;text-align:center;background:linear-gradient(135deg,#1db954,#111827 72%),#111827;place-items:center;padding:18px;display:grid}.spotify-placeholder span{background:#ffffff29;border-radius:18px;place-items:center;width:64px;height:64px;font-size:24px;font-weight:800;display:grid}.spotify-placeholder strong{margin-top:14px;font-size:16px}.spotify-placeholder small{color:#ffffffb8}.track-embed-placeholder{height:var(--spotify-row-height);justify-items:start;gap:var(--spotify-gap);border:1px solid var(--line);background:var(--panel);color:var(--text);text-align:left;border-radius:12px;grid-template-columns:56px minmax(0,1fr)}.track-embed-placeholder span{color:#fff;background:#111827;border-radius:10px;place-items:center;width:56px;height:56px;font-size:12px;font-weight:800;display:grid}.social-footer{color:var(--muted);justify-items:center;gap:12px;padding:28px 0 0;display:grid}.social-icons{flex-wrap:wrap;justify-content:center;align-items:center;gap:24px;padding:0 16px;display:flex}.social-icons a{width:24px;height:24px;color:var(--muted);place-items:center;transition:color .16s,transform .16s;display:grid}.social-icons a:hover{color:var(--text);transform:translateY(-1px)}.social-icons svg{fill:currentColor;width:20px;height:20px}.social-footer p{color:var(--muted);text-align:center;margin:0;font-size:12px}.social-footer a:hover{color:var(--text)}@keyframes pulse{50%{opacity:.5}}@keyframes photoArrive{0%{opacity:0;transform:translate(-50%)translateY(42px)rotate(0)scale(.84)}48%{opacity:1;transform:translate(-50%)translateY(0)rotate(0)scale(.98)}to{opacity:1;transform:translate(var(--photo-x)) translateY(0) rotate(var(--photo-r)) scale(1)}}@keyframes cursorBlink{50%{opacity:0}}@media(max-width:680px){.page-shell{padding-inline:16px}.site-header{gap:8px}.main-nav a{padding-inline:10px}.section-title-row,.spotify-row{flex-direction:column;align-items:flex-start;gap:8px}.channel-stats{white-space:normal;gap:12px}.about-photo-stack{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;height:auto;margin:26px 0;display:grid}.about-photo-card,.about-photo-one,.about-photo-two,.about-photo-three,.about-photo-four,.about-photo-five,.about-photo-one:hover,.about-photo-two:hover,.about-photo-three:hover,.about-photo-four:hover,.about-photo-five:hover,.about-photo-one:focus-within,.about-photo-two:focus-within,.about-photo-three:focus-within,.about-photo-four:focus-within,.about-photo-five:focus-within{width:100%;position:relative;inset:auto;transform:none}.about-photo-three{aspect-ratio:16/10;grid-column:span 2}.about-photo-inner,.about-photo-card:hover .about-photo-inner,.about-photo-card:focus-within .about-photo-inner{transform:none}.about-photo-front,.about-photo-back{position:relative;inset:auto}.about-photo-back{display:none}.about-timeline{grid-template-columns:1fr;gap:16px}.timeline-item{grid-template-columns:1fr;gap:6px}.about-projects{grid-template-columns:1fr;gap:16px}.project-item a{grid-template-columns:1fr;gap:10px}.project-techs{justify-content:flex-start}.project-preview{display:none}.about-hobbies{grid-template-columns:1fr;gap:16px}.hobby-grid{grid-template-columns:1fr;gap:20px}.gear-title-row{flex-direction:column;align-items:flex-start;gap:4px}.gear-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.gear-card{align-items:flex-start;min-height:auto;padding:8px 0}.gear-card:hover{background:0 0;border-color:#0000;transform:none}.gear-image{flex-basis:56px;width:56px;height:56px}.gear-card:after{display:none}.contact-grid,.call-options{grid-template-columns:1fr}.playbook-hero{grid-template-columns:1fr;gap:18px}.playbook-avatar{width:116px}.playbook-card-head{flex-direction:column;align-items:flex-start;gap:8px}.video-carousel-track{--video-step: calc(86% + 12px) }.video-card{flex-basis:86%}.video-edge{width:40px}.spotify-layout{grid-template-columns:1fr}.spotify-main-player,.spotify-main-player iframe,.spotify-placeholder{height:var(--spotify-main-height)}}
