*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #faf6f1;--surface: #ffffff;--surface-2: #f3ece4;--ink: #1a1714;--muted: #8c8178;--faint: #b9aea4;--accent: #e8502a;--accent-ink: #ffffff;--border: #e9e0d6;--font-display: "Bricolage Grotesque", sans-serif;--font-body: "Hanken Grotesk", sans-serif;--font-mono: "JetBrains Mono", monospace;--page-max: 1100px}[data-theme=dark]{--bg: #0e0e15;--surface: #15151e;--surface-2: #1b1b25;--ink: #f1efea;--muted: #8d8a98;--faint: #5a5868;--accent: #f4683c;--accent-ink: #14100d;--border: #262631}html{font-size:16px}body{background:var(--bg);color:var(--ink);font-family:var(--font-body);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background-color .2s,color .2s}ul{list-style:none;padding:0;margin:0}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit}.header{position:sticky;top:0;z-index:1000;background:var(--bg);border-bottom:1px solid var(--border);padding:0 5%;height:64px;display:flex;align-items:center;justify-content:space-between;transition:background-color .2s,border-color .2s}.logo{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--ink);flex-shrink:0}.logo-badge{width:34px;height:34px;background:var(--ink);color:var(--bg);border-radius:7px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.75rem;font-weight:800;letter-spacing:-.02em;transition:background-color .2s,color .2s}.header nav ul{display:flex;gap:.1rem;list-style:none;padding:0;margin:0}.header nav a{font-size:.875rem;font-family:var(--font-body);color:var(--muted);text-decoration:none;padding:.375rem .75rem;border-radius:7px;transition:color .15s,background .15s}.header nav a:hover{color:var(--ink);background:var(--surface-2)}.header nav a.active{color:var(--ink);font-weight:600}.header-actions{display:flex;align-items:center;gap:.5rem}.btn-theme{background:none;border:none;color:var(--muted);font-size:1.1rem;display:flex;align-items:center;padding:.375rem;border-radius:7px;transition:color .15s,background .15s;line-height:1}.btn-theme:hover{color:var(--ink);background:var(--surface-2)}.btn-cta{background:var(--accent);color:var(--accent-ink);border:none;padding:.45rem 1rem;border-radius:7px;font-size:.85rem;font-weight:600;font-family:var(--font-body);text-decoration:none;display:inline-block;transition:opacity .15s}.btn-cta:hover{opacity:.86}.menu-toggle{display:none;background:none;border:1px solid var(--border);border-radius:7px;padding:.375rem .5rem;color:var(--ink);font-size:1.1rem;align-items:center;line-height:1}.hero{width:90%;max-width:var(--page-max);margin:0 auto;padding:6rem 0 5rem;display:grid;grid-template-columns:1fr 260px;gap:4rem;align-items:center}.hero-eyebrow{display:inline-block;font-family:var(--font-mono);font-size:.775rem;color:var(--accent);text-transform:uppercase;letter-spacing:.14em;margin-bottom:1.25rem}.hero-name{font-family:var(--font-display);font-size:clamp(3rem,7.5vw,5.25rem);font-weight:800;line-height:.95;letter-spacing:-.03em;color:var(--ink);margin:0 0 1.5rem}.hero-body{font-size:1.1rem;color:var(--muted);max-width:460px;line-height:1.75;margin-bottom:2rem}.hero-actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn-primary{background:var(--ink);color:var(--bg);border:none;padding:.7rem 1.4rem;border-radius:8px;font-size:.9rem;font-weight:600;font-family:var(--font-body);text-decoration:none;display:inline-flex;align-items:center;gap:.3rem;transition:opacity .15s;line-height:1}.btn-primary:hover{opacity:.8}.btn-secondary{background:transparent;color:var(--ink);border:1.5px solid var(--border);padding:.7rem 1.4rem;border-radius:8px;font-size:.9rem;font-weight:600;font-family:var(--font-body);text-decoration:none;display:inline-flex;align-items:center;transition:border-color .15s;line-height:1}.btn-secondary:hover{border-color:var(--ink)}.hero-photo{width:260px;height:320px;border-radius:16px;overflow:hidden;background:var(--surface-2);flex-shrink:0;border:1px solid var(--border)}.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}.statement-strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:3.5rem 5%}.statement-inner{max-width:var(--page-max);margin:0 auto}.statement-hi{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1.1}.statement-rest{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:var(--muted);letter-spacing:-.02em;line-height:1.1}.projects-section{width:90%;max-width:var(--page-max);margin:0 auto;padding:5rem 0 2rem}.section-label{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;letter-spacing:.14em;color:var(--faint);margin-bottom:3rem}.project-item{display:grid;grid-template-columns:.9fr 1.1fr;gap:4rem;align-items:center;padding:4rem 0;border-top:1px solid var(--border)}.project-item:last-of-type{border-bottom:1px solid var(--border)}.project-item--reverse{grid-template-columns:1.1fr .9fr;direction:rtl}.project-item--reverse>*{direction:ltr}.project-img{border-radius:12px;overflow:hidden;background:var(--surface-2);aspect-ratio:16 / 10;display:flex;align-items:center;justify-content:center;border:1px solid var(--border)}.project-img img{width:100%;height:100%;object-fit:contain;padding:1.5rem;transition:transform .3s}.project-img:hover img{transform:scale(1.03)}.project-info{display:flex;flex-direction:column;gap:.85rem}.project-num{font-family:var(--font-mono);font-size:.7rem;color:var(--faint);letter-spacing:.12em}.project-name{font-family:var(--font-display);font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700;color:var(--ink);letter-spacing:-.02em;margin:0;line-height:1.1}.project-desc{font-size:.95rem;color:var(--muted);line-height:1.7;margin:0}.project-tags{display:flex;flex-wrap:wrap;gap:.4rem}.project-tag{font-family:var(--font-mono);font-size:.7rem;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);padding:.2rem .6rem;border-radius:4px;letter-spacing:.02em}.project-links{display:flex;gap:1.25rem;margin-top:.25rem;flex-wrap:wrap}.project-link{font-size:.875rem;font-weight:600;color:var(--accent);text-decoration:none;transition:opacity .15s;font-family:var(--font-body)}.project-link:hover{opacity:.72}.project-link--ghost{color:var(--muted);font-weight:500}.projects-cta{text-align:center;margin-top:3.5rem}.stack-section{background:var(--surface-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:3.5rem 0;margin-top:3rem;overflow:hidden}.stack-inner{max-width:var(--page-max);margin:0 auto;padding:0 5%}.stack-title{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;letter-spacing:.14em;color:var(--faint);margin-bottom:1.5rem}.stack-marquee{overflow:hidden;-webkit-mask:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%);mask:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%)}.stack-track{display:flex;gap:.6rem;width:max-content;animation:stack-scroll 22s linear infinite}@keyframes stack-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.stack-marquee:hover .stack-track{animation-play-state:paused}.stack-chip{display:inline-flex;align-items:center;gap:.5rem;background:var(--surface);border:1px solid var(--border);color:var(--ink);padding:.45rem 1rem;border-radius:999px;font-size:.875rem;font-weight:500;font-family:var(--font-body);white-space:nowrap;flex-shrink:0;transition:border-color .15s}.stack-chip:hover{border-color:var(--accent)}.stack-chip-icon{font-size:1.1rem;line-height:1;display:flex}.ba-section{width:90%;max-width:var(--page-max);margin:0 auto;padding:5rem 0 2rem}.ba-heading{font-family:var(--font-display);font-size:clamp(1.75rem,4vw,3rem);font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1.05;margin:.75rem 0 .85rem}.ba-intro{color:var(--muted);max-width:52ch;font-size:1rem;line-height:1.6;margin-bottom:2.25rem}.ba-intro b{color:var(--ink);font-weight:600}.ba-compare{position:relative;width:100%;aspect-ratio:16 / 10;border-radius:16px;overflow:hidden;border:1px solid var(--border);box-shadow:0 30px 60px -35px #1a181559;-webkit-user-select:none;user-select:none;cursor:ew-resize;touch-action:pan-y}.ba-compare:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.ba-pane{position:absolute;inset:0;padding:clamp(1rem,3vw,2rem);display:flex;flex-direction:column}.ba-after{background:var(--bg)}.cfg{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:clamp(.6rem,2vw,1.4rem);min-height:0}.cfg-stage{display:flex;flex-direction:column;gap:.5rem;min-width:0}.cfg-preview{flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center;padding:.8rem;min-height:0}.cfg-caption{font-family:var(--font-mono);font-size:clamp(.58rem,1.2vw,.7rem);color:var(--muted);text-align:center}.cfg-controls{display:flex;flex-direction:column;gap:.45rem;min-width:0}.cfg-group-label{font-family:var(--font-mono);font-size:.58rem;text-transform:uppercase;letter-spacing:.1em;color:var(--faint)}.cfg-row{display:flex;gap:.35rem}.cfg-opt{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:5px;padding:.4rem .2rem;border:1.5px solid var(--border);border-radius:9px;background:var(--surface);color:var(--ink);font-family:var(--font-body);font-size:.55rem;line-height:1.1;text-align:center;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.cfg-opt[aria-pressed=true]{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.cfg-swatches{display:flex;gap:.45rem}.cfg-swatch{width:26px;height:26px;border-radius:50%;border:2px solid var(--border);padding:0;cursor:pointer;transition:border-color .15s,box-shadow .15s}.cfg-swatch[aria-pressed=true]{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 30%,transparent)}.cfg-pill{flex:1;padding:.4rem 0;border:1.5px solid var(--border);border-radius:8px;background:var(--surface);color:var(--ink);font-family:var(--font-mono);font-size:.66rem;cursor:pointer;transition:border-color .15s,color .15s}.cfg-pill[aria-pressed=true]{border-color:var(--accent);color:var(--accent)}.cfg-cta{margin-top:auto;padding:.6rem;border:none;border-radius:10px;background:var(--ink);color:var(--bg);font-family:var(--font-body);font-weight:700;font-size:clamp(.66rem,1.4vw,.8rem);cursor:pointer}.cfg-sofa{display:flex;align-items:flex-end;gap:3px;width:100%;height:clamp(50px,11vw,100px);transition:width .25s ease}.cfg-arm{width:9%;min-width:7px;height:80%;background:var(--fabric);border-radius:7px 7px 3px 3px}.cfg-sbody{flex:1;display:flex;flex-direction:column;justify-content:flex-end;gap:3px;height:100%;min-width:0}.cfg-backrest{display:flex;gap:3px;height:46%}.cfg-pillow{flex:1;background:var(--fabric);filter:brightness(.92);border-radius:6px 6px 2px 2px}.cfg-seat{display:flex;gap:3px;height:34%}.cfg-cushion{flex:1;background:var(--fabric);filter:brightness(1.05);border-radius:3px}.cfg-ext{width:26%;height:34%;background:var(--fabric);filter:brightness(1.05);border-radius:4px;align-self:flex-end}.mini-sofa{display:flex;align-items:flex-end;gap:1.5px;height:17px}.mini-arm{width:3px;height:14px;background:currentColor;border-radius:2px 2px 1px 1px}.mini-body{display:flex;align-items:flex-end;gap:1.5px;height:11px}.mini-cushion{width:6px;height:11px;background:currentColor;border-radius:2px}.mini-ext{width:6px;height:6px;background:currentColor;border-radius:1px}.ba-before{background:#eef1f3;font-family:Arial,Helvetica,sans-serif}.bad{display:flex;flex-direction:column;gap:.5rem;height:100%}.bad-head{font-weight:700;font-size:clamp(.85rem,1.9vw,1.1rem);color:#2a2a2a;margin-bottom:.15rem}.bad-field{display:flex;flex-direction:column;gap:3px}.bad-field>span{font-size:.64rem;color:#444}.bad-sel{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #b6bcc2;border-radius:3px;padding:.45rem .6rem;font-size:clamp(.64rem,1.4vw,.76rem);color:#8a8a8a}.bad-sel i{font-style:normal;color:#555}.bad-note{font-size:.58rem;color:#8a8a8a;line-height:1.4}.bad-btn{margin-top:auto;align-self:flex-start;background:#3b6ea5;color:#fff;border:1px solid #2c5580;border-radius:3px;padding:.5rem 1.1rem;font-size:.74rem}.ba-divider{position:absolute;top:0;bottom:0;width:3px;background:var(--accent);z-index:5;transform:translate(-50%);pointer-events:none}.ba-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:var(--accent);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:0 6px 18px color-mix(in srgb,var(--accent) 50%,transparent)}.ba-tag{position:absolute;top:1rem;font-family:var(--font-mono);font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.35rem .75rem;border-radius:999px;z-index:4}.ba-tag--antes{left:1rem;background:#1a1815b3;color:#fff}.ba-tag--despues{right:1rem;background:var(--accent);color:var(--accent-ink)}.ba-hint{margin-top:1.1rem;font-family:var(--font-mono);font-size:.8rem;color:var(--muted)}@media(max-width:680px){.ba-compare{aspect-ratio:1 / 1}.cfg{gap:.45rem}.cfg-opt{font-size:.5rem;padding:.3rem .15rem}.cfg-swatch{width:20px;height:20px}.cfg-group-label{font-size:.54rem}.cfg-pill{font-size:.6rem}}.page{width:90%;max-width:var(--page-max);margin:3rem auto}.page-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,2.75rem);font-weight:800;color:var(--ink);letter-spacing:-.02em;margin-bottom:2.5rem}.works{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.work-item{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;position:relative;transition:transform .22s,box-shadow .22s}.work-item:hover{transform:translateY(-4px);box-shadow:0 16px 40px #00000014}.work-item .mask{height:176px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;flex-shrink:0}.work-item .mask img{max-height:110px;max-width:65%;object-fit:contain}.badge-construccion{position:absolute;top:10px;right:10px;background:var(--accent);color:var(--accent-ink);font-family:var(--font-mono);font-size:.65rem;font-weight:700;padding:.2rem .55rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}.work-overlay{position:absolute;inset:0;background:#e8502af0;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;opacity:0;transition:opacity .2s;border-radius:12px;text-align:center;z-index:2}[data-theme=dark] .work-overlay{background:#f4683cf0}.work-item:hover .work-overlay{opacity:1}.work-overlay p{font-size:.875rem;line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.work-overlay-btn{background:#fff;color:var(--accent);border:none;padding:.45rem 1.1rem;border-radius:6px;font-weight:600;font-size:.85rem;text-decoration:none;flex-shrink:0;transition:transform .15s}.work-overlay-btn:hover{transform:translateY(-1px)}.work-info{padding:1.2rem 1.2rem 1.4rem;display:flex;flex-direction:column;flex:1}.work-info .category{font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-weight:600;margin-bottom:.25rem}.work-info h2{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--ink);margin:0 0 .5rem}.work-info h2 a{color:inherit;text-decoration:none;transition:color .15s}.work-info h2 a:hover{color:var(--accent)}.work-desc{font-size:.85rem;color:var(--muted);line-height:1.6;margin:0 0 1rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}.work-techs{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:auto}.stack-badge{display:inline-flex;align-items:center;gap:.3rem;background:var(--surface-2);color:var(--muted);border:1px solid var(--border);padding:.18rem .55rem;border-radius:4px;font-family:var(--font-mono);font-size:.72rem}.detalle{max-width:680px;margin:0 auto;padding:2.5rem 0;display:flex;flex-direction:column;gap:1.25rem}.btn-back{background:none;border:none;color:var(--accent);font-size:.875rem;font-family:inherit;padding:0;transition:opacity .15s}.btn-back:hover{opacity:.72;text-decoration:underline}.detalle-categoria{font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-weight:600}.detalle h1{font-family:var(--font-display);font-size:2rem;font-weight:800;margin:0;color:var(--ink);letter-spacing:-.02em}.detalle-imagen{width:100%;max-height:300px;object-fit:contain;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);padding:1rem}.detalle-descripcion{font-size:1rem;line-height:1.8;color:var(--muted)}.detalle-techs{display:flex;flex-wrap:wrap;gap:.5rem}.sobre-mi{max-width:720px;margin:0 auto;padding:2rem 0}.sm-hero{text-align:center;margin-bottom:3rem}.sm-hero h1{font-family:var(--font-display);font-size:2.5rem;font-weight:800;margin-bottom:.5rem;color:var(--ink);letter-spacing:-.02em}.sm-tagline{font-size:1.1rem;color:var(--accent);font-style:italic}.sm-section{margin-bottom:3rem}.sm-section h2{font-family:var(--font-display);font-size:1.4rem;font-weight:700;margin-bottom:1rem;border-left:3px solid var(--accent);padding-left:.75rem;color:var(--ink)}.sm-section p{text-align:left;line-height:1.8;color:var(--muted);margin-bottom:1rem}.sm-historia{display:flex;gap:2rem;align-items:center}.sm-historia-img{width:240px;height:320px;object-fit:cover;object-position:top;border-radius:12px;flex-shrink:0;border:1px solid var(--border)}.sm-interests{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.interest-card{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:1.25rem;transition:transform .2s}.interest-card:hover{transform:translateY(-2px)}.interest-icon{font-size:1.5rem;display:block;margin-bottom:.5rem}.interest-card h3{font-family:var(--font-display);font-size:.95rem;font-weight:600;margin-bottom:.4rem;color:var(--ink)}.interest-card p{font-size:.85rem;color:var(--muted);line-height:1.6}.sm-cta{text-align:center;padding:2rem 0;border-top:1px solid var(--border)}.sm-cta p{margin-bottom:1rem;color:var(--muted)}.cv{max-width:760px;margin:0 auto;padding:2rem 0;display:flex;flex-direction:column;gap:2.5rem}.cv-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.cv-header h1{font-family:var(--font-display);font-size:2rem;font-weight:800;margin:0;color:var(--ink);letter-spacing:-.02em}.cv-subtitle{color:var(--accent);font-size:1rem;margin-top:.25rem}.cv-section h2{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);border-bottom:1px solid var(--border);padding-bottom:.5rem;margin-bottom:1.25rem}.cv-item{margin-bottom:1.5rem}.cv-item-header{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:.5rem}.cv-item-header h3{font-family:var(--font-display);font-size:1rem;font-weight:600;margin:0;color:var(--ink)}.cv-date{font-size:.82rem;color:var(--muted);white-space:nowrap;font-family:var(--font-mono)}.cv-company{font-size:.9rem;color:var(--accent);margin:.2rem 0 .4rem}.cv-item p{font-size:.9rem;color:var(--muted);line-height:1.7;text-align:left}.cv-skills{display:flex;flex-direction:column;gap:1rem}.cv-skill-group{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.cv-skill-label{font-size:.82rem;color:var(--muted);min-width:110px;font-family:var(--font-mono)}.cv-skill-tags{display:flex;flex-wrap:wrap;gap:.4rem}.contact-container{max-width:560px;margin:1rem auto;padding:0;text-align:center}.contact-container h1{font-family:var(--font-display);font-size:2.25rem;font-weight:800;margin-bottom:.5rem;color:var(--ink);letter-spacing:-.02em}.contact-container>p{color:var(--muted);margin-bottom:2rem}form{display:flex;flex-direction:column;gap:1rem}.form-group{width:100%;display:flex;flex-direction:column;gap:.3rem;text-align:left}.form-group label{font-family:var(--font-mono);font-size:.72rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}input,textarea{width:100%;padding:.7rem 1rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--ink);font-family:var(--font-body);font-size:1rem;resize:vertical;box-sizing:border-box;transition:border-color .15s}input:focus,textarea:focus{outline:none;border-color:var(--accent)}.btn{background:var(--accent);color:var(--accent-ink);padding:.75rem 2rem;border:none;border-radius:8px;font-weight:600;font-size:.9rem;font-family:var(--font-body);transition:opacity .15s;align-self:center}.btn:hover{opacity:.86}.contact-ok{display:flex;align-items:center;gap:.75rem;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:1.25rem;color:var(--accent);margin-top:1rem;text-align:left}.contact-ok span{font-size:1.5rem;flex-shrink:0}.contact-ok p{margin:0}.galeria{max-width:900px;margin:0 auto;padding:1rem 0}.galeria h1{font-family:var(--font-display);font-size:2rem;font-weight:800;margin-bottom:.25rem;color:var(--ink)}.galeria-sub{color:var(--muted);font-size:1rem;margin-bottom:2rem;text-align:left}.galeria-empty{color:var(--muted);font-style:italic;text-align:center;padding:3rem 0}.galeria-grid{columns:3;gap:12px}.galeria-item{break-inside:avoid;margin-bottom:12px;border-radius:10px;overflow:hidden}.galeria-item img{width:100%;display:block;transition:transform .3s}.galeria-item:hover img{transform:scale(1.02)}.blog-preview-section{width:90%;max-width:var(--page-max);margin:0 auto;padding:4rem 0 2rem}.blog-preview-inner{border-top:1px solid var(--border);padding-top:3rem}.blog-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.blog-preview-all{font-size:.875rem;font-weight:600;color:var(--accent);text-decoration:none;transition:opacity .15s}.blog-preview-all:hover{opacity:.72}.blog-preview-list{display:flex;flex-direction:column}.blog-preview-item{display:grid;grid-template-columns:120px 1fr auto;align-items:center;gap:1.5rem;padding:1.1rem 0;border-bottom:1px solid var(--border);text-decoration:none;color:var(--ink);transition:color .15s}.blog-preview-item:hover{color:var(--accent)}.blog-preview-item:hover .blog-preview-arrow{transform:translate(4px)}.blog-preview-title{font-family:var(--font-display);font-size:1rem;font-weight:600;line-height:1.3}.blog-preview-arrow{color:var(--faint);transition:transform .2s,color .15s;font-size:1rem}.blog-preview-item:hover .blog-preview-arrow{color:var(--accent)}.blog-date{font-family:var(--font-mono);font-size:.72rem;color:var(--faint);letter-spacing:.04em;white-space:nowrap}.blog-tags{display:flex;flex-wrap:wrap;gap:.35rem}.blog-tag{font-family:var(--font-mono);font-size:.68rem;color:var(--accent);background:transparent;border:1px solid var(--border);padding:.15rem .55rem;border-radius:4px;letter-spacing:.03em}.blog-list{display:flex;flex-direction:column;gap:0}.blog-list-item{display:grid;grid-template-columns:200px 1fr auto;gap:2rem;align-items:start;padding:2.5rem 0;border-bottom:1px solid var(--border)}.blog-list-item:first-child{border-top:1px solid var(--border)}.blog-list-meta{display:flex;flex-direction:column;gap:.6rem;padding-top:.2rem}.blog-list-body{display:flex;flex-direction:column;gap:.6rem}.blog-list-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--ink);margin:0;line-height:1.3}.blog-list-title a{color:inherit;text-decoration:none;transition:color .15s}.blog-list-title a:hover{color:var(--accent)}.blog-list-excerpt{font-size:.9rem;color:var(--muted);line-height:1.65;margin:0}.blog-read-link{font-size:.875rem;font-weight:600;color:var(--accent);text-decoration:none;white-space:nowrap;padding-top:.2rem;transition:opacity .15s}.blog-read-link:hover{opacity:.72}.blog-article{max-width:660px;margin:0 auto;padding:2rem 0 4rem;display:flex;flex-direction:column;gap:2rem}.blog-article-header{display:flex;flex-direction:column;gap:.75rem}.blog-article-title{font-family:var(--font-display);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1.1;margin:0}.blog-article-excerpt{font-size:1.1rem;color:var(--muted);line-height:1.7;font-style:italic;border-left:3px solid var(--accent);padding-left:1rem;margin:0}.blog-article-content{display:flex;flex-direction:column;gap:1.25rem;border-top:1px solid var(--border);padding-top:2rem}.blog-article-content h2{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--ink);margin:.75rem 0 0}.blog-article-content p{font-size:1rem;color:var(--muted);line-height:1.85;text-align:left;margin:0}.blog-article-footer{border-top:1px solid var(--border);padding-top:1.5rem}@media(max-width:768px){.blog-preview-item{grid-template-columns:1fr auto;gap:.75rem}.blog-preview-item .blog-date{display:none}.blog-list-item{grid-template-columns:1fr;gap:1rem;padding:2rem 0}.blog-read-link{align-self:flex-start}}.footer{background:#131310;color:#f1efea;padding:4rem 5% 2rem;margin-top:6rem}.footer-inner{display:grid;grid-template-columns:1fr auto auto;gap:3rem;max-width:var(--page-max);margin:0 auto 3rem;align-items:start}.footer-brand p{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:#f1efea;margin:0 0 .35rem}.footer-brand span{font-size:.85rem;color:#f1efea73;display:block}.footer-email{display:inline-block;color:#f4683c;font-family:var(--font-body);font-weight:600;font-size:.95rem;text-decoration:none;margin-top:1rem;transition:opacity .15s}.footer-email:hover{opacity:.78}.footer-nav-title{font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;color:#f1efea61;margin:0 0 1rem}.footer-nav{display:flex;flex-direction:column;gap:.5rem}.footer-nav a{color:#f1efea99;text-decoration:none;font-size:.9rem;transition:color .15s}.footer-nav a:hover{color:#f1efea}.footer-social-block{display:flex;flex-direction:column}.footer-social{display:flex;flex-direction:column;gap:.5rem}.footer-social a{display:flex;align-items:center;gap:.5rem;color:#f1efea99;text-decoration:none;font-size:.9rem;transition:color .15s}.footer-social a:hover{color:#f1efea}.footer-copy{text-align:center;font-family:var(--font-mono);font-size:.75rem;color:#f1efea47;border-top:1px solid rgba(241,239,234,.1);padding-top:1.5rem;max-width:var(--page-max);margin:0 auto}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.reveal{opacity:0;transform:translateY(16px);transition:opacity .45s ease,transform .45s ease;transition-delay:var(--reveal-delay, 0s)}.reveal.revealed{opacity:1;transform:translateY(0)}.back-to-top{position:fixed;bottom:2rem;right:2rem;background:var(--ink);color:var(--bg);border:none;border-radius:50%;width:42px;height:42px;font-size:1.1rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0003;transition:transform .2s;z-index:9000}.back-to-top:hover{transform:translateY(-2px)}@media(max-width:900px){.hero{grid-template-columns:1fr;padding:4rem 0 3.5rem;text-align:center}.hero-content{order:2}.hero-photo{order:1;width:180px;height:220px;margin:0 auto}.hero-body{max-width:100%;margin-inline:auto}.hero-actions{justify-content:center}.project-item{grid-template-columns:1fr;gap:2rem}.project-item--reverse{grid-template-columns:1fr;direction:ltr}.footer-inner{grid-template-columns:1fr;gap:2rem}}@media(max-width:768px){.header{position:sticky}.header nav{display:none;position:absolute;top:64px;left:0;width:100%;background:var(--bg);border-bottom:1px solid var(--border);padding:.75rem 5%;z-index:999}.header nav.is-active{display:block}.header nav ul{flex-direction:column;gap:.1rem}.header nav a{display:block;padding:.65rem .5rem;font-size:1rem}.menu-toggle{display:flex}.btn-cta{display:none}.statement-hi,.statement-rest{font-size:clamp(1.5rem,7vw,2.5rem)}.sm-historia{flex-direction:column}.sm-historia-img{width:100%;height:240px}.sm-interests{grid-template-columns:1fr}.cv-header,.cv-skill-group{flex-direction:column;align-items:flex-start}.works{grid-template-columns:1fr}.galeria-grid{columns:2}}@media(max-width:480px){.hero-name{font-size:2.5rem}.page{margin:1.5rem auto}.galeria-grid{columns:1}}.galeria-page{background:#080808;min-height:100vh;color:#d6d0c8;font-family:Georgia,Times New Roman,serif;overflow-x:hidden}.galeria-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:1.75rem 2.5rem;background:linear-gradient(to bottom,rgba(0,0,0,.65) 0%,transparent 100%);pointer-events:none}.galeria-nav a,.galeria-nav span{pointer-events:all}.galeria-back{color:#d6d0c8a6;text-decoration:none;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-family:sans-serif;transition:color .2s}.galeria-back:hover{color:#d6d0c8}.galeria-brand{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;font-family:sans-serif;color:#d6d0c880}.galeria-hero{height:100vh;background-size:cover;background-position:center 30%;background-attachment:fixed;position:relative}.galeria-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,8,8,.85) 0%,rgba(8,8,8,.15) 50%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:4rem 3.5rem}.galeria-hero-overlay h1{font-size:clamp(3.5rem,9vw,7rem);font-weight:300;margin:0;line-height:.95;color:#f0ede8;letter-spacing:-.02em}.galeria-hero-overlay p{font-size:1rem;color:#f0ede880;margin:1rem 0 0;font-style:italic;letter-spacing:.06em}.galeria-scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;color:#f0ede84d;font-family:sans-serif;font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;animation:fadeInDown 1.5s ease 1s both}.galeria-scroll-arrow{width:1px;height:40px;background:linear-gradient(to bottom,transparent,rgba(240,237,232,.4));animation:extendDown 1.5s ease-in-out infinite}@keyframes extendDown{0%,to{opacity:.3;transform:scaleY(1)}50%{opacity:.7;transform:scaleY(1.2)}}@keyframes fadeInDown{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.galeria-section{padding:3px;margin-top:3px}.galeria-grid{columns:3;gap:3px}.galeria-item{break-inside:avoid;margin-bottom:3px;overflow:hidden;cursor:zoom-in;position:relative}.galeria-item:after{content:"";position:absolute;inset:0;background:#08080800;transition:background .4s ease}.galeria-item:hover:after{background:#08080826}.galeria-item img{width:100%;display:block;transition:transform .6s cubic-bezier(.25,.46,.45,.94);filter:brightness(.88) contrast(1.04)}.galeria-item:hover img{transform:scale(1.04);filter:brightness(1) contrast(1.04)}.galeria-footer{text-align:center;padding:4rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;font-family:sans-serif;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:#d6d0c833}.galeria-ig{color:#d6d0c88c;text-decoration:none;font-size:.9rem;letter-spacing:.12em;transition:color .2s}.galeria-ig:before{content:"↗ ";font-size:.75rem}.galeria-ig:hover{color:#d6d0c8}.galeria-lightbox{position:fixed;inset:0;background:#050505f7;z-index:1000;display:flex;align-items:center;justify-content:center;animation:lbFadeIn .2s ease}@keyframes lbFadeIn{0%{opacity:0}to{opacity:1}}.galeria-lightbox img{max-height:88vh;max-width:88vw;object-fit:contain;-webkit-user-select:none;user-select:none;animation:lbZoomIn .25s ease}@keyframes lbZoomIn{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}.lb-close{position:absolute;top:1.5rem;right:1.75rem;background:none;border:none;color:#f0ede880;font-size:1.25rem;cursor:pointer;font-family:sans-serif;padding:.5rem;line-height:1;transition:color .2s;letter-spacing:0}.lb-close:hover{color:#f0ede8}.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;color:#f0ede859;font-size:2.5rem;cursor:pointer;padding:1.5rem;transition:color .2s;line-height:1;font-family:sans-serif;font-weight:200}.lb-prev{left:0}.lb-next{right:0}.lb-prev:hover,.lb-next:hover{color:#f0ede8}.lb-counter{position:absolute;bottom:1.75rem;left:50%;transform:translate(-50%);font-family:sans-serif;font-size:.68rem;letter-spacing:.22em;color:#f0ede84d;text-transform:uppercase}@media(max-width:768px){.galeria-hero{background-attachment:scroll}.galeria-hero-overlay{padding:2.5rem 1.5rem}.galeria-nav{padding:1.25rem 1.5rem}.galeria-grid{columns:2}.lb-prev{left:0;padding:1rem}.lb-next{right:0;padding:1rem}}@media(max-width:480px){.galeria-grid{columns:1}}.links-page{min-height:100vh;background:#0c0c0c;display:flex;align-items:center;justify-content:center;padding:3rem 1.5rem;font-family:sans-serif;box-sizing:border-box}.links-card{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:0}.links-avatar{width:90px;height:90px;border-radius:50%;object-fit:cover;object-position:top 20%;border:2px solid rgba(255,255,255,.1);margin-bottom:1.1rem}.links-name{color:#f0ede8;font-size:1.05rem;font-weight:600;margin:0 0 .2rem;letter-spacing:.02em}.links-handle{color:#f0ede866;font-size:.8rem;letter-spacing:.1em;margin:0 0 2.25rem}.links-list{width:100%;display:flex;flex-direction:column;gap:.75rem}.links-btn{display:flex;align-items:center;justify-content:center;gap:.65rem;width:100%;padding:.95rem 1.5rem;border-radius:12px;text-decoration:none;font-size:.9rem;font-weight:500;letter-spacing:.03em;cursor:pointer;transition:transform .18s ease,opacity .18s ease;border:none;box-sizing:border-box}.links-btn:hover{transform:translateY(-2px);opacity:.88}.links-btn:active{transform:translateY(0)}.links-btn--portfolio{background:#7c3aed;color:#fff}.links-btn--galeria{background:#ffffff0f;color:#f0ede8;border:1px solid rgba(255,255,255,.1)}.links-btn--linkedin{background:#0a66c2;color:#fff}.links-btn svg{flex-shrink:0}.links-footer{margin-top:2.5rem;color:#f0ede826;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase}
