:root{--color-bg-primary: #0a1628;--color-bg-secondary: #0f1d32;--color-bg-tertiary: #162035;--color-bg-card: #111c30;--color-bg-card-hover: #162540;--color-accent: #3b82f6;--color-accent-light: #60a5fa;--color-accent-dark: #2563eb;--color-accent-glow: rgba(59, 130, 246, .15);--color-text-primary: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-border: #1e293b;--color-border-light: #334155;--color-white: #ffffff;--color-success: #10b981;--color-gradient-start: #3b82f6;--color-gradient-end: #8b5cf6;--navbar-bg: rgba(10, 22, 40, .92);--navbar-link-hover-bg: rgba(255, 255, 255, .05);--mobile-menu-bg: rgba(10, 22, 40, .98);--font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--section-padding: 6rem 0;--container-max: 1200px;--container-padding: 0 1.5rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-accent: 0 4px 24px rgba(59, 130, 246, .25);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}[data-theme=light]{--color-bg-primary: #f8fafc;--color-bg-secondary: #f1f5f9;--color-bg-tertiary: #e2e8f0;--color-bg-card: #ffffff;--color-bg-card-hover: #f8fafc;--color-accent: #2563eb;--color-accent-light: #3b82f6;--color-accent-dark: #1d4ed8;--color-accent-glow: rgba(37, 99, 235, .1);--color-text-primary: #0f172a;--color-text-secondary: #475569;--color-text-muted: #94a3b8;--color-border: #e2e8f0;--color-border-light: #cbd5e1;--color-white: #0f172a;--color-success: #059669;--color-gradient-start: #2563eb;--color-gradient-end: #7c3aed;--navbar-bg: rgba(248, 250, 252, .92);--navbar-link-hover-bg: rgba(0, 0, 0, .04);--mobile-menu-bg: rgba(248, 250, 252, .98);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-accent: 0 4px 24px rgba(37, 99, 235, .2)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background-color:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;overflow-x:hidden}img{max-width:100%;height:auto;display:block}a{color:var(--color-accent-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent)}ul,ol{list-style:none}button{cursor:pointer;border:none;background:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}.container{max-width:var(--container-max);margin:0 auto;padding:var(--container-padding)}.section{padding:var(--section-padding)}.section--alt{background-color:var(--color-bg-secondary)}.section-heading{text-align:center;margin-bottom:4rem}.section-heading__label{display:inline-block;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--color-accent);margin-bottom:.75rem}.section-heading__title{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:800;line-height:1.2;color:var(--color-white);margin-bottom:1rem}.section-heading__subtitle{font-size:1.0625rem;color:var(--color-text-secondary);max-width:600px;margin:0 auto;line-height:1.7}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.75rem;font-size:.9375rem;font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-base);white-space:nowrap;text-decoration:none}.btn--primary{background:linear-gradient(135deg,var(--color-gradient-start),var(--color-gradient-end));color:#fff;box-shadow:var(--shadow-accent)}.btn--primary:hover{transform:translateY(-2px);box-shadow:0 6px 30px #3b82f659;color:#fff}.btn--secondary{background:transparent;color:var(--color-text-primary);border:1.5px solid var(--color-border-light)}.btn--secondary:hover{border-color:var(--color-accent);color:var(--color-accent-light);transform:translateY(-2px)}.btn--small{padding:.5rem 1.25rem;font-size:.8125rem}.btn--disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn--premium{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;box-shadow:0 4px 16px #f59e0b40}.btn--premium:hover{transform:translateY(-2px);box-shadow:0 6px 24px #f59e0b66;color:#fff}.btn--in-use{background:linear-gradient(135deg,#10b981,#059669);color:#fff;cursor:default;pointer-events:none}.grid{display:grid;gap:1.5rem}.grid--2{grid-template-columns:repeat(2,1fr)}.grid--3{grid-template-columns:repeat(3,1fr)}.grid--4{grid-template-columns:repeat(4,1fr)}@media(max-width:1024px){.grid--4,.grid--3{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}.section{padding:4rem 0}}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;transition:all var(--transition-base)}.card:hover{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent),var(--shadow-md);transform:translateY(-4px)}.tech-badge{display:inline-block;padding:.25rem .75rem;font-size:.75rem;font-weight:500;color:var(--color-accent-light);background:var(--color-accent-glow);border:1px solid rgba(59,130,246,.2);border-radius:9999px;white-space:nowrap}.gradient-text{background:linear-gradient(135deg,var(--color-gradient-start),var(--color-gradient-end));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeInUp .6s ease forwards}.glow-border{position:relative}.glow-border:before{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:linear-gradient(135deg,var(--color-accent),var(--color-gradient-end));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity var(--transition-base)}.glow-border:hover:before{opacity:1}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-bg-primary)}::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}::selection{background:#3b82f64d;color:#fff}[data-theme=light] ::selection{background:#2563eb33;color:#0f172a}[data-theme=light] ::-webkit-scrollbar-track{background:var(--color-bg-primary)}[data-theme=light] ::-webkit-scrollbar-thumb{background:var(--color-border-light)}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}.theme-toggle{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base);overflow:hidden;flex-shrink:0}.theme-toggle:hover{color:var(--color-accent-light);border-color:var(--color-accent);background:var(--color-accent-glow);transform:translateY(-1px)}.theme-toggle__icon{position:absolute;transition:all .35s cubic-bezier(.4,0,.2,1);opacity:0;transform:scale(.5) rotate(-90deg)}.theme-toggle__icon--active{opacity:1;transform:scale(1) rotate(0)}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 0;transition:all var(--transition-base);background:transparent}.navbar--scrolled{background:var(--navbar-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);padding:.65rem 0;box-shadow:0 4px 24px #00000026}.navbar__inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}.navbar__logo{display:flex;align-items:center;flex-shrink:0;color:var(--color-text-primary)}.navbar__nav{display:flex;align-items:center;gap:.25rem}.navbar__link{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);text-decoration:none}.navbar__link:hover{color:var(--color-white);background:var(--navbar-link-hover-bg)}.navbar__cta{font-size:.8125rem;padding:.6rem 1.4rem}.navbar__actions{display:flex;align-items:center;gap:.75rem}.navbar__toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:28px;height:28px;cursor:pointer;z-index:1001}.navbar__toggle span{display:block;width:100%;height:2px;background:var(--color-text-primary);border-radius:2px;transition:all var(--transition-fast);transform-origin:center}.navbar__toggle--open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navbar__toggle--open span:nth-child(2){opacity:0}.navbar__toggle--open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.navbar__mobile{position:fixed;inset:0;background:var(--mobile-menu-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all var(--transition-base);z-index:999}.navbar__mobile--open{opacity:1;visibility:visible}.navbar__mobile-nav{display:flex;flex-direction:column;align-items:center;gap:.5rem}.navbar__mobile-link{font-size:1.25rem;font-weight:600;color:var(--color-text-secondary);padding:.75rem 2rem;border-radius:var(--radius-md);transition:all var(--transition-fast);text-decoration:none}.navbar__mobile-link:hover{color:var(--color-white);background:var(--navbar-link-hover-bg)}.navbar__mobile-nav .btn{margin-top:1.5rem;padding:.85rem 2.5rem;font-size:1rem}.navbar__mobile-theme{margin-top:1rem}@media(max-width:768px){.navbar__nav,.navbar__actions{display:none}.navbar__toggle{display:flex}}.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding-top:5rem}.hero__bg{position:absolute;inset:0;z-index:0;pointer-events:none}.hero__bg-gradient{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(59,130,246,.08) 0%,transparent 60%)}.hero__bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(59,130,246,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.03) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 20%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 20%,transparent 70%)}.hero__bg-glow{position:absolute;border-radius:50%;filter:blur(120px);opacity:.4}.hero__bg-glow--1{width:600px;height:600px;background:#3b82f61f;top:-200px;right:-100px}.hero__bg-glow--2{width:400px;height:400px;background:#8b5cf614;bottom:-100px;left:-100px}.hero__inner{position:relative;z-index:1}.hero__content{max-width:760px;margin:0 auto;text-align:center;animation:fadeInUp .8s ease forwards}.hero__badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1.2rem;font-size:.8125rem;font-weight:500;color:var(--color-accent-light);background:var(--color-accent-glow);border:1px solid rgba(59,130,246,.2);border-radius:9999px;margin-bottom:2rem}.hero__badge-dot{width:6px;height:6px;background:var(--color-success);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.hero__title{font-size:clamp(2.25rem,5.5vw,3.75rem);font-weight:800;line-height:1.1;letter-spacing:-.03em;color:var(--color-white);margin-bottom:1.5rem}.hero__subtitle{font-size:clamp(1rem,1.5vw,1.125rem);color:var(--color-text-secondary);line-height:1.75;max-width:600px;margin:0 auto 2.5rem}.hero__actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:4rem}.hero__stats{display:flex;justify-content:center;align-items:center;gap:2rem;padding-top:2rem;border-top:1px solid var(--color-border)}.hero__stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.hero__stat-number{font-size:1.75rem;font-weight:800;color:var(--color-white)}.hero__stat-label{font-size:.8125rem;color:var(--color-text-muted);font-weight:500}.hero__stat-divider{width:1px;height:40px;background:var(--color-border)}@media(max-width:640px){.hero{padding-top:6rem}.hero__actions{flex-direction:column;align-items:center}.hero__actions .btn{width:100%;max-width:280px}.hero__stats{gap:1rem}.hero__stat-number{font-size:1.375rem}.hero__stat-label{font-size:.75rem}}.services-grid{gap:1.25rem}.service-card{text-align:center;padding:2.5rem 2rem}.service-card__icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--color-accent-glow);border:1px solid rgba(59,130,246,.15);border-radius:var(--radius-lg);color:var(--color-accent-light);margin-bottom:1.5rem;transition:all var(--transition-base)}.service-card:hover .service-card__icon{background:#3b82f633;border-color:var(--color-accent);transform:scale(1.05)}.service-card__title{font-size:1.125rem;font-weight:700;color:var(--color-white);margin-bottom:.75rem}.service-card__description{font-size:.875rem;color:var(--color-text-secondary);line-height:1.7}.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.about__text{font-size:1rem;line-height:1.8;color:var(--color-text-secondary);margin-bottom:1.25rem}.about__text strong{color:var(--color-white);font-weight:600}.about__highlights{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:2rem}.about__highlight{display:flex;align-items:center;gap:.6rem;font-size:.875rem;color:var(--color-text-secondary);font-weight:500}.about__highlight-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--color-accent-glow);color:var(--color-accent-light);flex-shrink:0}.about__owner{margin-top:2rem;padding:1.25rem 1.5rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;align-items:center;gap:1rem}.about__owner-info{display:flex;flex-direction:column;gap:.15rem}.about__owner-name{font-size:1rem;font-weight:700;color:var(--color-white)}.about__owner-role{font-size:.8125rem;color:var(--color-accent-light);font-weight:500}.about__owner-links{display:flex;gap:.75rem;margin-top:.5rem}.about__owner-links a{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);background:var(--color-accent-glow);color:var(--color-text-secondary);transition:all var(--transition-fast)}.about__owner-links a:hover{color:var(--color-accent-light);background:#3b82f633}.about__visual{display:flex;justify-content:center}.about__card{width:100%;max-width:380px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.about__card-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}.about__card-dots{display:flex;gap:6px}.about__card-dots span{width:10px;height:10px;border-radius:50%}.about__card-dots span:nth-child(1){background:#ef4444}.about__card-dots span:nth-child(2){background:#f59e0b}.about__card-dots span:nth-child(3){background:#10b981}.about__card-title{font-size:.75rem;color:var(--color-text-muted);font-weight:500}.about__card-body{padding:1.5rem}.about__card-body pre{margin:0}.about__card-body code{font-family:Fira Code,SF Mono,Cascadia Code,Consolas,monospace;font-size:.8125rem;line-height:1.7;color:var(--color-accent-light);white-space:pre-wrap}@media(max-width:768px){.about__grid{grid-template-columns:1fr;gap:2.5rem}.about__highlights{grid-template-columns:1fr}.about__visual{order:-1}.about__card{max-width:100%}}.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.why-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;transition:all var(--transition-base);position:relative;overflow:hidden}.why-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-gradient-start),var(--color-gradient-end));opacity:0;transition:opacity var(--transition-base)}.why-card:hover{border-color:#3b82f64d;transform:translateY(-4px);box-shadow:var(--shadow-md)}.why-card:hover:before{opacity:1}.why-card__number{display:inline-block;font-size:.75rem;font-weight:700;color:var(--color-accent);background:var(--color-accent-glow);padding:.25rem .6rem;border-radius:var(--radius-sm);margin-bottom:1.25rem;letter-spacing:1px}.why-card__title{font-size:1.0625rem;font-weight:700;color:var(--color-white);margin-bottom:.75rem}.why-card__description{font-size:.875rem;color:var(--color-text-secondary);line-height:1.7}@media(max-width:1024px){.why-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.why-grid{grid-template-columns:1fr}}.project-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base);display:flex;flex-direction:column}.project-card:hover{border-color:#3b82f666;box-shadow:0 8px 40px #0000004d,0 0 0 1px #3b82f61a;transform:translateY(-6px)}.project-card--featured{border-color:#3b82f640;background:linear-gradient(135deg,var(--color-bg-card) 0%,rgba(59,130,246,.05) 100%)}.project-card--featured:hover{border-color:var(--color-accent);box-shadow:0 8px 40px #3b82f626,0 0 0 1px var(--color-accent)}.project-card__image{position:relative;width:100%;aspect-ratio:16 / 9;overflow:hidden}.project-card__image--clickable{cursor:pointer}.project-card__gallery-badge{position:absolute;bottom:.75rem;left:.75rem;display:inline-flex;align-items:center;gap:.375rem;padding:.3rem .65rem;font-size:.6875rem;font-weight:600;color:#fff;background:#000000b3;border-radius:var(--radius-sm);z-index:2;transition:background var(--transition-fast)}.project-card__image--clickable:hover .project-card__gallery-badge{background:var(--color-accent)}.project-card__image-inner{width:100%;height:100%}.project-card__screenshot{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .5s ease}.project-card:hover .project-card__screenshot{transform:scale(1.05)}.project-card__image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:var(--color-bg-tertiary);position:relative;overflow:hidden}.project-card__image-gradient{position:absolute;inset:0;background:linear-gradient(135deg,#3b82f614,#8b5cf60f,#3b82f60a)}.project-card__image-icon{color:var(--color-text-muted);z-index:1;opacity:.5;transition:opacity var(--transition-base)}.project-card:hover .project-card__image-icon{opacity:.75;color:var(--color-accent-light)}.project-card__image-url{font-size:.75rem;color:var(--color-text-muted);z-index:1;font-weight:500;letter-spacing:.5px}.project-card__badge{position:absolute;top:.75rem;left:.75rem;padding:.25rem .75rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-white);background:linear-gradient(135deg,var(--color-gradient-start),var(--color-gradient-end));border-radius:9999px;z-index:2}.project-card__category{position:absolute;top:.75rem;right:.75rem;padding:.2rem .6rem;font-size:.6875rem;font-weight:500;color:var(--color-text-secondary);background:#0f1d32d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--color-border);border-radius:var(--radius-sm);z-index:2}.project-card__content{padding:1.5rem;display:flex;flex-direction:column;flex:1}.project-card__title{font-size:1.125rem;font-weight:700;color:var(--color-white);margin-bottom:.75rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card__description{font-size:.875rem;color:var(--color-text-secondary);line-height:1.65;margin-bottom:1.25rem;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-card__techs{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:1.5rem;max-height:3.6rem;overflow:hidden}.project-card__actions{display:flex;gap:.75rem;margin-top:auto}.project-card__actions .btn{flex:1;justify-content:center}.project-card{min-height:0}.projects__filters{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;margin-bottom:3rem}.projects__filter{padding:.5rem 1.25rem;font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);background:transparent;border:1px solid var(--color-border);border-radius:9999px;cursor:pointer;transition:all var(--transition-fast)}.projects__filter:hover{color:var(--color-white);border-color:var(--color-border-light);background:var(--navbar-link-hover-bg)}.projects__filter--active{color:#fff;background:linear-gradient(135deg,var(--color-gradient-start),var(--color-gradient-end));border-color:transparent;box-shadow:var(--shadow-accent)}.projects__filter--active:hover{background:linear-gradient(135deg,var(--color-gradient-start),var(--color-gradient-end));border-color:transparent;color:#fff}.projects-grid{gap:1.5rem}@media(max-width:1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.projects-grid{grid-template-columns:1fr}.projects__filters{gap:.375rem}.projects__filter{padding:.4rem 1rem;font-size:.75rem}}.contact__grid{display:grid;grid-template-columns:1fr 1.4fr;gap:3rem;align-items:start}.contact__info{display:flex;flex-direction:column;gap:1rem}.contact__info-card{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-base)}.contact__info-card:hover{border-color:#3b82f64d}.contact__info-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-accent-glow);border-radius:var(--radius-md);color:var(--color-accent-light);flex-shrink:0}.contact__info-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--color-text-muted);margin-bottom:.15rem}.contact__info-value{font-size:.9375rem;font-weight:500;color:var(--color-text-primary);text-decoration:none}a.contact__info-value:hover{color:var(--color-accent-light)}.contact__socials{display:flex;gap:.75rem;margin-top:.5rem}.contact__social{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-base)}.contact__social:hover{color:var(--color-accent-light);border-color:var(--color-accent);background:var(--color-accent-glow);transform:translateY(-2px)}.contact__form{display:flex;flex-direction:column;gap:1.25rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem}.contact__form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.contact__field{display:flex;flex-direction:column;gap:.4rem}.contact__label{font-size:.8125rem;font-weight:600;color:var(--color-text-secondary)}.contact__input{padding:.75rem 1rem;font-size:.9375rem;color:var(--color-text-primary);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);outline:none}.contact__input::placeholder{color:var(--color-text-muted)}.contact__input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow)}.contact__select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%2394A3B8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.contact__textarea{resize:vertical;min-height:120px}.contact__submit{align-self:flex-start;margin-top:.5rem}@media(max-width:768px){.contact__grid,.contact__form-row{grid-template-columns:1fr}.contact__submit{width:100%}}.contact__spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:contact-spin .6s linear infinite}@keyframes contact-spin{to{transform:rotate(360deg)}}.contact__status{display:flex;align-items:center;gap:.625rem;padding:.875rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;line-height:1.5}.contact__status--success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#4ade80}.contact__status--error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171}.contact__submit:disabled{opacity:.7;cursor:not-allowed}.footer{background:var(--color-bg-secondary);border-top:1px solid var(--color-border);padding:4rem 0 0}.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem}.footer__brand{display:flex;flex-direction:column;gap:1rem;color:var(--color-text-primary)}.footer__brand-text{font-size:.875rem;color:var(--color-text-secondary);line-height:1.7;max-width:320px}.footer__socials{display:flex;gap:.75rem;margin-top:.5rem}.footer__socials a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);transition:all var(--transition-base)}.footer__socials a:hover{color:var(--color-accent-light);border-color:var(--color-accent);background:var(--color-accent-glow)}.footer__links-title{font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--color-text-primary);margin-bottom:1.25rem}.footer__links{display:flex;flex-direction:column;gap:.65rem}.footer__link{font-size:.875rem;color:var(--color-text-secondary);transition:color var(--transition-fast);text-decoration:none}.footer__link:hover{color:var(--color-accent-light)}.footer__link--static{cursor:default}.footer__bottom{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 0;border-top:1px solid var(--color-border)}.footer__copyright,.footer__credit{font-size:.8125rem;color:var(--color-text-muted)}.footer__credit a{color:var(--color-accent-light);font-weight:500}.footer__credit a:hover{color:var(--color-accent)}@media(max-width:768px){.footer__top{grid-template-columns:1fr 1fr;gap:2rem}.footer__brand{grid-column:span 2}.footer__bottom{flex-direction:column;gap:.5rem;text-align:center}}@media(max-width:480px){.footer__top{grid-template-columns:1fr}.footer__brand{grid-column:span 1}}.gallery-page{min-height:100vh;background:var(--color-bg-primary);padding:0 1.5rem 4rem;max-width:1200px;margin:0 auto}.gallery-page__header{padding:1.5rem 0}.gallery-page__back{display:inline-flex;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;color:var(--color-accent-light);text-decoration:none;transition:color var(--transition-fast)}.gallery-page__back:hover{color:var(--color-accent)}.gallery-page__info{margin-bottom:2.5rem;max-width:720px}.gallery-page__title{font-size:clamp(1.5rem,3.5vw,2.25rem);font-weight:800;color:var(--color-text-primary);margin-bottom:.75rem;line-height:1.2}.gallery-page__description{font-size:1rem;color:var(--color-text-secondary);line-height:1.7;margin-bottom:1.25rem}.gallery-page__techs{display:flex;flex-wrap:wrap;gap:.375rem}.gallery-page__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.gallery-page__card{position:relative;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border);background:var(--color-bg-card);cursor:pointer;transition:all var(--transition-base)}.gallery-page__card:hover{border-color:var(--color-accent);transform:translateY(-4px);box-shadow:0 8px 32px #0003}.gallery-page__card img{width:100%;aspect-ratio:9 / 16;object-fit:cover;object-position:top center;display:block;transition:transform var(--transition-slow)}.gallery-page__card:hover img{transform:scale(1.03)}.gallery-page__card-label{display:block;padding:.75rem 1rem;font-size:.8125rem;font-weight:600;color:var(--color-text-primary);background:var(--color-bg-card);border-top:1px solid var(--color-border)}.gallery-page__fullscreen{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#000000f2;overscroll-behavior:contain}.gallery-page__fs-close{position:fixed;top:1rem;right:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff1a;color:#fff;border:none;cursor:pointer;z-index:10001;transition:background .15s ease}.gallery-page__fs-close:hover{background:#fff3}.gallery-page__fs-image{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:var(--radius-md)}.gallery-page__fs-nav{position:fixed;top:50%;transform:translateY(-50%);width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff1a;color:#fff;border:none;cursor:pointer;z-index:10001;transition:background .15s ease}.gallery-page__fs-nav:hover{background:#ffffff40}.gallery-page__fs-nav--prev{left:1rem}.gallery-page__fs-nav--next{right:1rem}.gallery-page__fs-info{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:1.5rem;padding:.5rem 1.25rem;background:#000000b3;border-radius:var(--radius-sm);z-index:10001}.gallery-page__fs-label{font-size:.875rem;font-weight:600;color:#ffffffe6}.gallery-page__fs-counter{font-size:.8125rem;color:#ffffff80;font-weight:500}.gallery-page__empty{text-align:center;padding:6rem 0}.gallery-page__empty h2{font-size:1.5rem;color:var(--color-text-primary);margin-bottom:.5rem}.gallery-page__empty p{color:var(--color-text-secondary)}@media(max-width:768px){.gallery-page__grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.gallery-page__fs-image{max-width:96vw;max-height:85vh}.gallery-page__fs-nav--prev{left:.25rem}.gallery-page__fs-nav--next{right:.25rem}}
