@import"https://fonts.googleapis.com/css2?family=Noto+Sans+Mono:wght@100..900&display=swap";@layer components;@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-translate-x:0;--tw-translate-y:0;--tw-translate-z:0}}}@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;--color-zinc-500:oklch(55.2% .016 285.938);--spacing:.25rem;--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{.fixed{position:fixed}.static{position:static}.top-4{top:calc(var(--spacing) * 4)}.left-1\/2{left:50%}.z-50{z-index:50}.block{display:block}.-translate-x-1\/2{--tw-translate-x: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.bg-zinc-500{background-color:var(--color-zinc-500)}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-2{padding-block:calc(var(--spacing) * 2)}}.stream-wrapper{z-index:2;pointer-events:none;width:min(640px,90vw);height:110px;position:fixed;left:50%;overflow:hidden;transform:translate(-50%)}@keyframes scroll-L{to{right:-200px}}.stream-item{opacity:.1;width:80px;height:320px;animation-name:scroll-L;animation-timing-function:linear;animation-iteration-count:infinite;position:absolute;right:100%}.stream-item:first-child{animation-duration:9s;animation-delay:0s}.stream-item:nth-child(2){animation-duration:3.8s;animation-delay:-.75s}.stream-item:nth-child(3){animation-duration:2.2s;animation-delay:-.625s}.stream-item:nth-child(4){animation-duration:6s;animation-delay:-.5s}.stream-item:nth-child(5){animation-duration:6s;animation-delay:-.375s}.stream-item:nth-child(6){animation-duration:4.5s;animation-delay:-.25s}.stream-item:nth-child(7){animation-duration:7.5s;animation-delay:-.125s}.stream-item:nth-child(8){animation-duration:12s;animation-delay:0s}.pulse-wrapper{z-index:2;pointer-events:none;width:20px;height:20px;position:fixed}@keyframes sweep{to{opacity:1;right:-200px}}.pulse-item{opacity:0;background-color:#042200e6;background-color:oklch(22% .08 140/.9);width:20px;height:100px;animation-name:sweep;animation-duration:1.1s;animation-timing-function:ease-out;animation-iteration-count:infinite;position:absolute;right:100%}@view-transition{navigation:auto}:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Noto Sans Mono,monospace;font-size:16px}body{--color-ground0:oklch(13% .012 34.31);--color-ground1:oklch(18.5% .012 34.31);--color-ground2:oklch(26% .012 34.31);--color-ground0-tr:oklch(16% .012 34.31/.52);--color-ground1-tr:oklch(22% .012 34.31/.62);--color-ground2-tr:oklch(28% .012 34.31/.45);--color-border:oklch(32% .018 34.31/.55);--color-border-hi:oklch(48% .12 145/.65);--color-text0:oklch(50% .012 34.31/.9);--color-text1:oklch(66% .015 34.31/.9);--color-text2:oklch(84% .01 34.31/.9);--color-high1:oklch(46% .12 145/.9);--color-high2:oklch(60% .14 145/.9);background-color:var(--color-ground0);color:var(--color-text1);min-height:100vh;font-family:Noto Sans Mono,monospace;font-size:16px;transition:background-color .4s,color .3s}a{color:inherit;text-decoration:none}a:hover{color:var(--color-high2)}.bg-image{z-index:0;background-image:url(/static/images/arroyo-uno.jpg);background-position:50%;background-size:cover;position:fixed;inset:0}.bg-image:after{content:"";opacity:0;background-image:url(/static/images/arroyo-dos.jpg);background-position:50%;background-size:cover;transition:opacity .5s;position:absolute;inset:0}body.light .bg-image:after{opacity:1}.bg-overlay{z-index:1;background-color:var(--color-ground0);opacity:0;transition:opacity .3s,background-color .4s;position:fixed;inset:0}body.page-inner .bg-overlay{opacity:.8}.site-logo{z-index:20;flex-direction:column;align-items:flex-start;gap:.55em;display:flex;position:fixed;top:1.75em;left:2em}.site-logo-img{filter:invert();opacity:.55;width:156px;transition:filter .3s,opacity .14s}.site-logo a:hover .site-logo-img{opacity:.9}.site-painter-link{color:var(--color-text1);letter-spacing:.02em;font-size:1.08em;transition:color .12s}.site-painter-link:hover{color:var(--color-high2)}body.page-inner .site-painter-link{display:none}.theme-toggle{cursor:pointer;color:var(--color-text1);background:0 0;border:none;align-items:center;padding:0;transition:color .12s;display:flex}.theme-toggle:hover{color:var(--color-high2)}.theme-icon{width:1.1em;height:1.1em}.landing-theme-toggle{margin-left:auto}.logo-theme-toggle{margin-top:.3em}body.light{--color-ground0:oklch(95% .008 34.31);--color-ground1:oklch(89% .008 34.31);--color-ground2:oklch(80% .008 34.31);--color-ground0-tr:oklch(94% .008 34.31/.55);--color-ground1-tr:oklch(88% .008 34.31/.55);--color-ground2-tr:oklch(82% .008 34.31/.4);--color-border:oklch(68% .015 34.31/.5);--color-border-hi:oklch(35% .12 145/.6);--color-text0:oklch(48% .012 34.31/.9);--color-text1:oklch(32% .015 34.31/.9);--color-text2:oklch(14% .012 34.31/.9);--color-high1:oklch(32% .12 145/.9);--color-high2:oklch(42% .14 145/.9);background-color:var(--color-ground0);color:var(--color-text1)}body.light .bg-overlay{background-color:#f0e9e8}body.light .site-logo-img{filter:none;opacity:.65}body.light .pulse-item{background-color:#2c5a21d9}body.light .landing-card{background-color:#f0e9e84d}.landing-bg{z-index:10;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.landing-stack{flex-direction:column;gap:.6em;width:90%;max-width:640px;display:flex}.landing-nav{justify-content:flex-start;gap:2em;display:flex}.landing-nav a{color:var(--color-text1);letter-spacing:.04em;font-size:1.5em;transition:color .12s}.landing-nav a:hover{color:var(--color-high2)}.landing-card{z-index:10;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background-color:#120b0a47;width:90%;max-width:640px;padding:3em 3.5em;transition:background-color .4s;position:relative}.landing-name{color:var(--color-text1);letter-spacing:.02em;margin:0;font-size:1.6em;font-weight:600;line-height:1.2}.landing-tagline{color:var(--color-text0);margin-top:.4em;font-size:.9em}.landing-bio{color:var(--color-text0);margin-top:1.2em;font-size:.92em;line-height:1.7}.page{z-index:10;max-width:680px;min-height:100vh;margin:0 auto;padding:4em 2em 5em;position:relative}.page-note{color:var(--color-text0);opacity:.7;margin-top:2em;font-size:.75em}.page-title{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text0);margin-bottom:2em;font-size:1em;font-weight:600}.project-card-link{color:inherit;margin-bottom:.75em;display:block}.project-card{background-color:var(--color-ground0-tr);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--color-border);border-radius:.1em;flex-direction:column;gap:.6em;padding:1.5em;transition:border-color .14s,background-color .14s;display:flex}.project-card:hover{border-color:var(--color-border-hi);background-color:var(--color-ground1-tr)}.project-card-header{justify-content:space-between;align-items:baseline;display:flex}.project-name{color:var(--color-text2);font-size:1em;font-weight:600}.project-year{color:var(--color-text0);font-size:.75em}.project-tagline{color:var(--color-text1);margin:0;font-size:.85em}.case-study-link{color:var(--color-high1);align-self:flex-end;margin-top:.25em;font-size:.8em}.project-card:hover .case-study-link{color:var(--color-high2)}.back-link{color:var(--color-text0);margin-bottom:2.5em;font-size:.8em;transition:color .12s;display:inline-block}.back-link:hover{color:var(--color-high2)}.project-header{margin-bottom:3em}.project-header h1{color:var(--color-text2);margin:0 0 .3em;font-size:1.5em;font-weight:600}.project-meta{color:var(--color-text0);align-items:baseline;gap:1.5em;margin-top:.75em;font-size:.8em;display:flex}.project-meta a{color:var(--color-high1)}.project-meta a:hover{color:var(--color-high2)}.case-study-section{margin-bottom:2.5em}.section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--color-text0);border-bottom:1px solid var(--color-border);margin-bottom:.8em;padding-bottom:.6em;font-size:.7em}.section-body{color:var(--color-text1);font-size:.9em;line-height:1.75}.tech-tags{flex-wrap:wrap;gap:.4em;display:flex}.tag{border:1px solid var(--color-border-hi);color:var(--color-high1);background-color:#2269290f;border-radius:.1em;padding:.2em .6em;font-size:.72em}.contact-email-block{margin-bottom:1.5em}.email-reveal-btn{color:var(--color-text0);border:1px solid var(--color-border);cursor:pointer;border-radius:.1em;padding:.5em 1em;font-size:.85em;transition:border-color .14s,color .14s;display:inline-block}.email-reveal-btn:hover{border-color:var(--color-border-hi);color:var(--color-text2)}.email-link{color:var(--color-high2);font-size:.9em}.contact-links{gap:1.5em;margin-top:2em;display:flex}.contact-links a{color:var(--color-text0);font-size:.85em;transition:color .12s}.contact-links a:hover{color:var(--color-high2)}@media(max-width:640px){.site-logo{grid-template-rows:auto auto;grid-template-columns:auto auto;align-items:center;gap:.3em .8em;display:grid}.site-logo>a:first-child{grid-area:1/1/3}.site-painter-link{grid-area:1/2;align-self:end}.logo-theme-toggle{grid-area:2/2;align-self:start;margin-top:0}.site-logo-img{width:120px}.landing-bg{align-items:flex-start;padding-top:7em}.landing-card{padding:2em 1.75em}.page{padding-top:6em;padding-left:1.25em;padding-right:1.25em}.project-meta{flex-wrap:wrap;gap:.75em 1.5em}}.toast{background-color:var(--color-ground1);color:var(--color-text2);border:1px solid var(--color-border);border-radius:.15em;font-size:.85em}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}
