:root{--bg:#c1c5b7;--bg-soft:#d8dbd0;--panel:#f4f5efb8;--panel-strong:#ecefe7eb;--line:#33454f29;--text:#33454f;--muted:#3e5d62;--accent:#5f8678;--accent-strong:#3e5d62;--accent-soft:#5f86782e;--success:#5f8678;--shadow:0 24px 60px #33454f1f;--radius-xl:32px;--radius-lg:24px;--radius-md:18px;--container:1480px}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}html,body{min-height:100%;margin:0}body{color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;background:radial-gradient(circle at 12% 10%,#8aad8e3d,#0000 24%),radial-gradient(circle at 88% 14%,#3e5d6224,#0000 22%),radial-gradient(circle at 78% 72%,#5f867824,#0000 28%),linear-gradient(#d8dbd0 0%,#c9cec1 52%,#c1c5b7 100%);font-family:Aptos,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}img{max-width:100%}.portfolio{position:relative;overflow:clip}.portfolio__backdrop{pointer-events:none;opacity:.34;background-image:radial-gradient(circle at 20% 18%,#f4f5ef8c 0,#f4f5ef00 32%),radial-gradient(circle at 78% 36%,#5f86781a 0,#5f867800 26%),linear-gradient(#33454f0a 1px,#0000 1px),linear-gradient(90deg,#33454f0a 1px,#0000 1px),repeating-radial-gradient(circle at 80% 22%,#3e5d620e 0 1px,#0000 1px 22px);background-position:50%,50%,50%,50%,100% 0;background-size:auto,auto,72px 72px,72px 72px,320px 320px;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000000e0,#0000004d 82%,#0000 100%);mask-image:linear-gradient(#000000e0,#0000004d 82%,#0000 100%)}.portfolio:before,.portfolio:after{content:"";pointer-events:none;z-index:-1;filter:blur(70px);border-radius:999px;position:fixed;inset:auto}.portfolio:before{background:#8aad8e29;width:28rem;height:28rem;top:12%;left:-8%}.portfolio:after{background:#3e5d621f;width:32rem;height:32rem;bottom:8%;right:-10%}.hero h1,.sectionHeading h2,.projectPanel h3,.processCard h3,.contactSection h2{font-family:Georgia,Times New Roman,serif}.section{width:min(calc(100% - 64px),var(--container));margin:0 auto}.hero{grid-template-columns:minmax(0,1.04fr) minmax(520px,.96fr);align-items:center;gap:clamp(56px,7vw,120px);min-height:100vh;padding:56px 0 48px;display:grid}.hero__copy{max-width:760px}.eyebrow{color:var(--accent);letter-spacing:.18em;text-transform:uppercase;margin:0 0 14px;font-size:.78rem;font-weight:700}.hero h1{letter-spacing:-.045em;max-width:8.4ch;margin:0;font-size:clamp(3.8rem,6.5vw,6.8rem);line-height:.92}.hero__lede{max-width:52ch;color:var(--muted);margin:28px 0 0;font-size:clamp(1.08rem,1.15vw,1.24rem);line-height:1.8}.hero__actions{flex-wrap:wrap;gap:14px;margin-top:34px;display:flex}.button{cursor:pointer;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;min-height:52px;padding:0 22px;transition:transform .18s,background .18s,border-color .18s,color .18s;display:inline-flex}.button:hover{transform:translateY(-2px)}.button:disabled{opacity:.7;cursor:wait;transform:none}.button--primary{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#f6f4ee;font-weight:700;box-shadow:0 16px 34px #1f5c4d29}.button--ghost{border-color:var(--line);color:var(--text);background:#f4f5ef8f}.hero__expertise{gap:14px;margin:42px 0 0;padding:0;list-style:none;display:grid}.hero__expertise li{color:var(--muted);padding-left:22px;line-height:1.6;position:relative}.hero__expertise li:before{content:"";background:linear-gradient(135deg,var(--accent),var(--accent-strong));border-radius:50%;width:10px;height:10px;position:absolute;top:10px;left:0;box-shadow:0 0 16px #1f5c4d2e}.hero__visual{justify-content:flex-end;align-items:center;min-height:640px;padding-left:0;display:flex;position:relative}.heroCard{background:linear-gradient(180deg,#ffffff75,transparent 35%),var(--panel);border:1px solid var(--line);border-radius:var(--radius-xl);width:min(100%,560px);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:32px;position:relative}.heroCard--main{animation:7s ease-in-out infinite floatCard}.heroCard__header{color:var(--muted);text-transform:uppercase;letter-spacing:.14em;justify-content:space-between;gap:16px;font-size:.82rem;display:flex}.heroCard__logoWrap{place-items:center;min-height:330px;display:grid}.heroCard__logo{filter:drop-shadow(0 18px 34px #1e242814);width:min(100%,290px);height:auto}.heroCard__grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.heroStat{border-radius:var(--radius-md);background:#f4f5ef85;border:1px solid #33454f14;min-height:112px;padding:16px}.heroStat strong{color:var(--accent);margin-bottom:8px;font-size:1.05rem;display:block}.heroStat span{color:var(--muted);font-size:.82rem;line-height:1.5}.sectionHeading{max-width:680px;margin-bottom:26px}.sectionHeading h2{letter-spacing:-.04em;margin:0;font-size:clamp(2rem,4vw,3.5rem);line-height:1.02}.showcase{padding:56px 0}.projectSelector{flex-wrap:wrap;gap:12px;margin-bottom:24px;display:flex}.projectSelector__item{min-width:210px;color:var(--text);text-align:left;background:#f4f5ef8a;border:1px solid #2c343a1a;border-radius:18px;flex-direction:column;gap:4px;padding:16px 18px;transition:transform .18s,border-color .18s,background .18s,box-shadow .18s;display:flex}.projectSelector__item span{font-weight:700}.projectSelector__item small{color:var(--muted);font-size:.82rem}.projectSelector__item:hover{border-color:#1f5c4d29;transform:translateY(-2px);box-shadow:0 14px 26px #3f342914}.projectSelector__item--active{background:#8aad8e2e;border-color:#5f867852}.showcase__grid{grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);align-items:stretch;gap:24px;display:grid}.projectPanel,.galleryPanel,.processCard,.stackPanel,.banner,.contactCard{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.projectPanel{padding:30px}.projectPanel__meta{color:var(--accent);letter-spacing:.16em;text-transform:uppercase;justify-content:space-between;gap:16px;font-size:.78rem;font-weight:700;display:flex}.projectPanel h3{letter-spacing:-.04em;margin:18px 0 0;font-size:clamp(2rem,3vw,3rem);line-height:1}.projectPanel__summary,.projectPanel__description,.processCard p,.contactSection__intro p,.banner p{color:var(--muted);line-height:1.75}.projectPanel__summary{margin:18px 0 0;font-size:1.08rem}.projectPanel__description{margin:18px 0 0}.projectPanel__actions{margin-top:26px}.metricList{gap:12px;margin-top:26px;display:grid}.metricList__item{background:#f4f5ef7a;border:1px solid #33454f14;border-radius:16px;padding:14px 16px}.tagRow{flex-wrap:wrap;gap:10px;margin-top:26px;display:flex}.tag{min-height:34px;color:var(--text);background:#f4f5ef85;border:1px solid #33454f14;border-radius:999px;align-items:center;padding:0 14px;font-size:.88rem;display:inline-flex}.tag--soft{background:var(--accent-soft);border-color:#1f5c4d1f}.galleryPanel{flex-direction:column;padding:18px;display:flex}.galleryPanel__frame{cursor:zoom-in;background:#8bad8e;border-radius:22px;justify-content:center;align-items:center;min-height:560px;display:flex;position:relative;overflow:hidden}.galleryPanel__image{opacity:0;cursor:zoom-in;pointer-events:none;transition:opacity .5s,transform .8s;position:absolute;inset:0;transform:scale(1.03)}.galleryPanel__img{object-fit:contain;object-position:center}.galleryPanel__video{object-fit:contain;background:#000;width:100%;height:100%;display:block}.galleryPanel__image--active{opacity:1;pointer-events:auto;transform:scale(1)}.galleryPanel__controls{justify-content:space-between;align-items:center;gap:20px;padding:18px 6px 6px;display:flex}.galleryPanel__caption{gap:6px;display:grid}.galleryPanel__caption span{color:var(--accent);letter-spacing:.16em;text-transform:uppercase;font-size:.76rem;font-weight:700}.galleryPanel__caption strong{font-size:.94rem}.galleryPanel__dots{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.galleryDot{cursor:pointer;background:#33454f2e;border:0;border-radius:999px;width:12px;height:12px;transition:width .18s,background .18s,transform .18s}.galleryDot:hover{transform:translateY(-1px)}.galleryDot--active{background:linear-gradient(135deg,var(--accent),var(--accent-strong));width:34px}.lightbox{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#5f716e9e;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.lightbox__panel{background:linear-gradient(#f4f5ef24,#f4f5ef0a),#33454fe6;border:1px solid #f4f5ef57;border-radius:28px;width:min(100%,1180px);max-height:calc(100vh - 48px);padding:18px;position:relative;box-shadow:0 30px 80px #33454f42}.lightbox__close{color:#f4f5ef;cursor:pointer;background:#f4f5ef14;border:1px solid #f4f5ef2e;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.7rem;line-height:1;transition:background .18s,transform .18s;display:inline-flex;position:absolute;top:18px;right:18px}.lightbox__close:hover{background:#f4f5ef24;transform:translateY(-1px)}.lightbox__mediaWrap{background:#141d20d1;border-radius:22px;height:min(72vh,760px);margin-top:30px;position:relative;overflow:hidden}.lightbox__arrow{z-index:2;color:#f4f5ef;cursor:pointer;background:#33454fb8;border:1px solid #f4f5ef2e;border-radius:50%;width:52px;height:52px;transition:background .18s,transform .18s;position:absolute;top:50%;transform:translateY(-50%)}.lightbox__arrow:hover{background:#33454feb}.lightbox__arrow--left{left:18px}.lightbox__arrow--right{right:18px}.lightbox__img{object-fit:contain}.lightbox__video{object-fit:contain;background:#000;width:100%;height:100%}.lightbox__footer{justify-content:space-between;align-items:center;gap:18px;margin-top:16px;display:flex}.lightbox__caption{color:#f4f5ef;gap:6px;display:grid}.lightbox__caption span{color:#d8dbd0;letter-spacing:.14em;text-transform:uppercase;font-size:.76rem;font-weight:700}.galleryPanel__placeholder{background:linear-gradient(#8aad8e33,#5f867814),#f4f5ef80;border-radius:22px;flex-direction:column;justify-content:center;align-items:flex-start;min-height:560px;padding:38px;display:flex}.galleryPanel__placeholderTag{min-height:32px;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;background:#8aad8e3d;border-radius:999px;align-items:center;margin-bottom:18px;padding:0 12px;font-size:.78rem;font-weight:700;display:inline-flex}.galleryPanel__placeholder h4{letter-spacing:-.04em;margin:0;font-family:Georgia,Times New Roman,serif;font-size:clamp(2rem,4vw,3rem);line-height:1}.galleryPanel__placeholder p{max-width:38ch;color:var(--muted);margin:18px 0 26px;line-height:1.75}.reveal{opacity:0;will-change:opacity,transform;transition:opacity 1.1s cubic-bezier(.16,1,.3,1),transform 1.1s cubic-bezier(.16,1,.3,1)}.reveal--up{transform:translateY(64px)}.reveal--left{transform:translate(-72px)}.reveal--right{transform:translate(72px)}.reveal--scale{transform:translateY(36px)scale(.94)}.reveal.is-visible{opacity:1;transform:translate(0,0)scale(1)}.process{padding:56px 0}.process__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;display:grid}.processCard{padding:26px}.processCard__index{color:var(--accent);letter-spacing:.14em;margin-bottom:18px;font-size:.78rem;font-weight:700;display:inline-flex}.processCard h3{margin:0;font-size:1.5rem}.stackPanel{margin-top:22px;padding:26px}.banner{margin-top:12px;margin-bottom:56px;padding:26px 30px}.banner p{max-width:60ch;margin:0;font-size:1.05rem}.contactSection{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:24px;padding-bottom:72px;display:grid}.contactSection__intro{padding:8px 0}.contactSection h2{letter-spacing:-.05em;margin:0;font-size:clamp(2.2rem,4vw,3.6rem);line-height:1.02}.contactMeta{gap:18px;margin-top:28px;display:grid}.contactMeta span,.field span{color:var(--accent);letter-spacing:.16em;text-transform:uppercase;margin-bottom:8px;font-size:.76rem;font-weight:700;display:block}.contactMeta strong{color:var(--text);line-height:1.6;display:block}.contactCard{padding:28px}.fieldGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.field{margin-bottom:16px;display:block}.field input,.field textarea{background:var(--panel-strong);width:100%;color:var(--text);border:1px solid #33454f24;border-radius:18px;outline:none;padding:15px 16px;transition:border-color .18s,box-shadow .18s}.field input::placeholder,.field textarea::placeholder{color:#7a7c7a}.field input:focus,.field textarea:focus{border-color:#1f5c4d59;box-shadow:0 0 0 4px #1f5c4d14}.field textarea{resize:vertical;min-height:160px}.contactCard__footer{justify-content:space-between;align-items:center;gap:16px;margin-top:8px;display:flex}.contactStatus{max-width:32ch;color:var(--muted);margin:0;line-height:1.6}@keyframes floatCard{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}@media (max-width:1100px){.hero,.showcase__grid,.contactSection{grid-template-columns:1fr}.hero{gap:40px;min-height:auto;padding-top:42px}.hero__visual{justify-content:flex-start;min-height:auto;padding-top:16px;padding-left:0}.heroCard{width:min(100%,620px)}.projectSelector{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.process__grid{grid-template-columns:1fr}.galleryPanel__frame,.galleryPanel__placeholder{min-height:460px}}@media (max-width:760px){.section{width:min(calc(100% - 20px),var(--container))}.hero,.galleryPanel__controls,.contactCard__footer{flex-direction:column;align-items:flex-start}.hero{gap:28px;padding-top:24px;padding-bottom:36px}.hero h1{max-width:none;font-size:clamp(2.9rem,13vw,4.1rem);line-height:.95}.hero__lede{margin-top:22px;font-size:1rem;line-height:1.7}.hero__actions{gap:12px;width:100%}.hero__actions .button{width:100%}.hero__expertise{gap:12px;margin-top:28px}.heroCard{padding:20px}.heroCard__grid,.fieldGrid{grid-template-columns:1fr}.heroStat{min-height:auto}.heroCard__logoWrap{min-height:200px}.heroCard__logo{width:min(100%,190px)}.sectionHeading{margin-bottom:22px}.sectionHeading h2{font-size:clamp(1.9rem,9vw,2.7rem);line-height:1.08}.projectSelector{grid-template-columns:1fr;margin-bottom:18px}.projectSelector__item{width:100%;min-width:0;padding:14px 16px}.galleryPanel__frame{min-height:320px}.galleryPanel__controls{padding:16px 2px 2px}.galleryPanel__caption{width:100%}.galleryPanel__dots{justify-content:flex-start}.galleryPanel__placeholder{min-height:320px;padding:24px}.projectPanel,.galleryPanel,.processCard,.stackPanel,.banner,.contactCard{border-radius:24px}.contactCard{padding:20px}.lightbox{padding:12px}.lightbox__panel{border-radius:22px;max-height:calc(100vh - 24px);padding:14px}.lightbox__close{top:14px;right:14px}.lightbox__mediaWrap{height:min(58vh,420px)}.lightbox__arrow{width:44px;height:44px}.lightbox__arrow--left{left:10px}.lightbox__arrow--right{right:10px}.lightbox__footer{flex-direction:column;align-items:flex-start}.projectPanel,.processCard,.stackPanel,.banner{padding:22px}.projectPanel h3,.galleryPanel__placeholder h4{font-size:clamp(1.8rem,8vw,2.35rem)}.metricList,.tagRow,.projectPanel__actions{margin-top:20px}.contactSection{gap:18px;padding-bottom:48px}.contactSection h2{font-size:clamp(2rem,9vw,2.8rem);line-height:1.08}.contactMeta{gap:14px;margin-top:22px}.contactStatus{max-width:none}.portfolio:before{width:18rem;height:18rem;left:-18%}.portfolio:after{width:20rem;height:20rem;bottom:12%;right:-22%}}@media (max-width:520px){.hero h1{font-size:clamp(2.5rem,13vw,3.4rem)}.eyebrow{letter-spacing:.15em;font-size:.72rem}.heroCard,.projectPanel,.galleryPanel,.processCard,.stackPanel,.banner,.contactCard{border-radius:20px}.heroCard{padding:18px}.heroCard__header{letter-spacing:.1em;font-size:.72rem}.heroCard__grid{gap:10px}.heroStat{padding:14px}.galleryPanel__placeholder,.galleryPanel__frame{min-height:280px}.field input,.field textarea{padding:14px}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition:none!important;animation:none!important}}
