@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800;900&family=Outfit:wght@300;400;500;600&family=DM+Mono:ital,wght@0,400;0,500;1,400&display=swap');
:root{--ink:#0D0A14;--surface:#14102A;--surface2:#1C1535;--glass:rgba(255,255,255,0.04);--border:rgba(196,160,220,0.1);--border2:rgba(196,160,220,0.2);--rose:#E07BA0;--rose-dim:rgba(224,123,160,0.15);--lavender:#A67CD6;--lavender-dim:rgba(166,124,214,0.15);--gold:#D4A870;--text:#F5F0FA;--muted:#9B8CAF;--danger:#FF4D6D;--gradient:linear-gradient(135deg,#A67CD6,#E07BA0);--r-sm:8px;--r-md:16px;--r-lg:24px;--r-full:9999px;--ease-out:cubic-bezier(.22,1,.36,1)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--ink);color:var(--text);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}
::selection{background:var(--rose);color:var(--ink)}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--ink)}::-webkit-scrollbar-thumb{background:var(--rose);border-radius:2px}
.container{max-width:1160px;margin:0 auto;padding:0 24px}.section{padding:100px 0}
.section-label{display:inline-flex;align-items:center;gap:10px;font-family:'DM Mono',monospace;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--rose);margin-bottom:16px}
.section-label::before{content:'//';color:var(--lavender);font-size:.85em}
.section-title{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(2rem,4vw,3rem);line-height:1.1;margin-bottom:16px}
.grad-text{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--r-full);font-family:'Outfit',sans-serif;font-weight:600;font-size:.9rem;transition:all .3s var(--ease-out);cursor:pointer;border:none;letter-spacing:.02em}
.btn--primary{background:var(--gradient);color:#fff;box-shadow:0 0 20px rgba(224,123,160,.3)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 0 32px rgba(224,123,160,.5)}
.btn--ghost{background:transparent;color:var(--text);border:1px solid var(--border2)}
.btn--ghost:hover{border-color:var(--rose);color:var(--rose);background:var(--rose-dim)}
.btn--sm{padding:10px 20px;font-size:.8rem}
.chip{display:inline-flex;align-items:center;padding:5px 14px;border-radius:var(--r-full);font-size:.72rem;font-weight:600;background:var(--glass);border:1px solid var(--border);color:var(--muted);transition:all .2s}
.chip:hover{border-color:var(--rose);color:var(--rose)}
.chip--teal{background:var(--rose-dim);border-color:rgba(224,123,160,.3);color:var(--rose)}
.chip--violet{background:var(--lavender-dim);border-color:rgba(166,124,214,.3);color:var(--lavender)}
/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .4s var(--ease-out)}
.nav.scrolled{background:rgba(13,10,20,.92);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);box-shadow:0 4px 24px rgba(0,0,0,.5)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.nav__logo{display:flex;align-items:center;text-decoration:none}
.nav__logo span{font-family:'Syne',sans-serif;font-weight:900;font-size:1.3rem;letter-spacing:-.02em;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav__logo img{height:34px;width:auto;display:block}
.nav__links{display:flex;align-items:center;gap:36px;list-style:none}
.nav__links a{font-size:.875rem;font-weight:500;color:var(--muted);transition:color .2s;position:relative}
.nav__links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--rose);transform:scaleX(0);transition:transform .3s var(--ease-out)}
.nav__links a:hover,.nav__links a.active{color:var(--text)}
.nav__links a:hover::after,.nav__links a.active::after{transform:scaleX(1)}
.nav__cta{display:flex;align-items:center;gap:12px}
.nav__menu-btn{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--text);flex-direction:column;gap:5px}
.nav__menu-btn span{display:block;width:22px;height:2px;background:var(--text);transition:all .3s;border-radius:2px}
.nav__menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__menu-btn.open span:nth-child(2){opacity:0}
.nav__menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav__mobile{display:none;position:fixed;inset:70px 0 0;background:rgba(13,10,20,.97);backdrop-filter:blur(20px);flex-direction:column;align-items:center;justify-content:center;gap:32px;z-index:999}
.nav__mobile.open{display:flex}
.nav__mobile a{font-family:'Syne',sans-serif;font-size:2rem;font-weight:800;color:var(--muted);transition:color .2s}
.nav__mobile a:hover{color:var(--rose)}
/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:70px}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(166,124,214,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(166,124,214,.05) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%)}
.hero-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(80px)}
.hero-orb--1{width:700px;height:700px;background:radial-gradient(circle,rgba(224,123,160,.14) 0%,transparent 70%);top:-20%;right:-10%;animation:orbFloat 10s ease-in-out infinite}
.hero-orb--2{width:500px;height:500px;background:radial-gradient(circle,rgba(166,124,214,.12) 0%,transparent 70%);bottom:-10%;left:-5%;animation:orbFloat 13s ease-in-out infinite reverse}
.hero__inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;width:100%}
.hero__label{display:inline-flex;align-items:center;gap:8px;font-family:'DM Mono',monospace;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--rose);margin-bottom:20px}
.hero__label::before{content:'';display:block;width:40px;height:1px;background:var(--rose)}
.hero__title{font-family:'Syne',sans-serif;font-weight:900;font-size:clamp(3rem,7vw,5.5rem);line-height:.95;letter-spacing:-.03em;margin-bottom:20px}
.hero__title .line1{display:block;color:var(--text)}
.hero__title .line2{display:block;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero__sub{font-size:1.1rem;color:var(--muted);min-height:28px;margin-bottom:36px}
.hero__sub .cursor{display:inline-block;width:2px;height:1em;background:var(--rose);margin-left:2px;vertical-align:middle;animation:blink .9s step-end infinite}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:56px}
.hero__stats{display:flex;gap:32px;flex-wrap:wrap;padding-top:32px;border-top:1px solid var(--border)}
.hero__stat-num{display:block;font-family:'Syne',sans-serif;font-weight:900;font-size:2.2rem;letter-spacing:-.03em;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.hero__stat-label{font-size:.8rem;color:var(--muted)}
.code-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 80px rgba(166,124,214,.08);animation:floatCard 6s ease-in-out infinite}
.code-card__header{display:flex;align-items:center;gap:8px;padding:14px 20px;background:var(--surface2);border-bottom:1px solid var(--border)}
.dot{width:12px;height:12px;border-radius:50%}
.dot--red{background:#FF5F56}.dot--yellow{background:#FFBD2E}.dot--green{background:#27C93F}
.code-card__file{font-family:'DM Mono',monospace;font-size:.75rem;color:var(--muted);margin:0 auto}
.code-card__body{padding:24px 28px}
.code-card pre{font-family:'DM Mono',monospace;font-size:.83rem;line-height:1.9;tab-size:2}
.code-card .kw{color:var(--lavender)}.code-card .var{color:var(--rose)}.code-card .prop{color:#C4B5D8}.code-card .str{color:var(--gold)}.code-card .cm{color:var(--muted);font-style:italic}
.scroll-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;font-family:'DM Mono',monospace;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.scroll-hint__line{width:1px;height:48px;background:linear-gradient(to bottom,var(--border2),transparent);animation:scrollPulse 2s ease-in-out infinite}
/* ABOUT */
.about{background:var(--surface)}
.about__inner{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center}
.about__img-wrap{position:relative}
.about__img-frame{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;position:relative}
.about__img-frame img{width:100%;height:100%;object-fit:cover}
.about__img-placeholder{font-size:5rem;opacity:.2}
.about__img-photo{width:100%;height:100%;object-fit:cover}
.about__badge{position:absolute;bottom:-20px;right:-20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 20px;box-shadow:0 8px 32px rgba(0,0,0,.5)}
.about__badge-icon{display:flex;align-items:center;justify-content:center;margin-bottom:4px;color:var(--gold)}
.about__badge-text{font-size:.7rem;color:var(--muted);white-space:nowrap}
.about__badge-num{font-family:'Syne',sans-serif;font-weight:800;font-size:1.3rem;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.about__text p{color:var(--muted);line-height:1.8;margin-bottom:16px}
.about__text p strong{color:var(--text)}
.about__tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;margin-bottom:32px}
.about__socials{display:flex;gap:12px;margin-top:28px}
.social-icon{width:42px;height:42px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;background:var(--glass);border:1px solid var(--border);color:var(--muted);transition:all .2s}
.social-icon:hover{border-color:var(--rose);color:var(--rose);background:var(--rose-dim);transform:translateY(-2px)}
/* SKILLS */
.skills__grid{display:flex;flex-wrap:wrap;gap:20px;margin-top:48px;justify-content:center}
.skill-group{flex:1 1 240px;max-width:300px;background:var(--glass);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:all .35s var(--ease-out);position:relative}
.skill-group::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out)}
.skill-group:hover::after{transform:scaleX(1)}
.skill-group:hover{transform:translateY(-5px);border-color:var(--border2);box-shadow:0 16px 48px rgba(0,0,0,.5),0 0 32px var(--sg-glow,rgba(224,123,160,.1))}
.skill-group__header{padding:20px 22px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}
.skill-group__icon-wrap{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--sg-ibg,rgba(224,123,160,.12));color:var(--sg-ic,var(--rose));transition:transform .3s var(--ease-out)}
.skill-group:hover .skill-group__icon-wrap{transform:scale(1.1)}
.skill-group__meta{flex:1;min-width:0}
.skill-group__title{font-family:'Syne',sans-serif;font-weight:700;font-size:.9rem;color:var(--text);line-height:1.2}
.skill-group__count{font-size:.68rem;color:var(--muted);font-family:'DM Mono',monospace;margin-top:2px}
.skill-group__tags{padding:16px 22px 20px;display:flex;flex-wrap:wrap;gap:7px}
.skill-group--violet{--sg-ibg:rgba(166,124,214,.15);--sg-ic:var(--lavender);--sg-glow:rgba(166,124,214,.12)}
.skill-group--gold{--sg-ibg:rgba(212,168,112,.13);--sg-ic:var(--gold);--sg-glow:rgba(212,168,112,.1)}
.skill-group--rose{--sg-ibg:rgba(224,123,160,.12);--sg-ic:var(--rose);--sg-glow:rgba(224,123,160,.1)}
.skill-group--mint{--sg-ibg:rgba(80,210,150,.1);--sg-ic:#50d296;--sg-glow:rgba(80,210,150,.08)}
/* PROJECTS */
.projects{background:var(--surface)}
.projects__header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:20px}
.projects__filters{display:flex;gap:8px;flex-wrap:wrap}
.filter-btn{padding:8px 18px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--glass);color:var(--muted);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:'Outfit',sans-serif}
.filter-btn:hover,.filter-btn.active{background:var(--rose-dim);border-color:rgba(224,123,160,.4);color:var(--rose)}
.projects__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.project-card{background:var(--glass);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:all .4s var(--ease-out);cursor:pointer;display:flex;flex-direction:column;min-width:0}
.project-card:hover{transform:translateY(-6px);border-color:var(--rose);box-shadow:0 20px 40px rgba(0,0,0,.5),0 0 40px rgba(224,123,160,.12)}
.project-card:focus-visible{outline:2px solid var(--rose);outline-offset:4px}
.project-card.featured{grid-column:auto}
.project-card__img{width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--surface2);position:relative;cursor:pointer}
.project-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-out)}
.project-card:hover .project-card__img img{transform:scale(1.06)}
.project-card__img-ph{width:100%;height:100%;display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;font-size:2.5rem;color:var(--border2)}
.project-card__img-ph span{font-family:'DM Mono',monospace;font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.project-card__cat{position:absolute;top:12px;left:12px;font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:var(--r-full);background:rgba(13,10,20,.85);backdrop-filter:blur(8px);border:1px solid var(--border2);color:var(--rose)}
.project-card__view{position:absolute;right:12px;bottom:12px;display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--r-full);font-size:.68rem;font-weight:600;background:rgba(13,10,20,.82);border:1px solid var(--border2);color:var(--text);opacity:0;transform:translateY(6px);transition:all .25s}
.project-card:hover .project-card__view{opacity:1;transform:translateY(0)}
.project-card__body{padding:20px 22px;display:flex;flex-direction:column;flex:1}
.project-card__title{font-family:'Syne',sans-serif;font-weight:700;font-size:1.05rem;margin-bottom:8px;color:var(--text);line-height:1.3}
.project-card__subtitle{font-size:.76rem;color:var(--rose);line-height:1.4;margin:-2px 0 8px}
.project-card__desc{font-size:.85rem;color:var(--muted);line-height:1.6;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.project-card__tools{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.project-card__footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;padding-top:14px;border-top:1px solid var(--border);font-size:.75rem;font-weight:600;color:var(--muted);transition:color .2s}
.project-card:hover .project-card__footer{color:var(--rose)}
/* PROJECTS GROUPS */
.projects-group{margin-bottom:72px}
.projects-group__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.projects-group__label{font-family:'Syne',sans-serif;font-weight:700;font-size:1.1rem;color:var(--text);display:flex;align-items:center;gap:10px}
.projects-group__label span{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.projects-group__see-all{font-size:.82rem;font-weight:600;color:var(--rose);border:1px solid var(--border);border-radius:var(--r-full);padding:7px 18px;background:var(--glass);transition:all .2s;white-space:nowrap}
.projects-group__see-all:hover{background:var(--rose-dim);border-color:rgba(224,123,160,.4)}
/* CAROUSEL */
.project-carousel{position:relative;overflow:hidden}
.project-carousel__track{display:flex;transition:transform .4s var(--ease-out)}
.project-carousel__slide{min-width:100%;position:relative}
.project-carousel__slide img{width:100%;height:100%;object-fit:cover}
.project-carousel__nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(13,10,20,.7);border:1px solid var(--border2);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);font-size:.75rem;transition:all .2s;z-index:2;backdrop-filter:blur(4px)}
.project-carousel__nav:hover{background:var(--rose-dim);border-color:var(--rose);color:var(--rose)}
.project-carousel__prev{left:8px}
.project-carousel__next{right:8px}
.project-carousel__dots{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);display:flex;gap:5px}
.project-carousel__dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;transition:all .2s}
.project-carousel__dot.active{background:var(--rose);width:14px;border-radius:3px}
.project-carousel__open{position:absolute;top:8px;right:8px;background:rgba(13,10,20,.7);border:1px solid var(--border2);border-radius:var(--r-sm);padding:5px 10px;font-size:.7rem;color:var(--text);cursor:pointer;z-index:2;backdrop-filter:blur(4px);transition:all .2s;font-family:'Outfit',sans-serif}
.project-carousel__open:hover{background:var(--rose-dim);border-color:var(--rose);color:var(--rose)}
/* LIGHTBOX MODAL */
.lightbox{display:none;position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.92);backdrop-filter:blur(8px);align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox__content{position:relative;max-width:90vw;max-height:90vh;display:flex;align-items:center;gap:16px}
.lightbox__media{max-width:80vw;max-height:85vh;border-radius:var(--r-md);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--surface2)}
.lightbox__media img{max-width:80vw;max-height:85vh;object-fit:contain;display:block;border-radius:var(--r-md)}
.lightbox__media iframe,.lightbox__media video{width:min(70vw,960px);height:min(50vw,540px);border:none;border-radius:var(--r-md)}
.lightbox__btn{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid var(--border2);color:var(--text);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.lightbox__btn:hover{background:var(--rose-dim);border-color:var(--rose);color:var(--rose)}
.lightbox__close{position:fixed;top:20px;right:24px;font-size:1.4rem;background:none;border:none;color:var(--muted);cursor:pointer;transition:color .2s;z-index:9001}
.lightbox__close:hover{color:var(--rose)}
.lightbox__counter{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);font-family:'DM Mono',monospace;font-size:.75rem;color:var(--muted)}
/* PROJECT DETAIL MODAL */
.project-modal{position:fixed;inset:0;z-index:8800;display:none;align-items:center;justify-content:center;padding:28px}
.project-modal.open{display:flex}
.project-modal__backdrop{position:absolute;inset:0;background:rgba(7,5,12,.88);backdrop-filter:blur(14px)}
.project-modal__dialog{position:relative;width:min(1120px,96vw);max-height:90vh;display:grid;grid-template-columns:minmax(0,1.25fr) minmax(340px,.75fr);overflow:hidden;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-lg);box-shadow:0 30px 100px rgba(0,0,0,.65)}
.project-modal__close{position:absolute;top:16px;right:16px;z-index:5;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(13,10,20,.82);border:1px solid var(--border2);color:var(--text);cursor:pointer;transition:all .2s}
.project-modal__close:hover{color:var(--rose);border-color:var(--rose);transform:rotate(8deg)}
.project-modal__gallery{min-height:520px;background:#09070f;display:flex;flex-direction:column;min-width:0}
.project-modal__media{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.project-modal__media img,.project-modal__media video{width:100%;height:100%;max-height:76vh;object-fit:contain}
.project-modal__media iframe{width:100%;height:100%;min-height:520px;border:0}
.project-modal__empty{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--muted)}
.project-modal__gallery-nav{height:56px;display:flex;align-items:center;justify-content:center;gap:18px;border-top:1px solid var(--border);background:rgba(13,10,20,.75)}
.project-modal__gallery-nav button{width:34px;height:34px;border-radius:50%;border:1px solid var(--border2);background:var(--glass);color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer}
.project-modal__gallery-nav button:hover{border-color:var(--rose);color:var(--rose)}
.project-modal__gallery-nav span{min-width:50px;text-align:center;font-family:'DM Mono',monospace;font-size:.7rem;color:var(--muted)}
.project-modal__content{padding:48px 40px 36px;overflow-y:auto}
.project-modal__category{display:inline-flex;padding:5px 11px;border-radius:var(--r-full);background:var(--rose-dim);border:1px solid rgba(224,123,160,.3);font-family:'DM Mono',monospace;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--rose);margin-bottom:18px}
.project-modal__content h2{font-family:'Syne',sans-serif;font-size:clamp(1.6rem,3vw,2.45rem);line-height:1.08;margin-bottom:10px}
.project-modal__subtitle{color:var(--rose);font-size:.9rem;line-height:1.5;margin-bottom:18px}
.project-modal__meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.project-modal__meta span{font-family:'DM Mono',monospace;font-size:.68rem;color:var(--muted);padding:5px 9px;border:1px solid var(--border);border-radius:var(--r-full)}
.project-modal__description{font-size:.9rem;line-height:1.8;color:var(--muted);white-space:pre-line;margin-bottom:28px}
.project-modal__description strong{color:var(--text)}
.project-modal__tools{display:flex;flex-wrap:wrap;gap:7px}
/* PDF VIEWER */
.pdf-preview{width:min(70vw,800px);height:min(55vw,600px);border:none;border-radius:var(--r-md)}
/* TIMELINE */
.timeline{margin-top:56px;position:relative}
.timeline::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:2px;background:linear-gradient(to bottom,var(--rose),var(--lavender),transparent)}
.timeline__item{padding-left:40px;padding-bottom:48px;position:relative}
.timeline__item:last-child{padding-bottom:0}
.timeline__dot{position:absolute;left:-7px;top:8px;width:16px;height:16px;border-radius:50%;background:var(--ink);border:2px solid var(--rose);box-shadow:0 0 12px rgba(224,123,160,.4)}
.timeline__title{font-family:'Syne',sans-serif;font-weight:700;font-size:1.1rem;color:var(--text);margin-bottom:4px}
.timeline__company{font-size:.9rem;color:var(--rose);font-weight:500}
.timeline__date{font-family:'DM Mono',monospace;font-size:.72rem;color:var(--muted);letter-spacing:.06em;margin:4px 0 10px}
.timeline__desc{font-size:.9rem;color:var(--muted);line-height:1.7}
/* TESTIMONIALS */
.testimonials{background:var(--surface)}
.testimonials-carousel{margin-top:48px;overflow:hidden}
.testimonials-carousel__viewport{overflow:hidden}
.testimonials-carousel__track{display:flex;gap:20px;transition:transform .65s var(--ease-out);will-change:transform}
.testimonial-card{flex:0 0 calc((100% - 20px)/2);min-height:260px;background:var(--glass);border:1px solid var(--border);border-radius:var(--r-md);padding:28px;transition:all .3s var(--ease-out);position:relative;display:flex;flex-direction:column}
.testimonial-card:hover{border-color:var(--lavender);transform:translateY(-4px)}
.tcard__quote{font-size:2rem;line-height:1;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}
.tcard__text{font-size:.9rem;color:var(--muted);line-height:1.75;margin-bottom:20px;font-style:italic}
.tcard__author{display:flex;align-items:center;gap:12px;margin-top:auto}
.tcard__avatar{width:44px;height:44px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:.9rem;color:#fff;flex-shrink:0}
.tcard__name{font-weight:600;font-size:.9rem}
.tcard__role{font-size:.78rem;color:var(--muted)}
.tcard__stars{color:var(--gold);font-size:.75rem;margin-bottom:2px}
.tcard__source{position:absolute;top:20px;right:20px;font-family:'DM Mono',monospace;font-size:.65rem;color:var(--border2)}
.testimonials-carousel__controls{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:20px}
.testimonials-carousel__controls button{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid var(--border2);background:var(--glass);color:var(--muted);cursor:pointer;transition:all .2s}
.testimonials-carousel__controls button:hover{border-color:var(--rose);color:var(--rose);background:var(--rose-dim)}
.testimonials-carousel__progress{width:110px;height:2px;background:var(--border2);overflow:hidden;border-radius:2px}
.testimonials-carousel__progress span{display:block;width:0;height:100%;background:var(--gradient);transition:width .4s var(--ease-out)}
/* CONTACT */
.contact__inner{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start;margin-top:48px}
.contact__info-title{font-family:'Syne',sans-serif;font-weight:700;font-size:1.5rem;margin-bottom:12px}
.contact__info-text{color:var(--muted);line-height:1.7;margin-bottom:32px}
.contact__methods{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}
.contact__method{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:var(--r-md);background:var(--glass);border:1px solid var(--border);transition:all .2s;color:var(--text)}
.contact__method:hover{border-color:var(--rose);color:var(--rose)}
.contact__method-icon{width:38px;height:38px;border-radius:var(--r-sm);background:var(--rose-dim);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--rose)}
.contact__method-label{font-size:.75rem;color:var(--muted);display:block}
.contact__method-value{font-size:.9rem;font-weight:500}
.form{display:flex;flex-direction:column;gap:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:.8rem;font-weight:600;color:var(--muted);letter-spacing:.04em}
.form-group input,.form-group textarea,.form-group select{background:var(--glass);border:1px solid var(--border);border-radius:var(--r-sm);padding:13px 16px;color:var(--text);font-family:'Outfit',sans-serif;font-size:.9rem;transition:border-color .2s,box-shadow .2s;outline:none;width:100%}
.form-group input:focus,.form-group textarea:focus{border-color:var(--rose);box-shadow:0 0 0 3px rgba(224,123,160,.12)}
.form-group textarea{resize:vertical;min-height:120px}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted)}
.form-group select option{background:var(--surface2)}
.form-msg{padding:12px 16px;border-radius:var(--r-sm);font-size:.85rem;display:none;margin-top:4px}
.form-msg.success{background:rgba(166,124,214,.1);border:1px solid rgba(166,124,214,.3);color:var(--lavender);display:block}
.form-msg.error{background:rgba(255,77,109,.1);border:1px solid rgba(255,77,109,.3);color:var(--danger);display:block}
/* FOOTER */
.footer{padding:48px 0 32px;border-top:1px solid var(--border)}
.footer__inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}
.footer__logo{display:flex;align-items:center}
.footer__logo span{font-family:'Syne',sans-serif;font-weight:900;font-size:1.2rem;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.footer__logo img{height:40px;width:auto;display:block}
.footer__text{font-size:.82rem;color:var(--muted);text-align:center}
.footer__socials{display:flex;gap:12px}
/* ANIMS */
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-30px,-40px) scale(1.05)}}
@keyframes floatCard{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes scrollPulse{0%,100%{opacity:.3}50%{opacity:1}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}
@media(max-width:900px){.hero__inner{grid-template-columns:1fr}.code-card{display:none}.about__inner{grid-template-columns:1fr}.about__img-wrap{max-width:320px;margin:0 auto}.projects__grid{grid-template-columns:repeat(2,minmax(0,1fr))}.contact__inner{grid-template-columns:1fr}.nav__links,.nav__cta .btn{display:none}.nav__menu-btn{display:flex}.project-modal__dialog{grid-template-columns:1fr;overflow-y:auto}.project-modal__gallery{min-height:360px}.project-modal__media iframe{min-height:360px}.project-modal__content{overflow:visible}.testimonial-card{flex-basis:82%}}
@media(max-width:600px){.section{padding:72px 0}.projects__grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}.hero__stats{gap:20px}.hero__title{font-size:clamp(2.5rem,12vw,3.5rem)}.project-modal{padding:10px}.project-modal__dialog{width:100%;max-height:94vh}.project-modal__gallery{min-height:280px}.project-modal__media iframe{min-height:280px}.project-modal__content{padding:30px 22px}.testimonial-card{flex-basis:92%;min-height:280px}.projects-browser__filters{padding:18px}}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.reveal,.project-card,.testimonial-card,.testimonials-carousel__track{transition:none!important}.code-card,.hero-orb{animation:none!important}}
/* LOADING SCREEN */
.loading-screen{position:fixed;inset:0;z-index:9999;background:var(--ink);display:flex;align-items:center;justify-content:center;overflow:hidden;opacity:1;visibility:visible;transition:opacity .7s ease,visibility .7s ease}
.loading-screen.ls-fade{opacity:0;visibility:hidden;pointer-events:none}
.loading-video{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:768px){.loading-video{object-fit:contain;transform:scale(0.82);transform-origin:center center}}
