@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Mono:ital,wght@0,300;0,400;0,500;1,300&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #06060a;--bg2: #0d0d14;--bg3: #13131d;--accent: #00e5b0;--accent-dim: rgba(0, 229, 176, .08);--accent-border: rgba(0, 229, 176, .2);--text: #f0eee8;--text2: #9896a4;--text3: #5a5868;--border: rgba(255, 255, 255, .07);--fh: "Syne", sans-serif;--fb: "DM Sans", sans-serif;--fm: "DM Mono", monospace}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--fb);font-size:16px;line-height:1.7;overflow-x:hidden}.op-cursor{position:fixed;width:10px;height:10px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s;mix-blend-mode:difference}.op-cursor-ring{position:fixed;width:36px;height:36px;border:1.5px solid var(--accent);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.5;transition:width .3s,height .3s,opacity .3s}body.op-ch .op-cursor{width:16px;height:16px}body.op-ch .op-cursor-ring{width:56px;height:56px;opacity:.25}.op-bg-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:.3}.op-sidebar{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:50;display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem 1rem;background:var(--bg2);border-right:1px solid var(--border);border-radius:0 12px 12px 0}.op-sidebar a{color:var(--text3);text-decoration:none;transition:color .2s,transform .2s;display:flex}.op-sidebar a:hover{color:var(--accent);transform:translate(4px)}.op-sidebar svg{width:18px;height:18px}.op-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.4rem 4rem;display:flex;align-items:center;justify-content:space-between;transition:background .4s,backdrop-filter .4s}.op-nav.scrolled{background:rgba(6,6,10,.88);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}.op-nav-logo{font-family:var(--fh);font-weight:800;font-size:1.1rem;letter-spacing:-.03em;color:var(--text);text-decoration:none}.op-nav-logo span{color:var(--accent)}.op-nav-links{display:flex;gap:2.5rem;list-style:none}.op-nav-links a{font-family:var(--fm);font-size:.8rem;color:var(--text2);text-decoration:none;letter-spacing:.05em;position:relative;transition:color .2s}.op-nav-links a:after{content:"";position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--accent);transition:width .3s}.op-nav-links a:hover,.op-nav-links a.active{color:var(--accent)}.op-nav-links a:hover:after,.op-nav-links a.active:after{width:100%}.op-section{position:relative;z-index:1;padding:7rem 5rem 7rem 6rem}.op-section-alt{background:var(--bg2)}.op-section-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:4rem}.op-section-num{font-family:var(--fm);font-size:.75rem;color:var(--accent);letter-spacing:.1em}.op-section-title{font-family:var(--fh);font-size:clamp(2rem,4vw,3rem);font-weight:800;letter-spacing:-.03em}.op-section-line{flex:1;height:1px;background:var(--border);max-width:200px}.op-btn{font-family:var(--fm);font-size:.8rem;letter-spacing:.08em;padding:.85rem 1.75rem;border-radius:4px;text-decoration:none;cursor:none;border:none;display:inline-flex;align-items:center;gap:.5rem;transition:transform .2s,box-shadow .2s,border-color .2s,color .2s}.op-btn-primary{background:var(--accent);color:var(--bg);font-weight:500}.op-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px #00e5b040}.op-btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.op-btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.op-btn-sm{padding:.6rem 1.25rem;font-size:.72rem}.op-btn-demo{background:transparent;color:var(--accent);border:1px solid var(--accent)}.op-btn-demo:hover{background:var(--accent-dim);transform:translateY(-2px)}.op-btn-gh{background:var(--bg3);color:var(--text);border:1px solid var(--border)}.op-btn-gh:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.op-hero{min-height:100vh;display:flex;align-items:center;padding:80px 5rem 0 6rem;position:relative;z-index:1}.op-hero-grid{display:grid;grid-template-columns:1fr auto;align-items:center;gap:4rem;width:100%;max-width:1100px}.op-hero-tag{font-family:var(--fm);font-size:.78rem;color:var(--accent);letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;opacity:0;transform:translateY(20px);animation:op-fadeUp .6s .3s forwards}.op-hero-tag:before{content:"";display:inline-block;width:32px;height:1px;background:var(--accent)}.op-hero-name{font-family:var(--fh);font-weight:800;font-size:clamp(3rem,7vw,6.5rem);line-height:.95;letter-spacing:-.04em;margin-bottom:1.25rem;overflow:hidden}.op-hero-name .line{display:block;opacity:0;transform:translateY(110%);animation:op-slideUp .8s cubic-bezier(.16,1,.3,1) forwards}.op-hero-name .line:nth-child(1){animation-delay:.5s}.op-hero-name .line:nth-child(2){animation-delay:.65s;color:var(--accent)}.op-hero-sub{font-size:1.05rem;color:var(--text2);max-width:480px;margin-bottom:2.5rem;opacity:0;transform:translateY(20px);animation:op-fadeUp .7s .9s forwards;line-height:1.7}.op-hero-tech-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;opacity:0;transform:translateY(20px);animation:op-fadeUp .7s 1s forwards}.op-tech-badge{font-family:var(--fm);font-size:.72rem;color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-border);padding:.35rem .85rem;border-radius:20px;letter-spacing:.04em;transition:background .3s,transform .3s}.op-tech-badge:hover{background:rgba(0,229,176,.15);transform:translateY(-2px)}.op-hero-actions{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;transform:translateY(20px);animation:op-fadeUp .7s 1.1s forwards}.op-hero-photo-wrap{position:relative;opacity:0;animation:op-fadeUp .8s 1.3s forwards}.op-hero-glow{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border-radius:50%;background:radial-gradient(circle,rgba(0,229,176,.15) 0%,transparent 70%);animation:op-glowPulse 3s ease-in-out infinite;pointer-events:none}.op-hero-photo{width:280px;height:280px;border-radius:50%;object-fit:cover;border:2px solid var(--accent-border);box-shadow:0 0 60px #00e5b026,0 0 0 8px #00e5b00a;display:block;animation:op-glowPulse 3s ease-in-out infinite}@keyframes op-glowPulse{0%,to{box-shadow:0 0 40px #00e5b01f,0 0 0 8px #00e5b00a}50%{box-shadow:0 0 80px #00e5b040,0 0 0 12px #00e5b014}}.op-hero-photo-placeholder{width:280px;height:280px;border-radius:50%;background:var(--bg3);border:2px solid var(--accent-border);display:flex;align-items:center;justify-content:center;box-shadow:0 0 60px #00e5b026;font-family:var(--fh);font-size:5rem;font-weight:800;color:var(--accent)}.op-hero-scroll{position:absolute;bottom:2.5rem;left:6rem;display:flex;align-items:center;gap:.75rem;opacity:0;animation:op-fadeUp .7s 1.6s forwards}.op-scroll-line{width:40px;height:1px;background:var(--text3);position:relative;overflow:hidden}.op-scroll-line:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--accent);animation:op-scrollAnim 2s 2s infinite}.op-scroll-label{font-family:var(--fm);font-size:.7rem;color:var(--text3);letter-spacing:.1em}.op-conoceme-intro{color:var(--text2);font-size:1.05rem;max-width:580px;margin-bottom:3rem;line-height:1.8}.op-expertise-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}.op-expertise-card{border:1px solid var(--border);border-radius:16px;background:rgba(13,13,20,.6);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:2.5rem 2rem;position:relative;overflow:hidden;transition:border-color .4s,transform .3s,box-shadow .3s;display:flex;flex-direction:column}.op-expertise-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent);opacity:0;transition:opacity .4s}.op-expertise-card:hover{border-color:var(--accent-border);transform:translateY(-6px);box-shadow:0 12px 48px #00e5b014}.op-expertise-card:hover:before{opacity:1}.op-expertise-icon{width:42px;height:42px;color:var(--accent);margin-bottom:1.25rem}.op-expertise-title{font-family:var(--fh);font-size:1.2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.75rem}.op-expertise-desc{color:var(--text2);font-size:.9rem;line-height:1.7;margin-bottom:1.5rem;flex:1}.op-expertise-tech{display:flex;flex-wrap:wrap;gap:.35rem}.op-expertise-tag{font-family:var(--fm);font-size:.65rem;color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-border);padding:.25rem .65rem;border-radius:12px;letter-spacing:.04em}.op-skills-card{border:1px solid var(--border);border-radius:16px;background:var(--bg2);padding:3rem}.op-skills-grid.desktop-only{display:grid;grid-template-columns:repeat(6,1fr);gap:1.25rem}.op-skills-grid:not(.desktop-only){display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}@media (max-width: 1024px){.op-skills-grid.desktop-only{grid-template-columns:repeat(4,1fr)}}.op-skill-item{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem;border:1px solid var(--border);border-radius:10px;background:var(--bg);transition:border-color .3s,transform .3s,background .3s;cursor:default}.op-skill-item img{width:54x;height:64px;object-fit:contain}.op-skill-name{font-family:var(--fm);font-size:.82rem;color:var(--text2);letter-spacing:.05em;text-align:center}.op-slider-outer{position:relative;overflow:hidden}.op-slider{display:flex;gap:1rem;transition:transform .5s cubic-bezier(.16,1,.3,1)}.op-slide{min-width:calc((100% - 2rem) / 3);flex-shrink:0;height:100%}.op-project-card{border:1px solid var(--border);border-radius:16px;background:rgba(13,13,20,.6);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden;transition:border-color .4s,transform .3s,box-shadow .3s;cursor:pointer;width:100%;max-width:420px;margin:0 auto;height:100%;position:relative;display:flex;flex-direction:column}.op-project-body{padding:1.25rem 1.5rem 1.5rem;flex:1;display:flex;flex-direction:column}.op-project-desc-wrap{margin-bottom:1.5rem;flex:1}.op-project-card:hover{border-color:var(--accent);transform:translateY(-4px)}.op-project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent);opacity:0;transition:opacity .4s}.op-project-card:hover:before{opacity:1}.op-project-img-container{width:100%;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;background:var(--bg3);border-bottom:1px solid var(--border);overflow:hidden}.op-project-img{width:100%;aspect-ratio:16 / 9;object-fit:cover;display:block;border-bottom:1px solid var(--border)}.op-project-img-placeholder{width:100%;aspect-ratio:16/9;background:var(--bg3);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center}.op-project-img-placeholder span{font-family:var(--fh);font-size:1.5rem;font-weight:800;color:var(--text3)}.op-project-title{font-family:var(--fh);font-size:1.75rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.75rem}.op-project-meta{display:flex;gap:1.5rem;margin-bottom:1.25rem;flex-wrap:wrap}.op-project-meta-item{display:flex;align-items:center;gap:.4rem;font-family:var(--fm);font-size:.75rem;color:var(--text2)}.op-project-meta-item strong{color:var(--text)}.op-project-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.75rem}.op-tag{font-family:var(--fm);font-size:.68rem;color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-border);padding:.28rem .7rem;border-radius:4px;letter-spacing:.04em}.op-project-links{display:flex;gap:.75rem}.op-slider-nav{display:flex;justify-content:center;gap:1rem;margin-top:1.25rem}.op-slider-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--bg);color:var(--text2);cursor:none;display:flex;align-items:center;justify-content:center;transition:border-color .2s,color .2s,transform .2s}.op-slider-btn:hover{border-color:var(--accent);color:var(--accent);transform:scale(1.05)}.op-slider-dots{display:flex;gap:.5rem;align-items:center}.op-dot{width:6px;height:6px;border-radius:50%;background:var(--text3);cursor:none;transition:background .3s,width .3s}.op-dot.active{background:var(--accent);width:20px;border-radius:4px}.op-timeline{position:relative;max-width:700px}.op-timeline-line{position:absolute;left:19px;top:0;bottom:0;width:1px;background:var(--border)}.op-timeline-item{position:relative;padding-left:52px;padding-bottom:2.5rem}.op-timeline-item:last-child{padding-bottom:0}.op-timeline-dot{position:absolute;left:12px;top:6px;width:14px;height:14px;border-radius:50%;background:var(--bg);border:2px solid var(--accent);z-index:1}.op-timeline-card{border:1px solid var(--border);border-radius:12px;background:rgba(13,13,20,.6);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:1.5rem 2rem;transition:border-color .3s,transform .3s}.op-timeline-card:hover{border-color:var(--accent-border);transform:translate(6px)}.op-timeline-period{font-family:var(--fm);font-size:.72rem;color:var(--accent);letter-spacing:.08em;display:block;margin-bottom:.5rem}.op-timeline-role{font-family:var(--fh);font-size:1.15rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem}.op-timeline-company{font-family:var(--fm);font-size:.78rem;color:var(--text2);display:block;margin-bottom:.75rem}.op-timeline-desc{color:var(--text2);font-size:.88rem;line-height:1.7;margin-bottom:1rem}.op-timeline-tags{display:flex;flex-wrap:wrap;gap:.35rem}.op-timeline-tag{font-family:var(--fm);font-size:.65rem;color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-border);padding:.25rem .65rem;border-radius:12px}.op-contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start;max-width:900px}.op-contact-info h3{font-family:var(--fh);font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.op-contact-info p{color:var(--text2);margin-bottom:2rem;font-size:.95rem}.op-contact-list{display:flex;flex-direction:column;gap:1rem}.op-contact-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border:1px solid var(--border);border-radius:10px;background:var(--bg2);text-decoration:none;color:var(--text2);font-family:var(--fm);font-size:.8rem;letter-spacing:.04em;transition:border-color .3s,color .3s,transform .3s}.op-contact-item:hover{border-color:var(--accent);color:var(--accent);transform:translate(6px)}.op-contact-item svg{width:18px;height:18px;flex-shrink:0;color:var(--accent)}.op-form-card{border:1px solid var(--border);border-radius:16px;background:rgba(13,13,20,.6);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:2.5rem;position:relative;overflow:hidden;transition:border-color .3s}.op-form-card:hover{border-color:var(--accent-border)}.op-form-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent);opacity:0;transition:opacity .4s}.op-form-card:hover:before{opacity:1}.op-form-card h3{font-family:var(--fh);font-size:1.25rem;font-weight:700;margin-bottom:1.5rem}.op-form-group{margin-bottom:1.1rem}.op-input,.op-select,.op-textarea{width:100%;padding:.85rem 1rem;border-radius:6px;border:1px solid var(--border);background:var(--bg3);color:var(--text);font-family:var(--fb);font-size:.9rem;outline:none;transition:border-color .3s}.op-input::placeholder,.op-textarea::placeholder{color:var(--text3)}.op-input:focus,.op-select:focus,.op-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #00e5b01a}.op-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239896a4' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-color:var(--bg3);padding-right:2.5rem}.op-select option{background:var(--bg3)}.op-textarea{resize:vertical;min-height:120px}.op-btn-send{width:100%;background:var(--accent);color:var(--bg);font-weight:600;border:none;padding:.95rem;border-radius:6px;font-family:var(--fm);font-size:.85rem;letter-spacing:.08em;cursor:none;display:flex;align-items:center;justify-content:center;min-height:48px;transition:transform .2s,box-shadow .2s}.op-btn-send:hover{transform:translateY(-2px);box-shadow:0 8px 32px #00e5b04d}.op-btn-send:disabled{opacity:.7;cursor:not-allowed;transform:none}.op-spinner{width:20px;height:20px;border:2px solid var(--bg);border-top-color:transparent;border-radius:50%;animation:op-spin .6s linear infinite}@keyframes op-spin{to{transform:rotate(360deg)}}.op-form-error{background:rgba(255,70,70,.1);border:1px solid rgba(255,70,70,.25);border-radius:6px;padding:.75rem 1rem;font-family:var(--fm);font-size:.78rem;color:#ff6b6b;margin-bottom:1rem}.op-floating{position:relative}.op-label{position:absolute;left:1rem;top:.85rem;font-family:var(--fb);font-size:.9rem;color:var(--text3);pointer-events:none;transition:top .2s,font-size .2s,color .2s}.op-floating:focus-within .op-label,.op-input:not(:placeholder-shown)~.op-label,.op-textarea:not(:placeholder-shown)~.op-label{top:-.6rem;font-size:.72rem;color:var(--accent)}.op-footer{position:relative;z-index:1;padding:2rem 5rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.op-footer-copy,.op-footer-right{font-family:var(--fm);font-size:.72rem;color:var(--text3);letter-spacing:.04em}.op-footer-right span{color:var(--accent)}.op-footer-left{display:flex;flex-direction:column;gap:.5rem}.op-footer-links{display:flex;gap:1.5rem}.op-footer-links a{font-family:var(--fm);font-size:.72rem;color:var(--text3);text-decoration:none;letter-spacing:.04em;transition:color .2s}.op-footer-links a:hover{color:var(--accent)}.op-legal-page{min-height:100vh;padding:8rem 5rem 4rem 6rem;position:relative;z-index:1}.op-legal-content{max-width:700px}.op-legal-content h1{font-family:var(--fh);font-size:clamp(2rem,4vw,3rem);font-weight:800;letter-spacing:-.03em;margin-bottom:2rem;color:var(--text)}.op-legal-content p{color:var(--text2);font-size:1rem;line-height:1.85;margin-bottom:1.25rem}.op-legal-info{border:1px solid var(--border);border-radius:12px;background:var(--bg2);padding:1.5rem 2rem;margin:1.5rem 0}.op-legal-info p{margin-bottom:.75rem}.op-legal-info p:last-child{margin-bottom:0}.op-legal-info strong{color:var(--text);font-weight:500}@media (max-width: 900px){.op-legal-page{padding:6rem 1.5rem 3rem}.op-legal-content h1{font-size:clamp(1.5rem,6vw,2rem)}.op-legal-info{padding:1rem 1.25rem}.op-footer-links{justify-content:center}}.op-reveal{opacity:0;transform:translateY(40px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}.op-reveal.visible{opacity:1;transform:translateY(0)}.op-reveal-left{transform:translate(-40px)}.op-reveal-left.visible{transform:translate(0)}.op-reveal-right{transform:translate(40px)}.op-reveal-right.visible{transform:translate(0)}.op-reveal-scale{transform:scale(.92)}.op-reveal-scale.visible{transform:scale(1)}.op-rd1{transition-delay:.1s}.op-rd2{transition-delay:.2s}.op-rd3{transition-delay:.3s}.op-rd4{transition-delay:.4s}@keyframes op-fadeUp{to{opacity:1;transform:translateY(0)}}@keyframes op-slideUp{to{opacity:1;transform:translateY(0)}}@keyframes op-scrollAnim{0%{left:-100%}50%{left:100%}to{left:100%}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.op-hero-scroll{display:none}}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.op-btn:focus-visible,.op-btn-send:focus-visible,.op-slider-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.op-mobile-nav{display:none;position:fixed;top:0;right:0;z-index:200;padding:1.25rem 1.5rem}.op-hamburger{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;position:relative;z-index:210}.op-hamburger-line{display:block;width:24px;height:2px;background:var(--text);border-radius:1px;transition:transform .3s var(--ease-out),opacity .3s var(--ease-out)}.op-hamburger-line.open:nth-child(1){transform:translateY(7px) rotate(45deg)}.op-hamburger-line.open:nth-child(2){opacity:0}.op-hamburger-line.open:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.op-mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(6,6,10,.6);z-index:190;animation:op-fadeIn .2s ease}.op-mobile-menu{position:fixed;top:0;right:0;width:min(300px,80vw);height:100vh;background:var(--bg2);border-left:1px solid var(--border);z-index:200;padding:5rem 2rem 2rem;transform:translate(100%);transition:transform .3s cubic-bezier(.16,1,.3,1)}.op-mobile-menu.open{transform:translate(0)}.op-mobile-links{list-style:none;display:flex;flex-direction:column;gap:.5rem}.op-mobile-link{display:block;padding:1rem 1.25rem;font-family:var(--fm);font-size:.85rem;color:var(--text2);text-decoration:none;letter-spacing:.06em;border:1px solid var(--border);border-radius:8px;transition:border-color .2s,color .2s,background .2s}.op-mobile-link:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}@media (max-width: 900px){.op-nav{display:none}.op-mobile-nav{display:block}.op-section,.op-hero{padding:5rem 1.5rem}.op-hero{padding-top:80px;min-height:90vh}.op-hero-grid{grid-template-columns:1fr;text-align:center;gap:2rem}.op-hero-name{font-size:clamp(2.2rem,10vw,3.5rem)}.op-hero-photo,.op-hero-photo-placeholder{width:min(250px,50vw);height:min(250px,50vw);margin:0 auto}.op-hero-photo-wrap{order:-1}.op-hero-glow{top:-10px;right:-10px;bottom:-10px;left:-10px}.op-hero-tag,.op-hero-tech-badges{justify-content:center}.op-hero-actions{justify-content:center;flex-direction:column;align-items:center}.op-hero-scroll{left:1.5rem;bottom:1.25rem}.op-conoceme-intro{max-width:100%;font-size:.95rem}.op-expertise-grid{grid-template-columns:1fr}.op-expertise-card{padding:1.75rem 1.25rem}.op-timeline{max-width:100%}.op-timeline-card{padding:1.25rem}.op-timeline-role{font-size:1rem}.op-section-header{margin-bottom:2.5rem}.op-section-title{font-size:clamp(1.5rem,6vw,2rem)}.op-slide{min-width:85%}.op-project-body{padding:1rem 1.25rem 1.25rem}.op-project-title{font-size:1.35rem}.op-contact-grid{grid-template-columns:1fr}.op-form-card{padding:1.5rem}.op-modal-header{padding:1.25rem 1.25rem 0}.op-modal-title{font-size:1.35rem;padding-right:1.5rem}.op-modal-gallery{padding:1rem 1.25rem;gap:.35rem}.op-modal-body{padding:0 1.25rem 1.25rem}.op-sidebar{display:none}.op-footer{padding:1.5rem;flex-direction:column;gap:.5rem;text-align:center}.op-contact-info h3{font-size:1.25rem}}@media (max-width: 480px){.op-hero-name{font-size:clamp(1.8rem,8vw,2.5rem)}.op-hero-sub{font-size:.9rem}.op-hero-photo,.op-hero-photo-placeholder{width:min(180px,45vw);height:min(180px,45vw)}.op-expertise-card{padding:1.25rem 1rem}.op-form-card{padding:1.25rem}.op-slide{min-width:95%}}.op-project-desc{color:var(--text2);font-size:.9rem;line-height:1.7;margin-bottom:0}.op-btn-link{background:none!important;border:none!important;color:var(--accent)!important;font-family:var(--fm)!important;font-size:.8rem!important;letter-spacing:.04em;cursor:pointer;padding:0;margin-top:.5rem;display:inline-flex;align-items:center;gap:.4rem;transition:color .2s,transform .2s}.op-btn-link:hover{color:var(--text);transform:translate(4px)}.op-btn-link:before{content:"";width:16px;height:1px;background:var(--accent);transition:width .2s}.op-btn-link:hover:before{width:24px}.op-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;padding:1rem;animation:op-fadeIn .3s ease}.op-modal-overlay:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}@keyframes op-fadeIn{0%{opacity:0}to{opacity:1}}.op-modal-content{background:var(--bg);border:1px solid var(--accent-border);border-radius:16px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;position:relative;animation:op-scaleIn .3s ease;box-shadow:0 0 60px #00e5b01f}@keyframes op-scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.op-modal-accent-line{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent)}.op-modal-close{position:absolute;top:1rem;right:1rem;z-index:10;background:var(--bg3);border:1px solid var(--border);border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text2);cursor:pointer;transition:border-color .2s,color .2s}.op-modal-close:hover{border-color:var(--accent);color:var(--accent)}.op-modal-header{padding:2rem 2rem 0}.op-modal-title{font-family:var(--fh);font-size:1.75rem;font-weight:800;letter-spacing:-.03em;padding-right:2rem}.op-modal-gallery{display:flex;align-items:center;gap:.5rem;padding:1.5rem 2rem}.op-modal-image-wrap{flex:1;aspect-ratio:16/9;overflow:hidden;border-radius:8px;background:var(--bg2);display:flex;align-items:center;justify-content:center}.op-modal-image{max-width:100%;max-height:100%;object-fit:contain}.op-gallery-btn{width:36px;height:36px;flex-shrink:0;border-radius:8px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s,color .2s}.op-gallery-btn:hover{border-color:var(--accent);color:var(--accent)}.op-modal-dots{display:flex;justify-content:center;gap:.5rem;padding-bottom:1rem}.op-modal-dot{width:8px;height:8px;border-radius:50%;background:var(--text3);border:none;cursor:pointer;transition:background .3s,width .3s}.op-modal-dot.active{background:var(--accent)}.op-modal-body{padding:0 2rem 2rem}.op-modal-desc{color:var(--text2);font-size:.95rem;line-height:1.8;white-space:pre-wrap;margin-bottom:1.5rem}.op-modal-meta{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:1.25rem}.op-modal-content::-webkit-scrollbar{width:6px}.op-modal-content::-webkit-scrollbar-track{background:var(--bg2)}.op-modal-content::-webkit-scrollbar-thumb{background:var(--text3);border-radius:3px}.op-modal-content::-webkit-scrollbar-thumb:hover{background:var(--accent)}.op-modal-content{scrollbar-width:thin;scrollbar-color:var(--text3) var(--bg2)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--text3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}.op-skills-slider-outer{position:relative;overflow:hidden;display:none}.op-skills-slider{display:flex;transition:transform .5s cubic-bezier(.16,1,.3,1)}.op-skills-slide{min-width:100%;display:flex;justify-content:center;gap:1rem;padding:1rem 0}.op-skill-item{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem;border:1px solid var(--border);border-radius:10px;background:var(--bg2);transition:border-color .3s,transform .3s,background .3s;cursor:default;min-width:140px}.op-skill-item:hover{border-color:var(--accent);transform:translateY(-5px);background:var(--accent-dim)}.op-skill-icon{width:44px;height:44px;object-fit:contain}.op-skill-name{font-family:var(--fm);font-size:.72rem;color:var(--text2);letter-spacing:.05em;text-align:center}.op-skills-dots{display:none;justify-content:center;gap:.5rem;margin-top:1rem}.op-skill-dot{width:8px;height:8px;border-radius:50%;background:var(--text3);border:none;cursor:pointer;transition:background .3s,width .3s;padding:0}.op-skill-dot.active{background:var(--accent);width:20px;border-radius:4px}.desktop-only{display:none}@media (max-width: 900px){#op-skills-slider-wrapper{display:block!important}#op-skills-dots-wrapper{display:flex!important}#op-skills-grid-wrapper{display:none!important}}@media (min-width: 901px){#op-skills-slider-wrapper,#op-skills-dots-wrapper{display:none!important}#op-skills-grid-wrapper{display:grid!important}}
