:root{--mao-forest-50: #ECF3EF;--mao-forest-100: #D2E2D9;--mao-forest-200: #A8C7B7;--mao-forest-300: #7BB89E;--mao-forest-400: #4E9B7E;--mao-forest-500: #2E7D5F;--mao-forest-600: #186A4D;--mao-forest-700: #0F3D2E;--mao-forest-800: #082A20;--mao-forest-900: #051A14;--mao-graphite-50: #F4F4F2;--mao-graphite-100: #E7E7E3;--mao-graphite-200: #CACAC4;--mao-graphite-300: #9C9C95;--mao-graphite-400: #6F6F69;--mao-graphite-500: #4A4A45;--mao-graphite-600: #2E2E2B;--mao-graphite-700: #1C1C1A;--mao-graphite-800: #131312;--mao-graphite-900: #0A0A09;--mao-parchment: #F7F5EF;--mao-paper: #FFFFFF;--mao-fog: #EDEAE2;--mao-bone: #E2DED3;--mao-stone-100: #D6D2C7;--mao-stone-200: #B4B0A6;--mao-stone-300: #8B877E;--mao-stone-400: #5F5C55;--mao-stone-500: #3A3833;--mao-stone-600: #26241F;--mao-stone-700: #15140F;--mao-success: #2E7D5F;--mao-success-soft: #DDEBE3;--mao-warning: #B86E1A;--mao-warning-soft: #F2E4CC;--mao-danger: #A23A2E;--mao-danger-soft: #F1D9D5;--mao-info: #2C5780;--mao-info-soft: #D9E2EC;--color-bg: var(--mao-parchment);--color-surface: var(--mao-paper);--color-surface-alt: var(--mao-fog);--color-border: var(--mao-bone);--color-border-strong: var(--mao-stone-100);--color-overlay: rgba(15, 23, 20, .55);--fg-1: var(--mao-stone-700);--fg-2: var(--mao-stone-500);--fg-3: var(--mao-stone-400);--fg-4: var(--mao-stone-300);--fg-inverse: var(--mao-parchment);--brand: var(--mao-forest-700);--brand-hover: var(--mao-forest-600);--brand-soft: var(--mao-forest-50);--brand-soft-2: var(--mao-forest-100);--brand-accent: var(--mao-forest-300);--brand-deep: var(--mao-forest-800);--font-sans: "Geist", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Geist Mono", "JetBrains Mono", ui-monospace, "SF Mono", Consolas, monospace;--font-display: var(--font-sans);--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-15: .9375rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-20: 1.25rem;--fs-24: 1.5rem;--fs-28: 1.75rem;--fs-32: 2rem;--fs-40: 2.5rem;--fs-48: 3rem;--fs-60: 3.75rem;--fs-72: 4.5rem;--lh-tight: 1.1;--lh-snug: 1.25;--lh-normal: 1.5;--lh-relaxed: 1.65;--tracking-tighter: -.04em;--tracking-tight: -.02em;--tracking-normal: 0;--tracking-wide: .04em;--tracking-caps: .14em;--sp-0: 0;--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.25rem;--sp-6: 1.5rem;--sp-7: 1.75rem;--sp-8: 2rem;--sp-10: 2.5rem;--sp-12: 3rem;--sp-16: 4rem;--sp-20: 5rem;--sp-24: 6rem;--sp-32: 8rem;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--shadow-xs: 0 1px 1px rgba(20, 18, 14, .04);--shadow-sm: 0 1px 2px rgba(20, 18, 14, .06), 0 1px 1px rgba(20, 18, 14, .04);--shadow-md: 0 4px 8px -2px rgba(20, 18, 14, .07), 0 2px 4px -2px rgba(20, 18, 14, .05);--shadow-lg: 0 12px 24px -8px rgba(20, 18, 14, .1), 0 4px 8px -4px rgba(20, 18, 14, .06);--shadow-xl: 0 24px 48px -12px rgba(20, 18, 14, .14), 0 8px 16px -8px rgba(20, 18, 14, .08);--shadow-brand: 0 8px 24px -6px rgba(15, 61, 46, .28);--ring-brand: 0 0 0 3px rgba(15, 61, 46, .18);--ring-danger: 0 0 0 3px rgba(162, 58, 46, .2);--ring-focus: 0 0 0 3px rgba(15, 61, 46, .3);--ease-out: cubic-bezier(.22, .61, .36, 1);--ease-in: cubic-bezier(.55, .06, .68, .19);--ease-inout: cubic-bezier(.65, .05, .36, 1);--ease-soft: cubic-bezier(.4, 0, .2, 1);--dur-fast: .14s;--dur-base: .22s;--dur-slow: .38s;--dur-page: .6s;--t-fast: var(--dur-fast) var(--ease-out);--t-base: var(--dur-base) var(--ease-out);--t-slow: var(--dur-slow) var(--ease-inout);--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1200px;--container-2xl: 1400px;--navbar-h: 72px;--color-primary: var(--brand);--color-primary-dark: var(--brand-hover);--color-primary-darker: var(--brand-deep);--color-primary-light: var(--brand-soft-2);--color-primary-lighter: var(--brand-soft);--color-accent: var(--brand-accent);--text-primary: var(--fg-1);--text-secondary: var(--fg-2);--text-muted: var(--fg-3);--text-inverse: var(--fg-inverse);--bg-white: var(--color-bg);--bg-light: var(--color-surface-alt);--bg-green-light: var(--brand-soft);--bg-dark: var(--brand-deep);--font-family: var(--font-sans);--font-size-xs: var(--fs-12);--font-size-sm: var(--fs-14);--font-size-base: var(--fs-16);--font-size-lg: var(--fs-18);--font-size-xl: var(--fs-20);--font-size-2xl: var(--fs-24);--font-size-3xl: var(--fs-28);--font-size-4xl: var(--fs-32);--font-size-5xl: var(--fs-48);--font-size-6xl: var(--fs-60);--font-size-7xl: var(--fs-72);--space-1: var(--sp-1);--space-2: var(--sp-2);--space-3: var(--sp-3);--space-4: var(--sp-4);--space-5: var(--sp-5);--space-6: var(--sp-6);--space-8: var(--sp-8);--space-10: var(--sp-10);--space-12: var(--sp-12);--space-16: var(--sp-16);--space-20: var(--sp-20);--space-24: var(--sp-24);--space-32: var(--sp-32);--shadow-green: var(--shadow-brand);--transition-fast: var(--t-fast);--transition-base: var(--t-base);--transition-slow: var(--t-slow);--container-max: var(--container-xl);--navbar-height: var(--navbar-h)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--fs-16);color:var(--fg-1);background:var(--color-bg);line-height:var(--lh-relaxed);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}img{display:block;max-width:100%}a{color:inherit}button{font-family:inherit}.section{padding:var(--space-32) var(--space-8)}.section__container{max-width:var(--container-max);margin:0 auto}.section__header{text-align:center;margin-bottom:var(--space-16)}.section__eyebrow{display:inline-block;font-size:var(--font-size-xs);font-weight:700;color:var(--color-primary);letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--space-3)}.section__title{font-size:clamp(var(--font-size-3xl),3.5vw,var(--font-size-5xl));font-weight:800;color:var(--text-primary);letter-spacing:-.025em;line-height:1.15;margin-bottom:var(--space-4)}.section__subtitle{font-size:var(--font-size-lg);color:var(--text-secondary);max-width:580px;margin:0 auto;line-height:1.75}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);border:none;cursor:pointer;font-family:var(--font-sans);font-weight:600;text-decoration:none;border-radius:var(--radius-md);transition:background var(--t-fast),color var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast);white-space:nowrap;line-height:1}.btn--primary{background:var(--brand);color:var(--fg-inverse)}.btn--primary:hover{background:var(--brand-hover);transform:translateY(-2px);box-shadow:var(--shadow-brand)}.btn--primary:active{transform:scale(.98);box-shadow:none}.btn--outline{background:transparent;color:var(--brand);border:1.5px solid var(--brand)}.btn--outline:hover{background:var(--brand-soft);transform:translateY(-2px)}.btn--outline:active{transform:scale(.98)}.btn--ghost{background:#f7f5ef1f;color:var(--mao-parchment);border:1.5px solid rgba(247,245,239,.3)}.btn--ghost:hover{background:#f7f5ef38;transform:translateY(-2px)}.btn--ghost:active{transform:scale(.98)}.btn--lg{padding:var(--sp-4) var(--sp-8);font-size:var(--fs-16);height:52px}.btn--md{padding:var(--sp-3) var(--sp-6);font-size:var(--fs-14);height:42px}.btn--sm{padding:var(--sp-2) var(--sp-4);font-size:var(--fs-12);height:34px}.animate-on-scroll{opacity:0;transform:translateY(16px);transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}.animate-on-scroll.is-visible{opacity:1;transform:translateY(0)}.animate-on-scroll.delay-1{transition-delay:.08s}.animate-on-scroll.delay-2{transition-delay:.16s}.animate-on-scroll.delay-3{transition-delay:.24s}.animate-on-scroll.delay-4{transition-delay:.32s}.animate-on-scroll.delay-5{transition-delay:.4s}.animate-on-scroll.delay-6{transition-delay:.48s}@media(max-width:768px){.section{padding:var(--space-20) var(--space-6)}}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--navbar-height);transition:background var(--transition-base),box-shadow var(--transition-base),backdrop-filter var(--transition-base)}.navbar--scrolled{background:#f7f5efd1;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 1px 0 0 var(--color-border)}.navbar__container{max-width:var(--container-max);margin:0 auto;padding:0 var(--space-8);height:100%;display:flex;align-items:center;justify-content:space-between}.navbar__logo{display:flex;align-items:center}.navbar__logo img{height:34px;width:auto}.navbar__nav{display:flex;align-items:center;gap:var(--space-8)}.navbar__link{font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast);position:relative}.navbar__link:after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:2px;background:var(--color-primary);border-radius:1px;transition:right var(--transition-base)}.navbar__link:hover{color:var(--color-primary)}.navbar__link:hover:after{right:0}.navbar__cta{margin-left:var(--space-2)}.navbar__hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md)}.navbar__hamburger span{display:block;width:22px;height:2px;background:var(--text-primary);border-radius:2px;transform-origin:center;transition:transform var(--transition-base),opacity var(--transition-base)}.navbar__hamburger--open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navbar__hamburger--open span:nth-child(2){opacity:0;transform:scaleX(0)}.navbar__hamburger--open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.navbar__mobile{display:none;position:fixed;top:var(--navbar-height);left:0;right:0;bottom:0;flex-direction:column;gap:var(--space-2);background:#f7f5eff7;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:var(--space-6) var(--space-8);border-top:1px solid var(--color-border);overflow-y:auto;transform:translateY(-8px);opacity:0;transition:opacity var(--transition-base),transform var(--transition-base)}.navbar__mobile--open{opacity:1;transform:translateY(0)}.navbar__mobile-link{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);text-decoration:none;padding:var(--space-4) 0;border-bottom:1px solid rgba(0,0,0,.05);transition:color var(--transition-fast)}.navbar__mobile-link:hover{color:var(--color-primary)}.navbar__mobile-cta{margin-top:var(--space-4);align-self:flex-start}@media(max-width:768px){.navbar__nav{display:none}.navbar__hamburger,.navbar__mobile{display:flex}}@media(max-width:480px){.navbar__container{padding:0 var(--space-5)}}.hero{position:relative;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;background:var(--bg-white);padding-top:var(--navbar-height)}.hero__blobs{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.hero__blob{position:absolute;border-radius:50%;filter:blur(72px)}.hero__blob--1{width:600px;height:600px;background:radial-gradient(circle,var(--mao-forest-100) 0%,rgba(210,226,217,0) 70%);top:-160px;right:-160px;opacity:.7;animation:blob-float 9s ease-in-out infinite}.hero__blob--2{width:340px;height:340px;background:radial-gradient(circle,var(--mao-forest-200) 0%,rgba(168,199,183,0) 70%);bottom:60px;left:-100px;opacity:.5;animation:blob-float 12s ease-in-out infinite reverse}.hero__blob--3{width:200px;height:200px;background:radial-gradient(circle,var(--mao-forest-300) 0%,rgba(123,184,158,0) 70%);top:40%;left:40%;opacity:.25;animation:blob-float 7s ease-in-out infinite 2s}@keyframes blob-float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-18px) scale(1.04)}}.hero__container{max-width:var(--container-max);width:100%;margin:0 auto;padding:var(--space-20) var(--space-8);display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center;position:relative}.hero__text{opacity:0;transform:translateY(28px);transition:opacity .85s var(--transition-slow),transform .85s var(--transition-slow)}.hero__text--visible{opacity:1;transform:none}.hero__eyebrow{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-primary);margin-bottom:var(--space-5)}.hero__headline{font-size:clamp(2.4rem,4.2vw,3.9rem);font-weight:900;line-height:1.1;letter-spacing:-.035em;color:var(--text-primary);margin-bottom:var(--space-6)}.hero__headline em{font-style:normal;color:var(--color-primary)}.hero__subtitle{font-size:var(--font-size-lg);color:var(--text-secondary);line-height:1.75;margin-bottom:var(--space-10);max-width:480px}.hero__actions{display:flex;gap:var(--space-4);flex-wrap:wrap;margin-bottom:var(--space-8)}.hero__trust{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--text-muted)}.hero__trust-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--color-primary);animation:pulse 2.4s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 #0f3d2e66}50%{box-shadow:0 0 0 6px #0f3d2e00}}.hero__visual{position:relative;height:440px;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(28px);transition:opacity .85s .2s var(--transition-slow),transform .85s .2s var(--transition-slow)}.hero__visual--visible{opacity:1;transform:none}.hero__icon-wrap{animation:icon-float 6s ease-in-out infinite;filter:drop-shadow(0 24px 48px rgba(15,61,46,.22))}.hero__icon{width:180px;height:180px;border-radius:var(--radius-2xl)}@keyframes icon-float{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}.hero__ring{position:absolute;width:260px;height:260px;border:1.5px solid rgba(15,61,46,.18);border-radius:50%;animation:ring-spin 18s linear infinite}.hero__ring:before{content:"";position:absolute;top:-5px;left:50%;width:10px;height:10px;background:var(--color-primary);border-radius:50%;transform:translate(-50%);box-shadow:var(--shadow-green)}@keyframes ring-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hero__badge{position:absolute;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:#fff;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;color:var(--text-primary);box-shadow:var(--shadow-lg);white-space:nowrap;letter-spacing:.01em}.hero__badge-dot{width:7px;height:7px;border-radius:50%;background:var(--color-primary);flex-shrink:0}.hero__badge-dot--alt{background:var(--color-accent)}.hero__badge--1{top:70px;right:10px;animation:badge-float 5s ease-in-out infinite}.hero__badge--2{bottom:90px;left:10px;animation:badge-float 5.5s ease-in-out infinite .8s}.hero__badge--3{top:50%;right:-10px;transform:translateY(-50%);animation:badge-float 6.5s ease-in-out infinite 1.5s}@keyframes badge-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.hero__badge--3{animation-name:badge-float-mid}@keyframes badge-float-mid{0%,to{transform:translateY(-50%)}50%{transform:translateY(calc(-50% - 8px))}}.hero__scroll{position:absolute;bottom:var(--space-10);left:50%;transform:translate(-50%);width:26px;height:42px;border:2px solid rgba(0,0,0,.14);border-radius:var(--radius-full);display:flex;justify-content:center;align-items:flex-start;padding-top:7px;transition:border-color var(--transition-base)}.hero__scroll:hover{border-color:var(--color-primary)}.hero__scroll-wheel{width:4px;height:8px;background:var(--color-primary);border-radius:var(--radius-full);animation:scroll-drop 2.2s ease-in-out infinite}@keyframes scroll-drop{0%{transform:translateY(0);opacity:1}80%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:0}}@media(max-width:960px){.hero__container{grid-template-columns:1fr;text-align:center;gap:var(--space-12)}.hero__subtitle,.hero__headline{max-width:100%}.hero__subtitle{margin:0 auto var(--space-10)}.hero__actions,.hero__trust{justify-content:center}.hero__visual{height:300px;order:-1}.hero__icon{width:130px;height:130px}.hero__ring{width:200px;height:200px}.hero__badge--3{display:none}}@media(max-width:480px){.hero__container{padding:var(--space-12) var(--space-5)}.hero__badge--1,.hero__badge--2{display:none}}.about{background:var(--bg-green-light)}.about__container{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-20);align-items:center}.about__title{margin-bottom:var(--space-6)}.about__body{font-size:var(--font-size-lg);color:var(--text-secondary);line-height:1.8;margin-bottom:var(--space-5)}.about__stats{display:flex;gap:var(--space-10);margin-top:var(--space-10);padding-top:var(--space-8);border-top:1px solid rgba(15,61,46,.2)}.about__stat{display:flex;flex-direction:column;gap:var(--space-1)}.about__stat-value{font-size:var(--font-size-4xl);font-weight:900;color:var(--color-primary);letter-spacing:-.04em;line-height:1}.about__stat-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.about__visual{display:flex;flex-direction:column;gap:var(--space-5)}.about__card{background:var(--bg-dark);border-radius:var(--radius-2xl);padding:var(--space-8);display:flex;flex-direction:column;gap:var(--space-5);box-shadow:var(--shadow-xl)}.about__card-icon{width:64px;height:64px;border-radius:var(--radius-xl)}.about__card-text{display:flex;flex-direction:column;gap:var(--space-1)}.about__card-name{font-size:var(--font-size-xl);font-weight:800;color:#fff;letter-spacing:-.02em}.about__card-tagline{font-size:var(--font-size-sm);color:var(--color-accent);font-weight:500;letter-spacing:.04em}.about__card-tag{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:#ffffff8c;font-weight:500}.about__dot{width:7px;height:7px;border-radius:50%;background:var(--color-accent);display:inline-block;animation:about-pulse 2.4s ease-in-out infinite}@keyframes about-pulse{0%,to{box-shadow:0 0 #7bb89e80}50%{box-shadow:0 0 0 6px #7bb89e00}}.about__float{background:#fff;border-radius:var(--radius-xl);padding:var(--space-5) var(--space-6);box-shadow:var(--shadow-md)}.about__float-label{display:block;font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-3)}.about__chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.about__chip{padding:var(--space-1) var(--space-3);background:var(--color-primary-lighter);color:var(--color-primary-darker);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}@media(max-width:960px){.about__container{grid-template-columns:1fr;gap:var(--space-12)}.about__stats{justify-content:space-between}}@media(max-width:480px){.about__stats{flex-direction:column;gap:var(--space-6)}}.services{background:var(--bg-white)}.services__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--space-6)}.service-card{grid-column:span 2;background:var(--bg-white);border:1px solid rgba(0,0,0,.07);border-radius:var(--radius-2xl);padding:var(--space-8);display:flex;flex-direction:column;gap:var(--space-4);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.service-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#0f3d2e33}.service-card:nth-child(4){grid-column:2 / 4}.service-card:nth-child(5){grid-column:4 / 6}.service-card__icon{width:48px;height:48px;background:var(--color-primary-lighter);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.service-card__icon svg{width:22px;height:22px}.service-card__title{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1.3}.service-card__desc{font-size:var(--font-size-base);color:var(--text-secondary);line-height:1.75;flex:1}@media(max-width:1024px){.services__grid{grid-template-columns:repeat(2,1fr)}.service-card{grid-column:span 1}.service-card:nth-child(4){grid-column:span 1}.service-card:nth-child(5){grid-column:span 1}}@media(max-width:640px){.services__grid{grid-template-columns:1fr}}.portfolio{background:var(--bg-light)}.portfolio__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.project-card{background:#fff;border-radius:var(--radius-2xl);overflow:hidden;border:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;transition:transform var(--transition-base),box-shadow var(--transition-base)}.project-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-border-strong)}.project-card__header{height:140px;position:relative;display:flex;align-items:flex-end;padding:var(--space-4) var(--space-5)}.project-card__status{display:inline-flex;padding:var(--space-1) var(--space-3);background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;color:#fff;letter-spacing:.04em}.project-card__body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3);flex:1}.project-card__tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.project-card__tag{padding:2px var(--space-2);background:var(--color-primary-lighter);color:var(--color-primary-darker);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.03em}.project-card__title{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.project-card__desc{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.7;flex:1}.project-card__header-icon{position:absolute;top:var(--space-4);right:var(--space-4);width:32px;height:32px;background:#ffffff2e;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.28);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:opacity .2s ease,transform .2s ease}.project-card__header-icon svg{width:14px;height:14px;color:#fff}.project-card--linked:hover .project-card__header-icon{opacity:1;transform:scale(1)}.project-card__link{display:inline-flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2);padding:var(--space-2) var(--space-4);align-self:flex-start;background:transparent;border:1.5px solid var(--color-primary);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;text-decoration:none;transition:background var(--transition-base),color var(--transition-base),transform var(--transition-base)}.project-card__link svg{width:14px;height:14px;transition:transform .2s ease}.project-card__link:hover{background:var(--color-primary);color:#fff;transform:translate(2px)}.project-card__link:hover svg{transform:translate(3px)}@media(max-width:1024px){.portfolio__grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.portfolio__grid{grid-template-columns:1fr}}.contact{background:var(--bg-white)}.contact__container{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-20);align-items:start}.contact__title{margin-bottom:var(--space-4)}.contact__body{font-size:var(--font-size-lg);color:var(--text-secondary);line-height:1.75;margin-bottom:var(--space-10)}.contact__items{display:flex;flex-direction:column;gap:var(--space-5)}.contact__item{display:flex;align-items:center;gap:var(--space-4);text-decoration:none;color:inherit;transition:color var(--transition-fast)}.contact__item:hover .contact__item-value{color:var(--color-primary)}.contact__item-icon{width:44px;height:44px;flex-shrink:0;background:var(--color-primary-lighter);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.contact__item-icon svg{width:20px;height:20px}.contact__item div{display:flex;flex-direction:column;gap:2px}.contact__item-label{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.contact__item-value{font-size:var(--font-size-base);font-weight:500;color:var(--text-primary);transition:color var(--transition-fast)}.contact__form-wrap{background:var(--bg-light);border-radius:var(--radius-2xl);padding:var(--space-10);border:1px solid rgba(0,0,0,.06)}.contact__form{display:flex;flex-direction:column;gap:var(--space-5)}.contact__field{display:flex;flex-direction:column;gap:var(--space-2)}.contact__label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.contact__input{width:100%;padding:var(--space-3) var(--space-4);background:#fff;border:1.5px solid rgba(0,0,0,.1);border-radius:var(--radius-lg);font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.contact__input::placeholder{color:var(--text-muted)}.contact__input:focus{border-color:var(--brand);box-shadow:var(--ring-brand)}.contact__textarea{resize:vertical;min-height:120px;line-height:1.6}.contact__error{font-size:var(--fs-14);color:var(--mao-danger);background:var(--mao-danger-soft);border:1px solid var(--mao-danger);border-radius:var(--radius-md);padding:var(--sp-3) var(--sp-4)}.contact__submit{width:100%;justify-content:center}.contact__submit:disabled{opacity:.65;cursor:not-allowed;transform:none!important}.contact__success{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4);padding:var(--space-12) var(--space-6)}.contact__success-icon{width:64px;height:64px;border-radius:50%;background:var(--color-primary-lighter);color:var(--color-primary);font-size:var(--font-size-3xl);font-weight:700;display:flex;align-items:center;justify-content:center}.contact__success h3{font-size:var(--font-size-2xl);font-weight:800;color:var(--text-primary)}.contact__success p{font-size:var(--font-size-base);color:var(--text-secondary);max-width:320px;line-height:1.7}@media(max-width:960px){.contact__container{grid-template-columns:1fr;gap:var(--space-12)}}@media(max-width:480px){.contact__form-wrap{padding:var(--space-6)}}.footer{background:var(--bg-dark);color:#ffffffbf;font-size:var(--font-size-sm)}.footer__top{max-width:var(--container-max);margin:0 auto;padding:var(--space-20) var(--space-8);display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:var(--space-12)}.footer__logo{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;margin-bottom:var(--space-5)}.footer__logo-icon{width:44px;height:44px;border-radius:var(--radius-lg);flex-shrink:0}.footer__logo-text{display:flex;flex-direction:column;gap:2px}.footer__logo-name{font-size:var(--font-size-base);font-weight:800;color:#fff;letter-spacing:-.02em}.footer__logo-tagline{font-size:var(--font-size-xs);color:var(--color-accent);letter-spacing:.04em;font-weight:500}.footer__brand-desc{font-size:var(--font-size-sm);color:#ffffff80;line-height:1.75;margin-bottom:var(--space-6)}.footer__social{display:flex;gap:var(--space-3)}.footer__social-link{width:38px;height:38px;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:#ffffff8c;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.footer__social-link:hover{background:#ffffff1a;color:#fff;border-color:#ffffff40}.footer__social-link svg{width:17px;height:17px}.footer__col-title{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#fff;margin-bottom:var(--space-5)}.footer__links{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}.footer__link{color:#ffffff80;text-decoration:none;font-size:var(--font-size-sm);transition:color var(--transition-fast);line-height:1.5}.footer__link:hover{color:var(--color-accent)}.footer__location{display:flex;align-items:center;gap:var(--space-2);color:#ffffff80;font-size:var(--font-size-sm)}.footer__avail-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--color-primary);flex-shrink:0;animation:avail-pulse 2.4s ease-in-out infinite}@keyframes avail-pulse{0%,to{box-shadow:0 0 #0f3d2e80}50%{box-shadow:0 0 0 5px #0f3d2e00}}.footer__bottom{max-width:var(--container-max);margin:0 auto;padding:var(--space-6) var(--space-8);border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between}.footer__copy{color:#ffffff59;font-size:var(--font-size-xs)}.footer__domain{font-size:var(--font-size-xs);font-weight:600;color:var(--color-accent);letter-spacing:.04em}@media(max-width:1024px){.footer__top{grid-template-columns:1fr 1fr;gap:var(--space-10)}.footer__brand{grid-column:1 / -1}}@media(max-width:640px){.footer__top{grid-template-columns:1fr;padding:var(--space-12) var(--space-6)}.footer__bottom{flex-direction:column;gap:var(--space-2);text-align:center;padding:var(--space-5) var(--space-6)}}
