@import "https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap";:root{--primary:#17a697;--dark:#1f2937;--light:#f3f4f6;--text-primary:var(--dark);--text-secondary:#6b7280;--bg-primary:#fff;--bg-secondary:var(--light);--border:#e5e7eb;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-full:9999px;--transition:.3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Poppins,sans-serif;line-height:1.6}a{color:var(--primary);transition:color var(--transition);text-decoration:none}a:hover{color:var(--dark)}button{cursor:pointer;border:none;font-family:Poppins,sans-serif}@media (prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.navbar{z-index:100;background:0 0;width:100%;height:68px;position:fixed;top:10px;left:0}.navbar-container{justify-content:space-between;align-items:center;width:100%;max-width:1280px;height:100%;margin:0 auto;padding:0 32px;display:flex}.navbar-logo{color:var(--text-primary);letter-spacing:-.3px;transition:opacity var(--transition), transform .35s cubic-bezier(.4, 0, .2, 1);font-size:20px;font-weight:700}.navbar-logo:hover{opacity:.7;color:var(--text-primary)}.navbar-logo.hidden{opacity:0;pointer-events:none;transform:translate(-120px)}.navbar-actions{align-items:center;gap:12px;transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .35s cubic-bezier(.4,0,.2,1);display:flex}.navbar-actions.hidden{opacity:0;pointer-events:none;transform:translate(120px)}.collab-btn{border-radius:var(--radius-lg);border:1.5px solid var(--text-primary);color:var(--text-primary);transition:background-color var(--transition), color var(--transition), border-color var(--transition);white-space:nowrap;background:0 0;padding:8px 20px;font-size:13px;font-weight:500}.collab-btn:hover{background-color:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.menu-toggle{border-radius:var(--radius-full);cursor:pointer;transition:background-color var(--transition), color var(--transition);color:var(--text-primary);background:0 0;align-items:center;gap:6px;padding:8px 14px;display:flex}.menu-toggle:hover{color:var(--text-primary)}.toggle-label{color:inherit;font-size:13px;font-weight:500}.toggle-icon{color:inherit;align-items:center;font-size:18px;display:flex}.toggle-icon:hover{color:var(--primary)}.nav-panel{background-color:var(--dark);border-radius:var(--radius-lg);z-index:200;pointer-events:none;opacity:0;transform-origin:100% 0;flex-direction:column;gap:0;width:340px;padding:24px;transition:opacity .25s cubic-bezier(.4,0,.2,1),transform .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:20px;right:20px;transform:translateY(-12px)scale(.97)}.nav-panel.open{pointer-events:all;opacity:1;transform:translateY(0)scale(1)}.panel-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.panel-label{color:#ffffff73;letter-spacing:.5px;text-transform:uppercase;font-size:13px;font-weight:500}.panel-close{color:#ffffff73;cursor:pointer;transition:color var(--transition);background:0 0;border:none;align-items:center;gap:6px;padding:0;font-family:Poppins,sans-serif;font-size:13px;font-weight:500;display:flex}.panel-close ion-icon{font-size:16px}.panel-close:hover{color:#fff}.panel-nav{flex:1}.panel-nav ul{margin:0;padding:0;list-style:none}.panel-nav li{border-top:1px solid #ffffff14}.panel-nav li:last-child{border-bottom:1px solid #ffffff14}.panel-nav-link{color:#fff;letter-spacing:-.5px;transition:color var(--transition);padding:14px 0;font-size:28px;font-weight:600;line-height:1.2;display:block}.panel-nav-link:hover{color:var(--primary)}.panel-footer{justify-content:space-between;align-items:flex-end;gap:16px;margin-top:28px;display:flex}.panel-email{color:#ffffff8c;text-underline-offset:3px;transition:color var(--transition);font-size:12px;font-weight:400;text-decoration:underline}.panel-email:hover{color:#fff}.panel-social{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.panel-social-link{color:#ffffff8c;transition:color var(--transition);text-align:right;font-size:12px;font-weight:400}.panel-social-link:hover{color:#fff}.nav-overlay{z-index:150;background:0 0;position:fixed;inset:0}@media (width<=767px){.navbar-container{padding:0 16px}.navbar-logo{font-size:18px}.toggle-label{display:none}.menu-toggle{padding:8px 10px}.nav-panel{width:auto;top:12px;left:12px;right:12px}.panel-nav-link{font-size:22px}}.footer{background-color:#0000;position:relative}.footer__wave{line-height:0;display:block;overflow:hidden}.footer__wave img{object-fit:cover;object-position:bottom;width:100%;max-height:360px;display:block}.footer__body{background-color:#1f2937;padding:40px 24px 24px}.footer__container{flex-direction:column;gap:40px;width:100%;max-width:1280px;margin:0 auto;display:flex}.footer__brand{flex-direction:column;gap:12px;max-width:320px;display:flex}.footer__logo{color:#fff;align-items:center;gap:8px;text-decoration:none;transition:opacity .2s;display:inline-flex;transform:translate(-20px)translateY(10px)}.footer__logo:hover{opacity:.8;color:#fff}.footer__logo:focus-visible{outline-offset:4px;border-radius:4px;outline:2px solid #fff9}.footer__logo-icon{color:#17a697;font-size:1.5rem}.footer__logo-name{letter-spacing:-.02em;color:#fff;font-size:1.1rem;font-weight:700;transform:translate(-20px)}.footer__logo-name em{color:#fff9;font-style:normal}.footer__tagline{color:#ffffff8c;font-size:.82rem;line-height:1.7}.footer__nav{flex-wrap:wrap;gap:32px 48px;display:flex}.footer__nav-group{flex-direction:column;gap:12px;display:flex}.footer__nav-heading{letter-spacing:.12em;text-transform:uppercase;color:#17a697;font-size:.65rem;font-weight:700}.footer__nav-list{flex-direction:column;gap:8px;list-style:none;display:flex}.footer__nav-link{color:#ffffffbf;align-items:center;gap:4px;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s,gap .2s;display:inline-flex}.footer__nav-link:hover{color:#17a697;gap:6px}.footer__nav-link:focus-visible{outline-offset:3px;border-radius:3px;outline:2px solid #fff9}.footer__ext-icon{opacity:.6;font-size:.75rem;transition:opacity .2s}.footer__nav-link:hover .footer__ext-icon{opacity:1}.footer__bottom{text-align:center;border-top:1px solid #ffffff14;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:1280px;margin:32px auto 0;padding-top:20px;display:flex}.footer__copy{color:#fff6;font-size:.78rem}.footer__credit{color:#fff6;align-items:center;gap:4px;font-size:.78rem;display:inline-flex}.footer__heart{color:#ff6b6b;vertical-align:middle;font-size:.85rem;animation:1.8s ease-in-out infinite heartbeat}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}@media (prefers-reduced-motion:reduce){.footer__heart{animation:none}}@media (width>=640px){.footer__bottom{text-align:left;flex-direction:row;justify-content:space-between}}@media (width>=1024px){.footer__wave img{transform:translateY(180px)}.footer__body{padding:56px 64px 32px}.footer__container{flex-direction:row;justify-content:space-between;align-items:flex-start}.footer__brand{max-width:280px}.footer__nav{gap:40px 64px}}.hero{align-items:center;max-width:93svw;min-height:100svh;padding:88px 24px 40px;display:flex}.hero__container{flex-direction:column;align-items:center;gap:48px;width:100%;max-width:1280px;margin:0 auto;display:flex}.hero__content{text-align:left;flex-direction:column;gap:16px;display:flex}.hero__title{color:var(--dark);letter-spacing:-.02em;font-size:clamp(1rem,3vw,3rem);font-weight:700;line-height:1.15}.hero__subtitle{color:var(--text-secondary);font-size:1rem;font-weight:500}.hero__subtitle span{color:var(--primary);font-weight:600;display:inline-block;position:relative}.hero__subtitle span:after{content:"";background-color:var(--primary);border-radius:var(--radius-full);opacity:.4;width:100%;height:2px;position:absolute;bottom:-2px;left:0}.hero__description{color:var(--text-secondary);max-width:480px;font-size:.975rem;line-height:1.75}.hero__cta{flex-wrap:wrap;align-items:center;gap:16px;margin-top:8px;display:flex}.hero__socials{gap:10px;display:flex}.hero__social-card{border:1.5px solid var(--border,#e5e7eb);width:44px;height:44px;color:var(--dark);background:#fff;border-radius:12px;justify-content:center;align-items:center;text-decoration:none;transition:border-color .2s,color .2s,transform .2s,box-shadow .2s;display:inline-flex}.hero__social-card ion-icon{font-size:1.2rem}.hero__social-card:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #17a69726}.hero__social-card:focus-visible{outline:2px solid var(--primary);outline-offset:3px}.hero__btn-preview{border:1.5px solid var(--border,#e5e7eb);background:#fff;border-radius:8px;align-items:stretch;display:inline-flex;overflow:hidden}.hero__btn-preview__label{color:var(--dark);align-items:center;padding:9px 14px;font-family:Poppins,sans-serif;font-size:.875rem;font-weight:500;text-decoration:none;transition:background-color .15s;display:inline-flex}.hero__btn-preview__label:hover{background-color:#f5f5f5}.hero__btn-preview__icon{border-left:1.5px solid var(--border,#e5e7eb);color:var(--dark);justify-content:center;align-items:center;padding:9px 10px;text-decoration:none;transition:background-color .15s;display:inline-flex}.hero__btn-preview__icon ion-icon{font-size:1rem}.hero__btn-preview__icon:hover{background-color:#f5f5f5}.hero__btn-preview__label:focus-visible,.hero__btn-preview__icon:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.hero__illustration{justify-content:center;align-items:center;width:100%;max-width:420px;display:flex}.hero__photo-wrap{width:100%;max-width:380px;position:relative}.hero__photo-wrap img{object-fit:contain;width:100%;height:auto;display:block}.tech-chip{border:1.5px solid var(--border,#e5e7eb);width:42px;height:42px;transform:rotate(var(--rot,0deg));animation:4s ease-in-out infinite floatChip;animation-delay:var(--delay,0s);background:#fff;border-radius:12px;justify-content:center;align-items:center;margin-left:70px;display:flex;position:absolute;box-shadow:0 4px 16px #00000014}.tech-chip img{object-fit:contain;width:22px;height:22px;display:block}@keyframes floatChip{0%,to{translate:0}50%{translate:0 -7px}}@media (prefers-reduced-motion:reduce){.tech-chip{animation:none}}@media (width>=1024px){.hero{max-width:100vw;padding:0 64px}.hero__container{flex-direction:row;justify-content:space-between;gap:64px}.hero__content{flex:1;max-width:560px}.hero__illustration{flex:none;max-width:480px}.hero__photo-wrap{max-width:440px}}.about{background-color:var(--bg-primary);padding:80px 24px}.about__container{flex-direction:column;align-items:center;gap:40px;width:100%;max-width:1280px;margin:0 auto;display:flex}.about__illustration{justify-content:center;width:100%;max-width:420px;display:flex}.about__illustration img{object-fit:contain;width:100%;height:auto}.about__content{text-align:left;flex-direction:column;gap:16px;display:flex}.about__title{color:var(--dark);letter-spacing:-.02em;font-size:clamp(1.75rem,5vw,2.5rem);font-weight:700;line-height:1.15}.about__description{color:var(--text-secondary);max-width:520px;font-size:.95rem;line-height:1.8}.about__divider{border:none;border-top:2px solid var(--border);margin:4px 0}.about__cta{flex-wrap:wrap;gap:12px;margin-top:4px;display:flex}.about__btn{border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);border:none;outline:none;align-items:center;gap:8px;padding:12px 28px;font-family:Poppins,sans-serif;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.about__btn:focus-visible{outline:2px solid var(--primary);outline-offset:3px}.about__btn--primary{background-color:var(--primary);color:#fff;box-shadow:0 4px 14px #17a6974d}.about__btn--primary:hover{color:#fff;background-color:#149486;transform:translateY(-2px);box-shadow:0 6px 20px #17a69766}.about__btn--primary:active{transform:translateY(0);box-shadow:0 2px 8px #17a6974d}.about__btn--outline{color:var(--primary);border:2px solid var(--primary);background-color:#0000}.about__btn--outline:hover{color:var(--primary);background-color:#17a6970f;transform:translateY(-2px)}.about__btn--outline:active{transform:translateY(0)}@media (width>=1024px){.about{padding:80px 64px}.about__container{flex-direction:row;align-items:center;gap:80px}.about__illustration{flex:none;max-width:480px}.about__content{flex:1}.about__description{max-width:100%}}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.skills{padding:80px 24px}.skills__container{width:100%;max-width:1280px;margin:0 auto}.skills__header{text-align:center;margin-bottom:56px}.skills__eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;font-size:.7rem;font-weight:600;display:block}.skills__title{color:var(--dark);letter-spacing:-.025em;margin:0 0 14px;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;line-height:1.15}.skills__title .accent{color:var(--primary)}.skills__desc{color:var(--text-secondary);max-width:400px;margin:0 auto;font-size:.95rem;line-height:1.65}.tools-marquee{margin-bottom:56px;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 18% 82%,#0000 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 18% 82%,#0000 100%)}.tools-marquee__track{width:max-content;animation:24s linear infinite marquee;display:flex}.tools-marquee__track:hover{animation-play-state:paused}.tools-marquee__item{white-space:nowrap;border-right:1px solid var(--border);cursor:default;align-items:center;gap:10px;padding:10px 28px;transition:opacity .2s;display:flex}.tools-marquee__item:hover{opacity:.65}.tools-marquee__item i{font-size:28px;line-height:1}.tools-marquee__item span{color:var(--text-primary);letter-spacing:-.01em;font-size:.85rem;font-weight:500}.skills__grid{grid-template-columns:repeat(3,1fr);gap:32px 24px;max-width:380px;margin:0 auto;display:grid}.skills__item{transition:opacity var(--transition);cursor:default;flex-direction:column;align-items:center;gap:12px;padding:24px 16px;display:flex}.skills__item:hover{opacity:.65}.skills__icon{justify-content:center;align-items:center;width:48px;height:48px;display:flex}.skills__icon i{font-size:48px;line-height:1}.skills__icon img{object-fit:contain;width:48px;height:48px}.skills__name{color:var(--text-primary);text-align:center;font-size:.9rem;font-weight:500}@media (width>=640px){.skills__grid{grid-template-columns:repeat(3,1fr);max-width:640px}}@media (width>=1024px){.skills{padding:96px 64px}.skills__grid{grid-template-columns:repeat(4,1fr);gap:32px;max-width:900px}}.projects{background-color:var(--bg-primary);padding:80px 24px}.projects__container{width:100%;max-width:1280px;margin:0 auto}.projects__header{text-align:center;margin-bottom:56px}.projects__eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin-bottom:12px;font-size:.7rem;font-weight:600;display:inline-block}.projects__title{color:var(--dark);letter-spacing:-.03em;margin-bottom:12px;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;line-height:1.15}.projects__title em{color:var(--primary);font-style:normal}.projects__subtitle{color:var(--text-secondary,#64748b);max-width:440px;margin:0 auto;font-size:.95rem;line-height:1.7}.projects__layout{flex-direction:column;gap:40px;display:flex}.projects__right{order:-1}.projects__grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.project-section{flex-direction:column;gap:20px;display:flex}.project-card{border-radius:var(--radius-lg,16px);aspect-ratio:4/3;cursor:pointer;background-color:var(--dark);position:relative;overflow:hidden}.project-card__thumbnail{object-fit:cover;width:100%;height:100%;transition:transform .4s cubic-bezier(.4,0,.2,1),filter .4s cubic-bezier(.4,0,.2,1);display:block}.project-card:hover .project-card__thumbnail,.project-card:focus-visible .project-card__thumbnail{filter:brightness(.3);transform:scale(1.05)}.project-card__overlay{background:linear-gradient(#0a101e1a 0%,#0a101e73 45%,#0a101ef2 100%);flex-direction:column;justify-content:flex-end;padding:20px;display:flex;position:absolute;inset:0}.project-card__info{flex-direction:column;align-items:flex-start;display:flex}.project-card__tag{letter-spacing:.1em;text-transform:uppercase;color:var(--primary);opacity:0;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;margin-bottom:6px;padding:2px 8px;font-size:.65rem;font-weight:700;transition:opacity .25s,transform .25s;transform:translateY(6px)}.project-card__name{color:#fff;letter-spacing:-.01em;opacity:0;-webkit-line-clamp:1;-webkit-box-orient:vertical;margin-bottom:4px;font-size:1rem;font-weight:700;transition:opacity .28s 40ms,transform .28s 40ms;display:-webkit-box;overflow:hidden;transform:translateY(8px)}.project-card__desc{color:#fff9;-webkit-line-clamp:2;opacity:0;-webkit-box-orient:vertical;font-size:.78rem;line-height:1.6;transition:opacity .28s 70ms,transform .28s 70ms;display:-webkit-box;overflow:hidden;transform:translateY(8px)}.project-card__btn-unused{display:none}.project-card__open-icon{z-index:2;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;pointer-events:none;background:#ffffff26;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:opacity .25s,transform .25s;display:flex;position:absolute;top:12px;right:12px;transform:translateY(-4px)}.project-card__open-icon .material-symbols-outlined{color:#fff;font-size:1rem}.project-card:hover .project-card__open-icon,.project-card:focus-visible .project-card__open-icon{opacity:1;transform:translateY(0)}.lightbox{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000e0;justify-content:center;align-items:center;animation:.2s lightbox-in;display:flex;position:fixed;inset:0}@keyframes lightbox-in{0%{opacity:0}to{opacity:1}}.lightbox__inner{flex-direction:column;width:100%;max-width:1080px;max-height:90vh;padding:0 16px;display:flex;position:relative}.lightbox__topbar{justify-content:space-between;align-items:center;padding:0 0 12px;display:flex}.lightbox__actions-left{align-items:center;gap:8px;display:flex}.lightbox__btn-visit{color:#fff;background:0 0;border:1px solid #ffffff59;border-radius:8px;align-items:center;gap:6px;padding:7px 16px;font-size:.82rem;font-weight:500;text-decoration:none;transition:border-color .2s,background .2s;display:inline-flex}.lightbox__btn-visit:hover{color:var(--light);background:#ffffff14;border-color:#ffffffb3}.lightbox__btn-visit .material-symbols-outlined{font-size:1rem}.lightbox__btn-download{color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff59;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:border-color .2s,background .2s;display:flex}.lightbox__btn-download:hover{background:#ffffff14;border-color:#ffffffb3}.lightbox__btn-download .material-symbols-outlined{font-size:1.1rem}.lightbox__close{color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff59;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:border-color .2s,background .2s;display:flex}.lightbox__close:hover{background:#ffffff14;border-color:#ffffffb3}.lightbox__close .material-symbols-outlined{font-size:1.1rem}.lightbox__img-wrap{flex:1;justify-content:center;align-items:center;min-height:0;display:flex;overflow:hidden}.lightbox__img{object-fit:contain;border-radius:12px;max-width:100%;max-height:calc(90vh - 60px);display:block}.project-card:hover .project-card__tag,.project-card:focus-visible .project-card__tag,.project-card:hover .project-card__name,.project-card:focus-visible .project-card__name,.project-card:hover .project-card__desc,.project-card:focus-visible .project-card__desc{opacity:1;transform:translateY(0)}.project-card:focus-visible{outline:2px solid var(--primary);outline-offset:3px}.projects__pagination{justify-content:center;align-items:center;gap:8px;display:flex}.pagination__dot{background:var(--border,#e2e8f0);cursor:pointer;border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:background .2s,transform .2s,width .25s}.pagination__dot--active{background:var(--primary);border-radius:4px;width:24px}.pagination__dot:focus-visible{outline:2px solid var(--primary);outline-offset:3px}.expand-cards{border-radius:var(--radius-lg,16px);flex-direction:row;gap:8px;height:260px;display:flex;overflow:hidden}.expand-card{cursor:pointer;border-radius:12px;flex:1;min-width:0;transition:flex .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.expand-card--active{flex:4}.expand-card__img{object-fit:contain;width:100%;height:100%;transition:filter .3s;display:block}.expand-card:not(.expand-card--active) .expand-card__img{filter:brightness(.55)saturate(.6);object-fit:cover}.expand-card__label{background:linear-gradient(#0000 0%,#0a101ed9 100%);align-items:flex-end;padding:46px 14px 12px;display:flex;position:absolute;bottom:0;left:0;right:0}.expand-card__label span{color:#fff;white-space:nowrap;text-overflow:ellipsis;opacity:0;font-size:.78rem;font-weight:600;transition:opacity .25s .2s,transform .25s .2s;overflow:hidden;transform:translateY(4px)}.expand-card--active .expand-card__label span{opacity:1;transform:translateY(0)}.expand-card:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media (prefers-reduced-motion:reduce){.project-card__thumbnail,.project-card__tag,.project-card__name,.project-card__desc,.project-card__btn,.expand-card,.expand-card__label span{transition:none}.project-card:hover .project-card__tag,.project-card:hover .project-card__name,.project-card:hover .project-card__desc,.project-card:hover .project-card__btn,.expand-card--active .expand-card__label span{opacity:1;transform:none}}@media (width>=1024px){.projects{padding:100px 64px}.projects__layout{flex-direction:row;align-items:stretch;gap:32px}.projects__left{flex:1;min-width:0}.project-section{max-height:100px}.projects__grid{flex:1;grid-template-columns:repeat(2,1fr);gap:16px}.projects__right{flex-direction:column;flex:0 0 320px;order:0;display:flex}.projects__right .expand-cards{flex-direction:column;flex:1;height:auto;max-height:640px}.projects__right .expand-card{flex:1;min-height:0}.projects__right .expand-card--active{flex:4}.projects__pagination{display:none}}.collaborators{background:var(--bg-light);padding:96px 104px;overflow:hidden}.collaborators__header{text-align:center;margin-bottom:56px;padding:0 24px}.collaborators__eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--primary);margin-bottom:12px;font-size:11px;font-weight:600;display:inline-block}.collaborators__title{color:var(--dark);letter-spacing:-.02em;font-size:clamp(28px,4vw,40px);font-weight:700;line-height:1.2}.collaborators__title span{color:var(--primary)}.collaborators__subtitle{color:var(--text-secondary);max-width:480px;margin-top:12px;margin-left:auto;margin-right:auto;font-size:15px}.collaborators__marquee-wrap{gap:16px;height:540px;display:flex;-webkit-mask-image:linear-gradient(#0000 0%,#000 12% 88%,#0000 100%);mask-image:linear-gradient(#0000 0%,#000 12% 88%,#0000 100%)}.collaborators__column{flex:1;min-width:0;position:relative;overflow:hidden}.collaborators__track{will-change:transform;flex-direction:column;gap:16px;display:flex}.collaborators__column--up .collaborators__track{animation:22s linear infinite collab-scroll-up}.collaborators__column--down .collaborators__track{animation:26s linear infinite collab-scroll-down}.collaborators__column--up-alt .collaborators__track{animation:30s linear infinite collab-scroll-up}.collaborators__column:hover .collaborators__track{animation-play-state:paused}@keyframes collab-scroll-up{0%{transform:translateY(0)}to{transform:translateY(-50%)}}@keyframes collab-scroll-down{0%{transform:translateY(-50%)}to{transform:translateY(0)}}.collab-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);transition:box-shadow var(--transition), border-color var(--transition);flex-shrink:0;padding:20px}.collab-card:hover{border-color:var(--primary);box-shadow:0 8px 24px #00000014}.collab-card__header{align-items:center;gap:12px;margin-bottom:14px;display:flex}.collab-card__avatar{border-radius:var(--radius-full);object-fit:cover;border:2px solid var(--border);flex-shrink:0;width:44px;height:44px}.collab-card__meta{min-width:0}.collab-card__name{color:var(--dark);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:600;line-height:1.3;overflow:hidden}.collab-card__handle{color:var(--text-secondary);font-size:12px;line-height:1.3}.collab-card__quote{color:var(--text-secondary);font-size:13.5px;line-height:1.6}.collab-card__quote strong{color:var(--dark);font-weight:500}@media (width<=768px){.collaborators{padding:96px 34px}.collab-card{max-width:200px}.collaborators__marquee-wrap{height:480px}.collaborators__column--up-alt{display:none}}.commentars-section{flex-direction:column;gap:24px;width:100%;padding:20px 40px;display:flex}.commentars-editor-wrapper{position:relative}.commentars-editor{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);transition:filter .2s;overflow:hidden}.commentars-editor.blurred{filter:blur(4px);pointer-events:none;-webkit-user-select:none;user-select:none}.editor-user-row{align-items:center;gap:8px;padding:10px 16px 0;display:flex}.editor-username{color:var(--text-primary);flex:1;font-size:.8125rem;font-weight:600}.btn-logout{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-secondary);transition:color var(--transition), background var(--transition);background:0 0;justify-content:center;align-items:center;display:flex}.btn-logout:hover{color:#ef4444;background:#ef444414}.btn-logout ion-icon{font-size:16px}.commentars-editor textarea{resize:none;width:100%;min-height:100px;color:var(--text-primary);background:0 0;border:none;outline:none;padding:16px;font-family:Poppins,sans-serif;font-size:.875rem;line-height:1.6}.commentars-editor textarea:disabled{cursor:default;opacity:.6}.commentars-editor textarea::placeholder{color:var(--text-secondary)}.editor-toolbar{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.toolbar-actions{align-items:center;gap:4px;display:flex}.toolbar-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);transition:background var(--transition), color var(--transition);background:0 0;justify-content:center;align-items:center;display:flex}.toolbar-btn:hover:not(:disabled){background:var(--border);color:var(--text-primary)}.toolbar-btn:disabled{opacity:.4;cursor:default}.toolbar-btn ion-icon{font-size:16px}.toolbar-right{align-items:center;gap:12px;display:flex}.char-count{color:var(--text-secondary);font-size:.75rem}.btn-submit{background:var(--primary);color:#fff;border-radius:var(--radius-full);transition:opacity var(--transition), transform var(--transition);align-items:center;gap:6px;padding:8px 18px;font-size:.8125rem;font-weight:600;display:flex}.btn-submit:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.btn-submit:disabled{opacity:.45;cursor:default}.btn-submit ion-icon{font-size:15px}.login-gate-backdrop{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(2px);z-index:10;cursor:default;background:#00000040;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:absolute;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-gate-inner{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:28px 32px;display:flex}.login-gate-inner>ion-icon{color:var(--text-primary);font-size:32px}.login-gate-tagline{color:var(--text-secondary);max-width:220px;font-size:.8125rem;line-height:1.5}.btn-github-login{background:var(--text-primary);color:var(--bg-primary,#0d1117);border-radius:var(--radius-full);transition:opacity var(--transition), transform var(--transition);align-items:center;gap:8px;padding:10px 22px;font-size:.875rem;font-weight:600;display:flex}.btn-github-login:hover{opacity:.88;transform:translateY(-1px)}.btn-github-login ion-icon{font-size:18px}.reply-editor{background:var(--bg-primary,#0d1117);border:1px solid var(--border);border-radius:var(--radius-lg);margin-top:10px;overflow:hidden}.reply-editor textarea{resize:none;width:100%;color:var(--text-primary);background:0 0;border:none;outline:none;padding:12px 14px;font-family:Poppins,sans-serif;font-size:.8125rem;line-height:1.6}.reply-editor textarea::placeholder{color:var(--text-secondary)}.reply-editor-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.reply-editor-actions{align-items:center;gap:8px;display:flex}.btn-cancel{border-radius:var(--radius-full);color:var(--text-secondary);border:1px solid var(--border);transition:color var(--transition), border-color var(--transition);background:0 0;padding:6px 14px;font-size:.8125rem;font-weight:500}.btn-cancel:hover{color:var(--text-primary);border-color:var(--text-secondary)}.comments-list-wrapper{flex-direction:column;gap:16px;display:flex}.comments-header{justify-content:space-between;align-items:center;display:flex}.comments-count{color:var(--text-primary);font-size:1.125rem;font-weight:700}.sort-tabs{align-items:center;gap:4px;display:flex}.sort-tab{border-radius:var(--radius-full);color:var(--text-secondary);transition:all var(--transition);letter-spacing:.04em;background:0 0;border:1px solid #0000;padding:5px 12px;font-size:.75rem;font-weight:600}.sort-tab:hover{color:var(--text-primary);border-color:var(--border)}.sort-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.comments-scroll{flex-direction:column;gap:0;max-height:480px;padding-right:4px;display:flex;overflow-y:auto}.comments-scroll::-webkit-scrollbar{width:4px}.comments-scroll::-webkit-scrollbar-track{background:0 0}.comments-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}.comments-loading,.comments-empty{color:var(--text-secondary);flex-direction:column;align-items:center;gap:10px;padding:48px 0;font-size:.875rem;display:flex}.comments-loading ion-icon,.comments-empty ion-icon{opacity:.5;font-size:28px}.comment-item{border-bottom:1px solid var(--border);padding:16px 0}.comment-item:last-child{border-bottom:none}.comment-body{gap:12px;display:flex}.comment-avatar{border-radius:var(--radius-full);background:var(--primary);color:#fff;flex-shrink:0;justify-content:center;align-items:center;font-size:.8125rem;font-weight:700;display:flex;overflow:hidden}.comment-avatar img{object-fit:cover;width:100%;height:100%}.comment-content{flex:1;min-width:0}.comment-meta{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:6px;display:flex}.comment-author{color:var(--text-primary);transition:color var(--transition);font-size:.875rem;font-weight:600;text-decoration:none}.comment-author:hover{color:var(--primary)}.badge{border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 8px;font-size:.6875rem;font-weight:600;display:inline-flex}.badge-novice{color:var(--text-secondary);background:#6b728026}.badge-apprentice{color:var(--primary);background:#17a69726}.badge ion-icon{font-size:10px}.comment-date{color:var(--text-secondary);font-size:.75rem}.comment-text{color:var(--text-primary);word-break:break-word;font-size:.875rem;line-height:1.65}.comment-actions{align-items:center;gap:4px;margin-top:10px;display:flex}.action-btn{border-radius:var(--radius-full);color:var(--text-secondary);transition:background var(--transition), color var(--transition);background:0 0;border:none;align-items:center;gap:5px;padding:4px 10px;font-size:.75rem;font-weight:500;display:flex}.action-btn:hover:not(:disabled){background:var(--border);color:var(--text-primary)}.action-btn:disabled{opacity:.4;cursor:default}.action-btn ion-icon{font-size:14px}.action-btn.report-btn:hover:not(:disabled){color:#ef4444;background:#ef444414}.replies-toggle{color:var(--primary);cursor:pointer;transition:opacity var(--transition);background:0 0;border:none;align-items:center;gap:6px;margin-top:8px;padding:4px 0;font-size:.8125rem;font-weight:600;display:inline-flex}.replies-toggle:hover{opacity:.75}.replies-toggle ion-icon{transition:transform var(--transition);font-size:14px}.replies-toggle.open ion-icon{transform:rotate(180deg)}.replies-container{border-left:2px solid var(--border);flex-direction:column;gap:0;margin-top:12px;padding-left:16px;display:flex}.reply-item{border-bottom:1px solid var(--border);padding:12px 0}.reply-item:last-child{border-bottom:none}@media (width>=768px){.commentars-section{flex-direction:row-reverse;align-items:flex-start;gap:32px;padding:20px 100px}.commentars-editor-wrapper{flex-shrink:0;width:340px;position:sticky;top:80px}.comments-list-wrapper{flex:1;min-width:0}}.gh-section{background-color:var(--bg-primary);padding:80px 24px}.gh-container{flex-direction:column;gap:48px;width:100%;max-width:1280px;margin:0 auto;display:flex}.gh-header{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.gh-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--primary);align-items:center;gap:8px;font-size:.68rem;font-weight:700;display:inline-flex}.gh-title{color:var(--dark);letter-spacing:-.025em;max-width:520px;font-size:2rem;font-weight:700;line-height:1.2}.gh-title--accent{color:var(--primary)}.gh-subtitle{color:var(--text-secondary);max-width:420px;font-size:.9rem;line-height:1.7}.gh-bento{grid-template-columns:1fr;gap:12px;display:grid}.gh-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:border-color .22s,box-shadow .22s}.gh-card:hover{border-color:#17a69747;box-shadow:0 4px 24px #17a69712}.gh-card--info{flex-direction:column;justify-content:space-between;gap:24px;display:flex}.gh-info-list{flex-direction:column;gap:14px;display:flex}.gh-info-row{align-items:center;gap:12px;display:flex}.gh-info-icon{border-radius:var(--radius-md);width:36px;height:36px;color:var(--primary);background:#17a6971a;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex}.gh-info-text{flex-direction:column;gap:1px;display:flex}.gh-info-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-size:.65rem;font-weight:600}.gh-info-value{color:var(--dark);font-size:.85rem;font-weight:500}.gh-social-row{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-full);align-items:center;gap:10px;width:fit-content;padding:10px 14px;display:flex}.gh-avatars{align-items:center;display:flex}.gh-avatar{border:2px solid var(--bg-primary);object-fit:cover;border-radius:50%;width:26px;height:26px;margin-left:-7px}.gh-avatars .gh-avatar:first-child{margin-left:0}.gh-avatar--more{border:2px solid var(--bg-primary);background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;margin-left:-7px;font-size:.58rem;font-weight:700;display:flex}.gh-social-text{color:var(--text-secondary);white-space:nowrap;font-size:.75rem}.gh-social-text strong{color:var(--dark);font-weight:600}.gh-card--profile{text-align:center;background:linear-gradient(160deg, #17a6970f 0%, var(--bg-primary) 60%);flex-direction:column;justify-content:center;align-items:center;gap:14px;max-height:270px;padding:10px;display:flex}.gh-profile-avatar-wrap{flex-shrink:0;width:72px;height:72px;position:relative}.gh-profile-avatar{border:2.5px solid var(--primary);object-fit:cover;border-radius:50%;width:72px;height:72px;display:block}.gh-profile-badge{background:var(--dark);border:2px solid var(--bg-primary);width:22px;height:22px;color:var(--bg-primary);border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;display:flex;position:absolute;bottom:0;right:0}.gh-profile-identity{flex-direction:column;gap:2px;display:flex}.gh-profile-name{color:var(--dark);letter-spacing:-.01em;font-size:.875rem;font-weight:700}.gh-profile-handle{color:var(--text-secondary);font-size:.72rem}.gh-profile-stats{gap:10px;width:100%;display:flex}.gh-stat{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center;flex-direction:column;flex:1;gap:2px;padding:8px 6px;display:flex}.gh-stat-num{color:var(--dark);letter-spacing:-.02em;font-size:1.05rem;font-weight:700;line-height:1}.gh-stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);font-size:.58rem;font-weight:600}.gh-profile-btn{width:100%;color:var(--bg-primary);background:var(--dark);border-radius:var(--radius-lg);justify-content:center;align-items:center;gap:6px;padding:9px 20px;font-size:.8rem;font-weight:600;text-decoration:none;transition:background .2s,transform .2s,box-shadow .2s;display:inline-flex}.gh-profile-btn:hover{background:var(--primary);transform:translateY(-1px);box-shadow:0 4px 16px #17a6974d}.gh-profile-btn:focus-visible{outline:2px solid var(--primary);outline-offset:3px}.gh-card--activity{flex-direction:column;gap:14px;display:flex;overflow:hidden}.gh-activity-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.gh-activity-title{color:var(--dark);align-items:center;gap:6px;font-size:.875rem;font-weight:700;display:flex}.gh-activity-title ion-icon{color:var(--primary);font-size:1rem}.gh-activity-range{color:var(--text-secondary);font-size:.68rem;font-weight:500}.gh-graph-scroll{cursor:grab;padding-bottom:3px;overflow:auto hidden}.gh-graph-scroll:active{cursor:grabbing}.gh-graph-scroll::-webkit-scrollbar{height:3px}.gh-graph-scroll::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.gh-graph-scroll::-webkit-scrollbar-thumb{background:#17a6974d;border-radius:4px}.gh-graph-scroll::-webkit-scrollbar-thumb:hover{background:var(--primary)}.gh-graph-inner{gap:3px;width:max-content;display:flex}.gh-day-labels{grid-template-rows:14px repeat(7,11px);gap:2px;margin-right:1px;padding-top:2px;display:grid}.gh-day-label{color:var(--text-secondary);-webkit-user-select:none;user-select:none;text-align:right;padding-right:3px;font-size:.55rem;line-height:11px}.gh-day-label--spacer{height:14px}.gh-graph-main{flex-direction:column;gap:2px;display:flex}.gh-month-row{height:14px;position:relative}.gh-month-label{color:var(--text-secondary);white-space:nowrap;-webkit-user-select:none;user-select:none;font-size:.55rem;position:absolute;top:2px}.gh-cells{grid-template-rows:repeat(7,11px);grid-auto-flow:column;gap:2px;display:grid}.gh-cell{cursor:pointer;border-radius:2px;width:11px;height:11px;transition:opacity .12s}.gh-cell:hover{opacity:.7;outline:1.5px solid var(--primary);outline-offset:1px}.gh-cell[data-level="0"]{background:var(--bg-secondary);border:1px solid var(--border)}.gh-cell[data-level="1"]{background:#17a6972e}.gh-cell[data-level="2"]{background:#17a6976b}.gh-cell[data-level="3"]{background:#17a697ad}.gh-cell[data-level="4"]{background:var(--primary)}.gh-graph-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.gh-total{color:var(--text-secondary);font-size:.72rem}.gh-total strong{color:var(--dark);font-weight:600}.gh-legend{align-items:center;gap:3px;display:flex}.gh-legend-label{color:var(--text-secondary);font-size:.6rem}.gh-legend-cell{cursor:default;border-radius:2px;flex-shrink:0;width:11px;height:11px}.gh-legend-cell[data-level="0"]{background:var(--bg-secondary);border:1px solid var(--border)}.gh-legend-cell[data-level="1"]{background:#17a6972e}.gh-legend-cell[data-level="2"]{background:#17a6976b}.gh-legend-cell[data-level="3"]{background:#17a697ad}.gh-legend-cell[data-level="4"]{background:var(--primary)}@media (width>=640px){.gh-bento{grid-template-columns:1fr 1fr}.gh-card--activity{grid-column:1/-1}}@media (width>=1024px){.gh-section{padding:120px 64px}.gh-title{font-size:2.5rem}.gh-bento{grid-template-rows:auto auto;grid-template-columns:1fr 200px}.gh-card--info{grid-area:1/1}.gh-card--profile{grid-area:1/2/3}.gh-card--activity{grid-area:2/1}}
