:root{--bg:#060a10;--bg-elevated:#0c1219;--bg-card:#0f1724;--border:#3ee8c51f;--border-hover:#3ee8c566;--text:#e8edf5;--text-muted:#7d8da8;--accent:#3ee8c5;--accent-dim:#3ee8c51a;--accent-glow:#3ee8c540;--sans:"DM Sans", system-ui, sans-serif;--mono:"JetBrains Mono", ui-monospace, monospace;--code-kw:#c792ea;--code-name:#82aaff;--code-str:#c3e88d;--code-prop:#f78c6c;--code-brace:#ffcb6b;--radius:10px;--radius-lg:14px;--container:min(1120px, 92vw);--header-h:72px}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;margin:0;font-size:1rem;line-height:1.6;overflow-x:hidden}#root{z-index:1;min-height:100vh;position:relative}a{color:inherit;text-decoration:none}ul{margin:0;padding:0;list-style:none}h1,h2,h3{margin:0;font-weight:600;line-height:1.2}p{color:var(--text-muted);margin:0 0 1rem}p:last-child{margin-bottom:0}.container{width:var(--container);margin-inline:auto}.code-bg{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.code-bg__grid{background-image:linear-gradient(#3ee8c50a 1px,#0000 1px),linear-gradient(90deg,#3ee8c50a 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 70% at 50% 30%,#000,#0000);mask-image:radial-gradient(80% 70% at 50% 30%,#000,#0000)}.code-bg__glow{filter:blur(80px);opacity:.5;border-radius:50%;position:absolute}.code-bg__glow--1{aspect-ratio:1;background:var(--accent-glow);width:50vw;max-width:500px;top:-10%;right:-5%}.code-bg__glow--2{aspect-ratio:1;background:#82aaff1f;width:40vw;max-width:400px;bottom:10%;left:-10%}.code-bg__scanline{opacity:.4;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000008 2px 4px);position:absolute;inset:0}.code-bg__line{font-family:var(--mono);color:#3ee8c514;white-space:nowrap;-webkit-user-select:none;user-select:none;font-size:.65rem;animation:linear infinite floatLine;position:absolute}@keyframes floatLine{0%{opacity:0;transform:translateY(10px)}10%{opacity:1}90%{opacity:1}to{opacity:0;transform:translateY(-30px)}}.code-window{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 0 0 1px #0000004d,0 20px 50px #00000073,0 0 40px #3ee8c50d}.code-window__bar{background:var(--bg-elevated);border-bottom:1px solid var(--border);align-items:center;gap:.4rem;padding:.65rem 1rem;display:flex}.code-window__dot{border-radius:50%;width:10px;height:10px}.code-window__dot:first-child{background:#ff5f57}.code-window__dot:nth-child(2){background:#febc2e}.code-window__dot:nth-child(3){background:#28c840}.code-window__title{font-family:var(--mono);color:var(--text-muted);margin-left:.5rem;font-size:.72rem}.code-window__body{padding:1.25rem 1.5rem}.code-logo{font-family:var(--mono);letter-spacing:-.03em;white-space:nowrap;font-weight:500}.code-logo__kw{color:var(--code-kw)}.code-logo__name{color:var(--code-name)}.code-logo__prop{color:var(--code-prop)}.code-logo__str{color:var(--code-str)}.code-logo__op,.code-logo__punct{color:var(--text-muted)}.code-logo__brace{color:var(--code-brace)}.code-logo--compact{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:.4rem .55rem;font-size:.72rem}.code-logo--compact .code-logo__name{font-weight:600}.code-logo--footer{font-size:.82rem}.code-logo--snippet{text-align:left;white-space:pre;background:0 0;border:none;margin:0;padding:0;font-size:.78rem;line-height:1.65}.code-logo--snippet code{font-family:inherit}.code-window .code-logo--snippet{padding:0}.code-window .code-window__body:has(.code-logo--snippet){padding:1.25rem 1.5rem 1.5rem}.typing-text__cursor{vertical-align:text-bottom;background:var(--accent);width:2px;height:1em;margin-left:2px;animation:1s step-end infinite blink;display:inline-block}@keyframes blink{50%{opacity:0}}.btn{font-family:var(--mono);border-radius:var(--radius);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.85rem 1.5rem;font-size:.88rem;font-weight:500;transition:transform .2s,background .2s,border-color .2s,box-shadow .2s;display:inline-flex}.btn:hover{transform:translateY(-2px)}.btn__prompt{color:var(--accent);font-weight:700}.btn--primary{color:var(--bg);background:var(--accent);border-color:var(--accent);box-shadow:0 0 20px #3ee8c540}.btn--primary:hover{background:#5ef0d4;box-shadow:0 0 28px #3ee8c566}.btn--ghost{color:var(--text);background:var(--bg-card);border-color:var(--border)}.btn--ghost:hover{border-color:var(--accent);color:var(--accent)}.btn--sm{padding:.55rem 1rem;font-size:.8rem}.header{z-index:100;height:var(--header-h);transition:background .3s,border-color .3s,-webkit-backdrop-filter .3s,backdrop-filter .3s;position:fixed;top:0;left:0;right:0}.header--scrolled{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);background:#060a10e6}.header__inner{justify-content:space-between;align-items:center;gap:1.5rem;height:100%;display:flex}.header__logo{align-items:center;gap:.65rem;display:flex}.header__logo-text{font-size:clamp(.68rem,1.8vw,.88rem);display:none}@media (width>=640px){.header__logo-text{display:inline}}.header__nav a{font-family:var(--mono);color:var(--text-muted);font-size:.82rem;transition:color .2s}.nav-link__index{color:var(--accent);margin-right:.15rem}.header__nav a:hover{color:var(--accent)}.header__nav ul{gap:1.75rem;display:flex}.header__actions{align-items:center;gap:.75rem;display:flex}.lang-toggle{font-family:var(--mono);color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:.45rem .7rem;font-size:.75rem;font-weight:600;transition:color .2s,border-color .2s}.lang-toggle:hover{color:var(--accent);border-color:var(--accent)}.header__cta{display:none}.header__burger{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:8px;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:0;display:flex}.header__burger span{background:var(--accent);border-radius:1px;width:18px;height:2px;margin-inline:auto;display:block}@media (width>=900px){.header__burger{display:none}.header__cta{display:inline-flex}.header__nav{display:block!important}}@media (width<=899px){.header__nav{inset:var(--header-h) 0 0 0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border);background:#060a10f7;padding:2rem;display:none;position:fixed}.header__nav--open{display:block}.header__nav ul{flex-direction:column;gap:1.5rem}.header__nav a{color:var(--text);font-size:1.1rem}}.hero{padding:calc(var(--header-h) + 4rem) 0 5rem;position:relative}.hero__grid{align-items:start;gap:2.5rem;display:grid}@media (width>=900px){.hero__grid{grid-template-columns:1.15fr .85fr;align-items:center;gap:3rem}}.hero__eyebrow{font-family:var(--mono);margin-bottom:1rem;font-size:.8rem}.hero__eyebrow-val{color:var(--code-str)}.hero__terminal-line{font-family:var(--mono);background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:1.25rem;padding:.5rem .75rem;font-size:.85rem;display:inline-block}.hero__prompt{color:var(--accent)}.hero__cmd{color:var(--code-name)}.hero__title{font-family:var(--mono);color:var(--text);margin-bottom:1.25rem;font-size:clamp(1.5rem,4.5vw,2.35rem);font-weight:500;line-height:1.35}.hero__title-comment{color:var(--text-muted)}.hero__title-accent{color:var(--accent);margin-top:.25rem;font-style:normal;display:block}@media (width>=640px){.hero__title-accent{margin-top:0;display:inline}}.hero__subtitle{max-width:32rem;margin-bottom:2rem;font-size:1.05rem}.hero__actions{flex-wrap:wrap;gap:1rem;display:flex}.hero__json{font-family:var(--mono);white-space:pre;margin:0;font-size:.8rem;line-height:1.7}.hero__json code{font-family:inherit}.hero__json-comment{color:var(--text-muted);font-size:.72rem}.hero__panel .code-window__body{padding:1.25rem 1.5rem}.section{padding:5rem 0;position:relative}.section--alt{border-block:1px solid var(--border);background:#0c121999}.section__header{text-align:center;max-width:36rem;margin:0 auto 3rem}.section__header--left{text-align:left;max-width:none;margin:0 0 1.5rem}.section__comment{font-family:var(--mono);color:var(--text-muted);margin-bottom:.75rem;font-size:.85rem}.section__comment-kw{color:var(--code-kw)}.section__title{font-family:var(--mono);color:var(--text);margin-bottom:1rem;font-size:clamp(1.5rem,3.5vw,2.25rem);font-weight:600}.section__title:before{content:"function ";color:var(--code-kw);font-weight:500}.section__title:after{content:"()";color:var(--code-brace);font-weight:500}.services-grid{gap:1.25rem;display:grid}@media (width>=640px){.services-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.services-grid{grid-template-columns:repeat(4,1fr)}}.service-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem 1.25rem 1.5rem 2.75rem;transition:border-color .25s,transform .25s,box-shadow .25s;animation:.5s both fadeUp;position:relative;overflow:hidden}.service-card:before{content:"";background:var(--accent);width:3px;height:0;transition:height .3s;position:absolute;top:0;left:0}.service-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:0 12px 32px #00000059}.service-card:hover:before{height:100%}.service-card__line{font-family:var(--mono);color:#3ee8c559;font-size:.7rem;position:absolute;top:1.5rem;left:.85rem}.service-card__fn{font-family:var(--mono);color:var(--code-name);margin-bottom:.75rem;font-size:.78rem;display:block}.service-card h3{color:var(--text);margin-bottom:.5rem;font-size:1rem}.service-card p{margin:0;font-size:.88rem}.service-card__cursor{background:var(--accent);opacity:0;width:8px;height:14px;transition:opacity .2s;animation:1s step-end infinite blink;position:absolute;bottom:1rem;right:1rem}.service-card:hover .service-card__cursor{opacity:.6}.projects-grid{gap:1.25rem;display:grid}@media (width>=768px){.projects-grid{grid-template-columns:repeat(2,1fr)}}.project-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);font-family:var(--sans);padding:1.5rem;transition:border-color .25s,transform .25s;animation:.6s both fadeUp}.project-card:hover{border-color:var(--border-hover);transform:translateY(-3px)}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.project-card__path{font-family:var(--mono);color:var(--code-name);opacity:.85;margin-bottom:.75rem;font-size:.72rem;display:block}.project-card__path:before{content:"./";color:var(--accent);margin-right:.15rem}.project-card__tag{font-family:var(--mono);color:var(--accent);background:var(--accent-dim);border:1px solid #3ee8c533;border-radius:4px;margin-bottom:.75rem;padding:.2rem .55rem;font-size:.68rem;font-weight:600;display:inline-block}.project-card h3{color:var(--text);margin-bottom:.5rem;font-size:1.1rem}.project-card p{margin-bottom:1rem;font-size:.9rem}.project-card__tech{flex-wrap:wrap;gap:.45rem;display:flex}.project-card__tech li{font-family:var(--mono);background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:.25rem .5rem;font-size:.72rem}.about-grid{align-items:start;gap:2.5rem;display:grid}@media (width>=768px){.about-grid{grid-template-columns:.95fr 1.05fr;align-items:center}}.about-content .section__header{margin-bottom:1.25rem}.about-content h2.section__title{margin-bottom:0}.about-list{margin-top:1.25rem}.about-list li{font-family:var(--mono);color:var(--text-muted);border-bottom:1px dashed var(--border);margin-bottom:.6rem;padding:.35rem 0;font-size:.88rem}.about-list__prefix{color:var(--accent)}.contact-grid{gap:2rem;display:grid}@media (width>=768px){.contact-grid{grid-template-columns:1fr 1.15fr;align-items:start}}.contact-email{font-family:var(--mono);font-size:.88rem;line-height:1.8}.contact-email a{color:var(--accent);text-underline-offset:3px;text-decoration:underline}.contact-form{background:0 0;border:none;grid-template-columns:1fr 1fr;gap:1rem;padding:0;display:grid}.contact-form label{flex-direction:column;gap:.35rem;display:flex}.contact-form__label{font-family:var(--mono);color:var(--code-prop);font-size:.75rem}.contact-form input,.contact-form textarea{font-family:var(--mono);color:var(--text);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:.7rem .9rem;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--text-muted);opacity:.6}.contact-form input:focus,.contact-form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.contact-form__full{grid-column:1/-1}.contact-form textarea{resize:vertical;min-height:110px}.contact-form button{grid-column:1/-1;justify-self:start}.contact-form__note{font-family:var(--mono);grid-column:1/-1;margin:0;font-size:.85rem}.code-window .contact-form{margin:0}.code-window:has(.contact-form) .code-window__body{padding:1.25rem 1.5rem 1.5rem}.footer{border-top:1px solid var(--border);background:#060a10cc;padding:2rem 0}.footer__inner{color:var(--text-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;font-size:.85rem;display:flex}.footer__copy{font-family:var(--mono);flex-wrap:wrap;align-items:center;gap:.35rem;margin:0;display:flex}.footer__meta{font-family:var(--mono);margin:0;font-size:.8rem}.floating-widgets{z-index:200;flex-direction:column;align-items:flex-end;gap:.75rem;display:flex;position:fixed;bottom:1.25rem;right:1.25rem}.fab{cursor:pointer;border:none;border-radius:50%;place-items:center;width:56px;height:56px;text-decoration:none;transition:transform .2s,box-shadow .2s;display:grid;position:relative;box-shadow:0 8px 24px #0006}.fab:hover{transform:scale(1.06)}.fab__icon{width:28px;height:28px}.fab__glyph{font-family:var(--mono);font-size:1.1rem;font-weight:700;line-height:1}.fab__glyph--code{color:inherit;font-size:.95rem}.fab--whatsapp{color:#fff;background:#25d366}.fab--whatsapp:hover{background:#20bd5a;box-shadow:0 8px 28px #25d36673}.fab--chat{background:var(--bg-card);color:var(--accent);border:1px solid var(--border-hover)}.fab--chat:hover,.fab--chat.fab--active{background:var(--accent);color:var(--bg);box-shadow:0 8px 28px #3ee8c559}.fab__tooltip{font-family:var(--mono);white-space:nowrap;color:var(--text);background:var(--bg-card);border:1px solid var(--border);opacity:0;pointer-events:none;border-radius:6px;padding:.4rem .65rem;font-size:.72rem;transition:opacity .2s;position:absolute;right:calc(100% + 10px)}.fab--whatsapp:hover .fab__tooltip{opacity:1}.chat-widget{flex-direction:column;align-items:flex-end;gap:.75rem;display:flex}.chat-panel{background:var(--bg-card);border:1px solid var(--border-hover);border-radius:var(--radius-lg);flex-direction:column;width:min(360px,100vw - 2rem);max-height:min(520px,100vh - 8rem);animation:.25s chatSlideIn;display:flex;overflow:hidden;box-shadow:0 0 0 1px #0000004d,0 24px 48px #00000080}@keyframes chatSlideIn{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.chat-panel__bar{background:var(--bg-elevated);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:.4rem;padding:.6rem .75rem .6rem 1rem;display:flex}.chat-panel__title{font-family:var(--mono);color:var(--text-muted);flex:1;font-size:.72rem}.chat-panel__close{width:28px;height:28px;color:var(--text-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;padding:0;font-size:1.25rem;line-height:1;transition:color .2s,border-color .2s}.chat-panel__close:hover{color:var(--accent);border-color:var(--accent)}.chat-panel__messages{flex-direction:column;flex:1;gap:.65rem;min-height:140px;padding:1rem;display:flex;overflow-y:auto}.chat-bubble{max-width:92%;font-size:.85rem;line-height:1.45;font-family:var(--sans);border-radius:10px;padding:.6rem .75rem}.chat-bubble__prefix{font-family:var(--mono);font-size:.8rem;font-weight:600}.chat-bubble--bot{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);align-self:flex-start}.chat-bubble--bot .chat-bubble__prefix{color:var(--accent)}.chat-bubble--user{color:var(--text);background:#3ee8c51f;border:1px solid #3ee8c540;align-self:flex-end}.chat-bubble--user .chat-bubble__prefix{color:var(--code-name)}.chat-bubble--typing{padding:.75rem 1rem}.chat-typing{vertical-align:middle;gap:4px;display:inline-flex}.chat-typing span{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite chatDot}.chat-typing span:nth-child(2){animation-delay:.15s}.chat-typing span:nth-child(3){animation-delay:.3s}@keyframes chatDot{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.chat-panel__chips{border-top:1px solid var(--border);flex-shrink:0;padding:0 1rem .75rem}.chat-panel__chips-label{font-family:var(--mono);color:var(--code-kw);margin:.75rem 0 .5rem;font-size:.72rem}.chat-chips{flex-wrap:wrap;gap:.4rem;max-height:120px;display:flex;overflow-y:auto}.chat-chip{font-family:var(--mono);color:var(--text);background:var(--bg-elevated);border:1px solid var(--border);cursor:pointer;border-radius:999px;padding:.4rem .65rem;font-size:.68rem;transition:border-color .2s,color .2s,background .2s}.chat-chip:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.chat-chip:disabled{opacity:.5;cursor:not-allowed}.chat-panel__footer{border-top:1px solid var(--border);flex-shrink:0;gap:.5rem;padding:.75rem 1rem 1rem;display:flex}.chat-panel__link{font-family:var(--mono);text-align:center;color:var(--accent);background:var(--accent-dim);border:1px solid #3ee8c540;border-radius:8px;flex:1;padding:.55rem .75rem;font-size:.72rem;font-weight:600;transition:background .2s,border-color .2s}.chat-panel__link:hover{border-color:var(--accent);background:#3ee8c533}.chat-panel__link--wa{color:#25d366;background:#25d3661a;border-color:#25d3664d}.chat-panel__link--wa:hover{background:#25d3662e;border-color:#25d366}@media (width<=480px){.floating-widgets{bottom:1rem;right:1rem}.fab{width:52px;height:52px}.fab__tooltip{display:none}.chat-panel{width:calc(100vw - 2rem)}}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}html{scroll-behavior:auto}}
