@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/0b1dc8ddaa74ba49-s.8624a701.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/e629b5bc06499d58-s.8e66b869.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/1a099d89ee94ee96-s.f6ed4c33.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/fba5a26ea33df6a3-s.p.1bbdebe6.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/0b1dc8ddaa74ba49-s.8624a701.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/e629b5bc06499d58-s.8e66b869.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/1a099d89ee94ee96-s.f6ed4c33.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/fba5a26ea33df6a3-s.p.1bbdebe6.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:600;font-display:swap;src:url(../media/0b1dc8ddaa74ba49-s.8624a701.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:600;font-display:swap;src:url(../media/e629b5bc06499d58-s.8e66b869.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:600;font-display:swap;src:url(../media/1a099d89ee94ee96-s.f6ed4c33.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:600;font-display:swap;src:url(../media/fba5a26ea33df6a3-s.p.1bbdebe6.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:700;font-display:swap;src:url(../media/0b1dc8ddaa74ba49-s.8624a701.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:700;font-display:swap;src:url(../media/e629b5bc06499d58-s.8e66b869.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:700;font-display:swap;src:url(../media/1a099d89ee94ee96-s.f6ed4c33.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:700;font-display:swap;src:url(../media/fba5a26ea33df6a3-s.p.1bbdebe6.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Plus Jakarta Sans Fallback;src:local(Arial);ascent-override:98.88%;descent-override:21.15%;line-gap-override:0.0%;size-adjust:104.98%}.plus_jakarta_sans_2b965ca8-module__koHbNG__className{font-family:Plus Jakarta Sans,Plus Jakarta Sans Fallback;font-style:normal}.plus_jakarta_sans_2b965ca8-module__koHbNG__variable{--font-plus-jakarta:"Plus Jakarta Sans","Plus Jakarta Sans Fallback"}
@font-face{font-family:Instrument Serif;font-style:italic;font-weight:400;font-display:swap;src:url(../media/fc0a7394b875fa43-s.614a1c00.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Instrument Serif;font-style:italic;font-weight:400;font-display:swap;src:url(../media/7ebf22b5a21034f8-s.p.d8bad3ab.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Instrument Serif;font-style:normal;font-weight:400;font-display:swap;src:url(../media/ccf27e5a7366fb23-s.262b87c4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Instrument Serif;font-style:normal;font-weight:400;font-display:swap;src:url(../media/e41d5df559864f9e-s.p.380d09ea.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Instrument Serif Fallback;src:local(Times New Roman);ascent-override:117.94%;descent-override:36.93%;line-gap-override:0.0%;size-adjust:83.94%}.instrument_serif_23b5b5cb-module__qHqRta__className{font-family:Instrument Serif,Instrument Serif Fallback;font-weight:400}.instrument_serif_23b5b5cb-module__qHqRta__variable{--font-instrument-serif:"Instrument Serif","Instrument Serif Fallback"}
:root{--bg:#0a0a0f;--bg-pure:#0f0f17;--bg-subtle:#12121c;--bg-muted:#1a1a2e;--bg-elevated:#16162a;--fg:#e8e8ed;--fg-muted:#9a9ab0;--fg-subtle:#5a5a72;--border:#ffffff14;--border-hover:#ffffff26;--accent:#10b981;--accent-hover:#34d399;--accent-light:#10b9811a;--accent-muted:#10b98133;--glow-sm:0 0 10px #10b98126;--glow-md:0 0 20px #10b98133,0 0 40px #10b9811a;--glow-lg:0 0 30px #10b98140,0 0 60px #10b98126,0 0 100px #10b9810d;--success:#10b981;--success-light:#10b9811a;--warning:#f59e0b;--warning-light:#f59e0b1a;--error:#ef4444;--error-light:#ef44441a;--shadow-xs:0 1px 2px #0000004d;--shadow-sm:0 2px 4px #0003,0 1px 2px #0000004d;--shadow-md:0 4px 12px #0000004d,0 2px 4px #0003;--shadow-lg:0 12px 32px #0006,0 4px 8px #0000004d;--container-max:1100px;--container-narrow:680px;--surface-max:1200px;--content-px:24px;--section-gap:6px;--radius:12px}@media (min-width:768px){:root{--content-px:40px;--section-gap:8px}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:var(--bg);color:var(--fg);font-family:var(--font-plus-jakarta),system-ui,-apple-system,sans-serif;min-height:100vh;font-size:16px;line-height:1.6}body:after{content:"";pointer-events:none;z-index:100;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;position:fixed;inset:0}img,picture,video,svg{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit;background:0 0;border:none}ul,ol{list-style:none}::selection{color:#fff;background-color:#10b9814d}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;font-weight:600;line-height:1.2}.font-serif{font-family:var(--font-instrument-serif),Georgia,serif;font-weight:400}.text-gradient{background:linear-gradient(135deg,#34d399 0%,#10b981 50%,#6ee7b7 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.page-wrapper{background-color:var(--bg);background-image:radial-gradient(at top,#10b9810f 0%,#0000 50%),radial-gradient(at 100% 0,#3b82f60a 0%,#0000 50%),radial-gradient(at 0 100%,#8b5cf60a 0%,#0000 50%);flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1}.container{width:100%;max-width:var(--container-max);padding-left:var(--content-px);padding-right:var(--content-px);margin-left:auto;margin-right:auto}.container-narrow{width:100%;max-width:var(--container-narrow);padding-left:var(--content-px);padding-right:var(--content-px);margin-left:auto;margin-right:auto}.page-surface{width:100%;max-width:var(--surface-max);background-color:#0000;flex:1;margin-left:auto;margin-right:auto}.header{z-index:50;background-color:#0000;border-bottom:1px solid #0000;transition:all .4s;position:sticky;top:0}.header.scrolled{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom-color:var(--border);box-shadow:var(--shadow-md);background-color:#0a0a0fcc}.header-inner{justify-content:space-between;align-items:center;height:64px;display:flex}.header-logo{align-items:center;gap:10px;transition:opacity .2s;display:flex}.header-logo:hover{opacity:.7}.header-logo-icon{background-color:var(--accent);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:600;display:flex}.header-logo-text{font-family:var(--font-instrument-serif),Georgia,serif;color:#fff;font-size:18px}.header-nav{align-items:center;gap:4px;display:none}@media (min-width:768px){.header-nav{display:flex}}.header-nav-link{color:var(--fg-muted);border-radius:20px;padding:8px 14px;font-size:14px;font-weight:500;transition:all .2s;position:relative}.header-nav-link:hover{color:#fff;background-color:#ffffff0f}.header-nav-link.active{color:#fff;background-color:#ffffff1a}.header-menu-btn{color:#ffffffb3;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.header-menu-btn:hover{color:#fff;background-color:#ffffff1a}@media (min-width:768px){.header-menu-btn{display:none}}.mobile-menu-overlay{z-index:40;opacity:0;pointer-events:none;background-color:#00000080;transition:opacity .3s;position:fixed;inset:0}.mobile-menu-overlay.open{opacity:1;pointer-events:auto}.mobile-menu-panel{z-index:41;background-color:var(--bg-pure);border-left:1px solid var(--border);width:280px;height:100%;box-shadow:var(--shadow-lg);transition:transform .3s;position:fixed;top:0;right:0;transform:translate(100%)}.mobile-menu-panel.open{transform:translate(0)}.mobile-menu-content{padding:80px 20px 32px}.mobile-menu-nav{flex-direction:column;gap:4px;display:flex}.mobile-menu-link{color:var(--fg-muted);border-radius:8px;padding:12px 16px;font-size:16px;font-weight:500;display:block}.mobile-menu-link:hover{background-color:var(--bg-muted);color:var(--fg)}.mobile-menu-link.active{background-color:var(--accent-light);color:var(--accent)}.footer{background-color:var(--bg-pure);border-top:1px solid var(--border);color:var(--fg);margin-top:var(--section-gap)}.footer-inner{padding:60px 0}.footer-grid{grid-template-columns:1fr;gap:40px;display:grid}@media (min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1fr;gap:60px}}.footer-brand-logo{align-items:center;gap:10px;margin-bottom:16px;display:flex}.footer-brand-icon{background-color:var(--accent);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:600;display:flex}.footer-brand-text{font-family:var(--font-instrument-serif),Georgia,serif;color:var(--fg);font-size:18px}.footer-brand p{color:var(--fg-muted);max-width:280px;font-size:15px;line-height:1.6}.footer-social{gap:8px;margin-top:20px;display:flex}.footer-social-link{width:36px;height:36px;color:var(--fg-subtle);border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.footer-social-link:hover{color:var(--fg);background-color:#ffffff0f}.footer-heading{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-subtle);margin-bottom:16px;font-size:13px;font-weight:600}.footer-links{flex-direction:column;gap:10px;display:flex}.footer-link{color:var(--fg-muted);font-size:15px;transition:color .2s}.footer-link:hover{color:var(--accent)}.footer-bottom{border-top:1px solid var(--border);flex-direction:column;gap:12px;margin-top:48px;padding-top:24px;display:flex}@media (min-width:640px){.footer-bottom{flex-direction:row;justify-content:space-between;align-items:center}}.footer-bottom p{color:var(--fg-subtle);font-size:14px}.hero{padding:32px 0 40px}@media (min-width:768px){.hero{padding:40px 0 48px}}.hero-inner{color:#fff;border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-lg);background:#0f0f1799 linear-gradient(135deg,#10b98114 0%,#0f0f17e6 40%,#3b82f60f 100%);border-radius:16px;padding:32px;position:relative;overflow:hidden}@media (min-width:768px){.hero-inner{border-radius:20px;padding:48px}}.hero-bg{pointer-events:none;background:radial-gradient(at 100% 100%,#10b9811f 0%,#0000 55%),radial-gradient(at 0 0,#3b82f614 0%,#0000 55%);position:absolute;inset:0}.hero-content{max-width:600px;animation:.8s ease-out both hero-entrance;position:relative}.hero-badge{background-color:#10b9811a;border:1px solid #10b98133;border-radius:20px;align-items:center;gap:8px;margin-bottom:24px;padding:6px 14px;display:inline-flex}.hero-badge-dot{width:8px;height:8px;position:relative}.hero-badge-dot:before{content:"";background-color:var(--accent);border-radius:50%;animation:1.5s ease-in-out infinite ping;position:absolute;inset:0}.hero-badge-dot:after{content:"";background-color:var(--accent);border-radius:50%;position:absolute;inset:0}.hero-badge-text{color:var(--accent-hover);font-size:13px;font-weight:500}.hero-title{font-family:var(--font-instrument-serif),Georgia,serif;letter-spacing:-.02em;color:#fff;margin-bottom:20px;font-size:44px;font-weight:400;line-height:1.15}@media (min-width:768px){.hero-title{font-size:60px}}.hero-location{color:#ffffff80;align-items:center;gap:6px;margin-bottom:16px;font-size:14px;display:inline-flex}.hero-description{color:#fff9;max-width:480px;margin-bottom:24px;font-size:17px;line-height:1.7}.hero-tech{flex-wrap:wrap;gap:8px;margin-bottom:32px;display:flex}.hero-tech-chip{color:#ffffffb3;background-color:#ffffff0f;border:1px solid #ffffff1a;border-radius:20px;padding:4px 12px;font-size:13px;font-weight:500;transition:all .2s}.hero-tech-chip:hover{color:var(--accent);background-color:#10b98114;border-color:#10b98166}.hero-cta{flex-wrap:wrap;gap:12px;display:flex}.section{padding:var(--section-gap)0}.section-inner{background-color:var(--bg-pure);border:1px solid var(--border);border-radius:var(--radius);padding:32px}@media (min-width:768px){.section-inner{padding:40px}}.section-subtle{background-color:var(--bg-subtle)}.section-muted{background-color:var(--bg-muted)}.section-header{flex-direction:column;gap:16px;margin-bottom:40px;display:flex}@media (min-width:768px){.section-header{flex-direction:row;justify-content:space-between;align-items:flex-end}}.section-label{color:var(--accent);align-items:center;gap:8px;margin-bottom:6px;font-size:13px;font-weight:600;display:inline-flex}.section-label-line{background-color:var(--accent);border-radius:2px;width:24px;height:2px}.section-title{color:var(--fg);font-size:28px;font-weight:600}@media (min-width:768px){.section-title{font-size:36px}}.section-link{color:var(--fg-muted);align-items:center;gap:6px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex;position:relative}.section-link:after{content:"";background-color:var(--accent);width:0;height:1px;transition:width .3s;position:absolute;bottom:-2px;left:0}.section-link:hover{color:var(--accent);gap:10px}.section-link:hover:after{width:100%}.cards-grid{grid-template-columns:1fr;gap:20px;display:grid}@media (min-width:640px){.cards-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.cards-grid{grid-template-columns:repeat(3,1fr)}}.project-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius);border:1px solid var(--border);background-color:#0f0f1799;flex-direction:column;height:100%;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;overflow:hidden}.project-card:hover{box-shadow:var(--glow-sm),var(--shadow-lg);border-color:#10b9814d;transform:translateY(-4px)}.project-card-image{aspect-ratio:16/9;background-color:var(--bg-muted);position:relative;overflow:hidden}.project-card-image:after{content:"";pointer-events:none;background:linear-gradient(#0000 50%,#0a0a0f66 100%);position:absolute;inset:0}.project-card-image img{object-fit:cover;width:100%;height:100%;transition:transform .4s cubic-bezier(.16,1,.3,1)}.project-card:hover .project-card-image img{transform:scale(1.05)}.card-image-placeholder{width:100%;height:100%;color:var(--fg-subtle);background:linear-gradient(135deg,#10b98114 0%,#0a0a0f66 100%);justify-content:center;align-items:center;transition:color .3s;display:flex}.project-card:hover .card-image-placeholder,.blog-card:hover .card-image-placeholder{color:var(--accent)}.project-card-content{flex-direction:column;flex:1;padding:20px;display:flex}.project-card-title{color:var(--fg);align-items:center;gap:6px;margin-bottom:6px;font-size:16px;font-weight:600;transition:color .2s;display:flex}.project-card:hover .project-card-title{color:var(--accent)}.project-card-title svg{opacity:0;color:var(--accent);flex-shrink:0;transition:all .3s;transform:translate(-4px)}.project-card:hover .project-card-title svg{opacity:1;transform:translate(0)}.project-card-description{color:var(--fg-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;font-size:14px;line-height:1.6;display:-webkit-box;overflow:hidden}.project-card-tags{border-top:1px solid var(--border);flex-wrap:wrap;gap:6px;margin-top:16px;padding-top:16px;display:flex}.project-card-tag{color:var(--accent);background-color:#10b98114;border:1px solid #10b98126;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:500}.blog-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius);border:1px solid var(--border);background-color:#0f0f1799;flex-direction:column;height:100%;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;overflow:hidden}.blog-card:hover{box-shadow:var(--glow-sm),var(--shadow-lg);border-color:#10b9814d;transform:translateY(-4px)}.blog-card-image{aspect-ratio:16/9;background-color:var(--bg-muted);position:relative;overflow:hidden}.blog-card-image img{object-fit:cover;width:100%;height:100%;transition:transform .4s cubic-bezier(.16,1,.3,1)}.blog-card:hover .blog-card-image img{transform:scale(1.05)}.blog-card-category{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);color:var(--fg);background-color:#0f0f17b3;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600;position:absolute;top:12px;left:12px}.blog-card-content{flex-direction:column;flex:1;padding:20px;display:flex}.blog-card-meta{color:var(--fg-subtle);align-items:center;gap:8px;margin-bottom:10px;font-size:12px;display:flex}.blog-card-meta-dot{background-color:var(--fg-subtle);border-radius:50%;width:3px;height:3px}.blog-card-title{color:var(--fg);margin-bottom:8px;font-size:17px;font-weight:600;line-height:1.3;transition:color .2s}.blog-card:hover .blog-card-title{color:var(--accent)}.blog-card-excerpt{color:var(--fg-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;font-size:14px;line-height:1.6;display:-webkit-box;overflow:hidden}.blog-card-link{border-top:1px solid var(--border);color:var(--accent);align-items:center;gap:6px;margin-top:16px;padding-top:16px;font-size:13px;font-weight:500;transition:gap .2s;display:inline-flex}.blog-card:hover .blog-card-link{gap:10px}.cta-section{padding:var(--section-gap)0;background-color:var(--accent);color:#fff;text-align:center}.cta-content{max-width:500px;margin:0 auto}.cta-title{color:#fff;margin-bottom:12px;font-size:28px;font-weight:600}@media (min-width:768px){.cta-title{font-size:36px}}.cta-description{color:#ffffffd9;max-width:400px;margin:0 auto 28px;font-size:16px;line-height:1.6}.btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background-color:var(--accent);color:#fff;box-shadow:var(--glow-sm)}.btn-primary:hover{background-color:var(--accent-hover);box-shadow:var(--glow-md)}.btn-secondary{color:var(--fg);border:1px solid var(--border);background-color:#ffffff0f}.btn-secondary:hover{border-color:var(--border-hover);background-color:#ffffff1a}.btn-light{color:var(--fg);background-color:#ffffff1a}.btn-light:hover{background-color:#ffffff26}.btn-lg{padding:12px 24px;font-size:15px}.page-header{padding:48px 0 40px}@media (min-width:768px){.page-header{padding:64px 0 48px}}.page-header-label{color:var(--accent);align-items:center;gap:8px;margin-bottom:12px;font-size:13px;font-weight:600;display:inline-flex}.page-header-title{font-family:var(--font-instrument-serif),Georgia,serif;color:var(--fg);margin-bottom:12px;font-size:36px;font-weight:400}@media (min-width:768px){.page-header-title{font-size:48px}}.page-header-description{color:var(--fg-muted);max-width:560px;font-size:17px;line-height:1.7}.article-page{padding:40px 0 var(--section-gap)}.back-link{color:var(--fg-subtle);align-items:center;gap:6px;margin-bottom:32px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.back-link:hover{color:var(--accent)}.back-link:hover svg{transform:translate(-3px)}.back-link svg{transition:transform .2s}.article-header{margin-bottom:40px}.article-category{background-color:var(--accent-light);color:var(--accent);border-radius:6px;margin-bottom:12px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.article-title{font-family:var(--font-instrument-serif),Georgia,serif;color:var(--fg);margin-bottom:12px;font-size:32px;font-weight:400;line-height:1.2}@media (min-width:768px){.article-title{font-size:40px}}.article-description{color:var(--fg-muted);max-width:600px;margin-bottom:20px;font-size:17px;line-height:1.7}.article-meta{color:var(--fg-subtle);flex-wrap:wrap;align-items:center;gap:12px;font-size:14px;display:flex}.article-meta-item{align-items:center;gap:5px;display:flex}.article-tags{flex-wrap:wrap;gap:8px;margin-top:20px;display:flex}.article-tag{background-color:var(--bg-muted);color:var(--fg-muted);border-radius:6px;padding:5px 12px;font-size:13px}.article-tag-accent{background-color:var(--accent-light);color:var(--accent)}.article-featured-image{border-radius:var(--radius);border:1px solid var(--border);margin-bottom:40px;overflow:hidden}.article-featured-image img{width:100%;height:auto}.article-actions{flex-wrap:wrap;gap:10px;margin-top:24px;display:flex}.prose{color:var(--fg-muted);font-size:16px;line-height:1.8}.prose h2,.prose h3,.prose h4{color:var(--fg);margin-top:40px;margin-bottom:16px;font-weight:600}.prose h2{font-size:24px}.prose h3{font-size:20px}.prose p{margin-bottom:20px}.prose a{color:var(--accent);text-underline-offset:2px;text-decoration:underline}.prose strong{color:var(--fg);font-weight:600}.prose code{color:var(--accent);background-color:#10b9811a;border:1px solid #10b98126;border-radius:4px;padding:2px 6px;font-size:.9em}.prose pre{border:1px solid var(--border);color:var(--fg);border-radius:var(--radius);background-color:#0006;margin:24px 0;padding:20px;overflow-x:auto}.prose pre code{color:inherit;background:0 0;border:none;padding:0}.prose blockquote{border-left:3px solid var(--accent);border-radius:0 var(--radius)var(--radius)0;color:var(--fg);background-color:#10b9810d;margin:24px 0;padding:16px 20px;font-style:italic}.prose ul,.prose ol{margin:20px 0;padding-left:24px}.prose li{margin:6px 0}.prose hr{background-color:var(--border);border:none;height:1px;margin:40px 0}.not-found-page{background-color:var(--bg);background-image:radial-gradient(#10b98114 0%,#0000 60%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.not-found-content{text-align:center;max-width:400px}.not-found-visual{margin-bottom:24px;position:relative}.not-found-number{font-family:var(--font-instrument-serif),Georgia,serif;color:var(--bg-muted);text-shadow:0 0 40px #10b9811a;font-size:120px;font-weight:400;line-height:1}@media (min-width:768px){.not-found-number{font-size:160px}}.not-found-icon{background-color:var(--accent-light);border-radius:var(--radius);width:72px;height:72px;box-shadow:var(--glow-md);color:var(--accent);border:1px solid #10b98133;justify-content:center;align-items:center;animation:3s ease-in-out infinite float;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.not-found-title{color:var(--fg);margin-bottom:8px;font-size:28px;font-weight:600}.not-found-description{color:var(--fg-muted);margin-bottom:32px;font-size:16px;line-height:1.6}.not-found-actions{flex-direction:column;justify-content:center;gap:10px;display:flex}@media (min-width:480px){.not-found-actions{flex-direction:row}}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state-icon{background-color:var(--bg-muted);border-radius:var(--radius);width:64px;height:64px;color:var(--fg-subtle);justify-content:center;align-items:center;margin-bottom:20px;display:flex}.empty-state-title{color:var(--fg);margin-bottom:6px;font-size:20px;font-weight:600}.empty-state-description{color:var(--fg-muted);max-width:280px;font-size:15px}.about-section{margin-bottom:48px}.about-section-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.about-section-icon{background-color:var(--accent-light);width:36px;height:36px;color:var(--accent);border:1px solid #10b98126;border-radius:8px;justify-content:center;align-items:center;display:flex}.about-section-title{color:var(--fg);font-size:22px;font-weight:600}.about-section p{color:var(--fg-muted);font-size:16px;line-height:1.7}.skills-grid{grid-template-columns:1fr;gap:12px;display:grid}@media (min-width:640px){.skills-grid{grid-template-columns:repeat(2,1fr)}}.skill-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);background-color:#0f0f1799;padding:20px;transition:all .4s cubic-bezier(.16,1,.3,1)}.skill-card:hover{box-shadow:var(--glow-sm);border-color:#10b9814d}.skill-card-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.skill-card-icon{color:var(--accent)}.skill-card-title{color:var(--fg);font-size:15px;font-weight:600}.skill-card-items{flex-wrap:wrap;gap:6px;display:flex}.skill-card-item{color:var(--accent);background-color:#10b98114;border:1px solid #10b98126;border-radius:6px;padding:4px 10px;font-size:13px}.social-grid{grid-template-columns:1fr;gap:12px;display:grid}@media (min-width:640px){.social-grid{grid-template-columns:repeat(3,1fr)}}.social-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);text-align:center;background-color:#0f0f1799;flex-direction:column;align-items:center;padding:24px 16px;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex}.social-card:hover{box-shadow:var(--glow-sm);border-color:#10b9814d}.social-card-icon{color:var(--fg-subtle);margin-bottom:10px;transition:color .2s}.social-card:hover .social-card-icon{color:var(--accent)}.social-card-label{color:var(--fg);margin-bottom:2px;font-size:15px;font-weight:500}.social-card-value{color:var(--fg-subtle);font-size:13px}@keyframes ping{0%{opacity:1;transform:scale(1)}75%,to{opacity:0;transform:scale(2)}}@keyframes float{0%,to{transform:translate(-50%,-50%)translateY(0)}50%{transform:translate(-50%,-50%)translateY(-6px)}}@keyframes hero-entrance{0%{opacity:0;filter:blur(4px);transform:translateY(20px)}to{opacity:1;filter:blur();transform:translateY(0)}}@keyframes pulse-glow{0%,to{box-shadow:var(--glow-sm)}50%{box-shadow:var(--glow-md)}}.scroll-reveal{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(24px)}.scroll-reveal.revealed{opacity:1;transform:translateY(0)}.scroll-reveal.stagger-children>*{opacity:0;transition:opacity .4s,transform .4s;transform:translateY(16px)}.scroll-reveal.stagger-children.revealed>:first-child{opacity:1;transition-delay:0s;transform:translateY(0)}.scroll-reveal.stagger-children.revealed>:nth-child(2){opacity:1;transition-delay:80ms;transform:translateY(0)}.scroll-reveal.stagger-children.revealed>:nth-child(3){opacity:1;transition-delay:.16s;transform:translateY(0)}.scroll-reveal.stagger-children.revealed>:nth-child(4){opacity:1;transition-delay:.24s;transform:translateY(0)}.scroll-reveal.stagger-children.revealed>:nth-child(5){opacity:1;transition-delay:.32s;transform:translateY(0)}.scroll-reveal.stagger-children.revealed>:nth-child(6){opacity:1;transition-delay:.4s;transform:translateY(0)}.admin-layout{background-color:var(--bg);min-height:100vh;display:flex}.admin-sidebar-wrapper{display:none}@media (min-width:1024px){.admin-sidebar-wrapper{display:block}}.admin-main{flex-direction:column;flex:1;min-width:0;display:flex}.admin-content{flex:1;padding:16px}@media (min-width:640px){.admin-content{padding:24px}}@media (min-width:1024px){.admin-content{padding:32px}}.admin-content-inner{width:100%;max-width:960px;margin:0 auto}.admin-sidebar{background-color:var(--bg-pure);border-right:1px solid var(--border);flex-direction:column;width:240px;min-height:100vh;display:flex}.admin-sidebar-brand{border-bottom:1px solid var(--border);align-items:center;height:64px;padding:0 20px;display:flex}.admin-sidebar-brand a{color:var(--fg);font-size:16px;font-weight:600;transition:color .15s}.admin-sidebar-brand a:hover,.admin-sidebar-brand-dot{color:var(--accent)}.admin-sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:16px 12px;display:flex}.admin-sidebar-link{color:var(--fg-muted);border-radius:8px;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.admin-sidebar-link:hover{background-color:var(--bg-muted);color:var(--fg)}.admin-sidebar-link.active{background-color:var(--accent-light);color:var(--accent)}.admin-sidebar-link-icon{color:var(--fg-subtle);flex-shrink:0;transition:color .15s}.admin-sidebar-link.active .admin-sidebar-link-icon{color:var(--accent)}.admin-sidebar-footer{border-top:1px solid var(--border);padding:16px}.admin-sidebar-back{color:var(--fg-subtle);border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:14px;transition:all .15s;display:flex}.admin-sidebar-back:hover{color:var(--fg);background-color:var(--bg-muted)}.admin-header{background-color:var(--bg-pure);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex}.admin-header-right{align-items:center;gap:12px;display:flex}.admin-header-label{color:var(--fg-subtle);font-size:12px;display:none}@media (min-width:640px){.admin-header-label{display:block}}.admin-header-divider{background-color:var(--border);width:1px;height:20px;display:none}@media (min-width:640px){.admin-header-divider{display:block}}.admin-page-header{margin-bottom:32px}.admin-page-header h1{color:var(--fg);margin-bottom:8px;font-size:30px;font-weight:700}.admin-page-header p{color:var(--fg-muted)}.admin-page-header-row{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.admin-stats-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:32px;display:grid}@media (min-width:768px){.admin-stats-grid{grid-template-columns:repeat(4,1fr);gap:24px}}.admin-stat-value{color:var(--fg);font-size:24px;font-weight:700}.admin-stat-label{color:var(--fg-muted);font-size:14px}.admin-stat-sub{color:var(--fg-subtle);margin-top:4px;font-size:12px}.admin-actions-grid{grid-template-columns:1fr;gap:24px;display:grid}@media (min-width:768px){.admin-actions-grid{grid-template-columns:repeat(2,1fr)}}.admin-actions-title{color:var(--fg);font-size:20px;font-weight:700}.admin-actions-text{color:var(--fg-muted);margin-bottom:16px}.admin-actions-buttons{gap:8px;display:flex}.admin-list{flex-direction:column;gap:16px;display:flex}.admin-list-item{justify-content:space-between;align-items:center;display:flex}.admin-list-item-info{flex:1}.admin-list-item-title-row{align-items:center;gap:12px;margin-bottom:8px;display:flex}.admin-list-item-title{color:var(--fg);font-size:18px;font-weight:600}.admin-list-item-badges{gap:8px;display:flex}.admin-list-item-description{color:var(--fg-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:14px;display:-webkit-box;overflow:hidden}.admin-list-item-meta{color:var(--fg-subtle);margin-top:8px;font-size:12px}.admin-list-item-actions{flex-shrink:0;align-items:center;gap:8px;margin-left:16px;display:flex}.delete-confirm{align-items:center;gap:8px;display:flex}.delete-confirm-text{color:var(--error);white-space:nowrap;font-size:13px}.admin-empty{text-align:center;padding:48px 24px}.admin-empty p{color:var(--fg-muted);margin-bottom:16px}.card{background-color:var(--bg-elevated);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}.card-header{border-bottom:1px solid var(--border);padding:20px 24px}.card-content{padding:24px}.card-footer{border-top:1px solid var(--border);background-color:#0f0f1780;padding:16px 24px}.btn-outline{color:var(--fg-muted);border:1px solid var(--border);background-color:#0000}.btn-outline:hover{color:var(--fg);border-color:var(--border-hover);background-color:#ffffff0f}.btn-ghost{color:var(--fg-muted);background-color:#0000}.btn-ghost:hover{color:var(--fg);background-color:#ffffff0f}.btn-danger{background-color:var(--error);color:#fff}.btn-danger:hover{background-color:#dc2626}.btn-sm{height:36px;padding:6px 14px;font-size:13px}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-full{width:100%}.badge{border-radius:8px;align-items:center;padding:2px 8px;font-size:12px;font-weight:500;display:inline-flex}.badge-success{background-color:var(--success-light);color:var(--success)}.badge-draft{background-color:var(--bg-muted);color:var(--fg-subtle)}.badge-accent{background-color:var(--accent-light);color:var(--accent)}.form-group{width:100%}.form-label{color:var(--fg);margin-bottom:10px;font-size:14px;font-weight:500;display:block}.form-label-required{color:var(--error);margin-left:4px}.form-input{border-radius:var(--radius);background-color:var(--bg-elevated);border:1px solid var(--border);width:100%;height:44px;color:var(--fg);outline:none;padding:0 16px;font-family:inherit;font-size:14px;transition:all .2s}.form-input::placeholder{color:var(--fg-subtle)}.form-input:hover{border-color:var(--border-hover)}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #10b98126,var(--glow-sm)}.form-input:disabled{background-color:var(--bg-muted);cursor:not-allowed;opacity:.6}.form-input.error{border-color:var(--error)}.form-input.error:focus{border-color:var(--error);box-shadow:0 0 0 2px #ef444426}.form-textarea{border-radius:var(--radius);background-color:var(--bg-elevated);border:1px solid var(--border);width:100%;color:var(--fg);resize:vertical;outline:none;min-height:128px;padding:12px 16px;font-family:inherit;font-size:14px;line-height:1.6;transition:all .2s}.form-textarea::placeholder{color:var(--fg-subtle)}.form-textarea:hover{border-color:var(--border-hover)}.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px #10b98126,var(--glow-sm)}.form-textarea:disabled{background-color:var(--bg-muted);cursor:not-allowed;opacity:.6}.form-textarea.error{border-color:var(--error)}.form-textarea.error:focus{border-color:var(--error);box-shadow:0 0 0 2px #ef444426}.form-select-wrapper{position:relative}.form-select{border-radius:var(--radius);appearance:none;background-color:var(--bg-elevated);border:1px solid var(--border);width:100%;height:44px;color:var(--fg);cursor:pointer;outline:none;padding:0 40px 0 16px;font-family:inherit;font-size:14px;transition:all .2s}.form-select:hover{border-color:var(--border-hover)}.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #10b98126,var(--glow-sm)}.form-select:disabled{background-color:var(--bg-muted);cursor:not-allowed;opacity:.6}.form-select.error{border-color:var(--error)}.form-select-icon{pointer-events:none;color:var(--fg-subtle);position:absolute;top:50%;right:14px;transform:translateY(-50%)}.form-checkbox-label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:2px 0;display:inline-flex}.form-checkbox-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.form-checkbox{border:2px solid var(--border);appearance:none;background-color:var(--bg-elevated);cursor:pointer;border-radius:6px;width:20px;height:20px;transition:all .2s}.form-checkbox:hover{border-color:#10b98180}.form-checkbox:checked{background-color:var(--accent);border-color:var(--accent)}.form-checkbox:focus-visible{box-shadow:0 0 0 2px #10b98133}.form-checkbox:disabled{opacity:.5;cursor:not-allowed}.form-checkbox-icon{pointer-events:none;color:#fff;opacity:0;transition:all .2s;position:absolute;transform:scale(.75)}.form-checkbox:checked+.form-checkbox-icon{opacity:1;transform:scale(1)}.form-checkbox-text{color:var(--fg);font-size:14px}.form-error{color:var(--error);align-items:center;gap:6px;margin-top:8px;font-size:14px;display:flex}.form-error-icon{flex-shrink:0}.form-hint{color:var(--fg-subtle);margin-top:8px;font-size:14px}.tag-input-container{border:1px solid var(--border);border-radius:var(--radius);background-color:var(--bg-elevated);flex-wrap:wrap;align-items:center;gap:8px;padding:10px;transition:all .2s;display:flex}.tag-input-container:hover{border-color:var(--border-hover)}.tag-input-container.focused{border-color:var(--accent);box-shadow:0 0 0 2px #10b98126,var(--glow-sm)}.tag-input-container.empty{padding-top:0;padding-bottom:0}.tag-input-tag{background-color:var(--accent-light);color:var(--accent);border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:14px;font-weight:500;display:inline-flex}.tag-input-tag-remove{color:#10b98199;cursor:pointer;transition:color .15s;display:flex}.tag-input-tag-remove:hover{color:var(--accent)}.tag-input-field{min-width:140px;height:32px;color:var(--fg);background:0 0;border:none;outline:none;flex:1;padding:0 8px;font-family:inherit;font-size:14px}.tag-input-field::placeholder{color:var(--fg-subtle)}.form-stack{flex-direction:column;gap:32px;display:flex}.form-row{grid-template-columns:1fr;gap:24px;display:grid}@media (min-width:768px){.form-row{grid-template-columns:repeat(2,1fr)}}.form-checkboxes{gap:32px;padding-top:8px;display:flex}.form-actions{border-top:1px solid var(--border);gap:16px;padding-top:24px;display:flex}.form-alert-error{background-color:var(--error-light);border-radius:var(--radius);border:1px solid #ef444433;padding:16px}.form-alert-error p{color:var(--error);font-size:14px}.preview-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.preview-toggle{color:var(--accent);cursor:pointer;align-items:center;gap:6px;font-size:14px;font-weight:500;transition:color .15s;display:inline-flex}.preview-toggle:hover{color:var(--accent-hover)}.preview-container{border:1px solid var(--border);border-radius:var(--radius);background-color:var(--bg-elevated);min-height:320px;padding:24px}.login-page{background:url(https://miro.medium.com/v2/0*rCuLTvg2I9RVzKcq) 50%/cover no-repeat fixed;justify-content:center;align-items:center;min-height:100vh;padding:48px 20px;display:flex;position:relative}.login-page:before{content:"";-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0a0a0fbf;position:absolute;inset:0}.login-wrapper{z-index:1;width:100%;max-width:384px;position:relative}.login-header{text-align:center;margin-bottom:32px}.login-title{color:#fff;letter-spacing:-.02em;font-size:30px;font-weight:600}.login-subtitle{color:#ffffff80;margin-top:8px;font-size:14px}.login-card{border-radius:var(--radius);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--glow-sm);background-color:#0f0f17b3;border:1px solid #10b98133;padding:32px}.login-form{flex-direction:column;gap:20px;display:flex}.login-footer{text-align:center;color:#ffffff4d;margin-top:24px;font-size:12px}.login-card .form-label{color:#ffffffd9}.login-card .form-input{color:#fff;background-color:#ffffff0f;border-color:#ffffff1f}.login-card .form-input::placeholder{color:#ffffff4d}.login-card .form-input:hover{border-color:#fff3}.login-card .form-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #10b98133,var(--glow-sm)}.glass{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);background-color:#0f0f1799}.glass-subtle{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#0f0f174d}.accent-glow{box-shadow:var(--glow-md)}.text-glow{text-shadow:0 0 20px #10b98180}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-fade-in{animation:.3s fadeIn}.image-upload{width:100%}.image-upload-tabs{background-color:var(--bg-muted);border-radius:8px;gap:4px;width:fit-content;margin-bottom:12px;padding:4px;display:flex}.image-upload-tab{color:var(--fg-muted);border-radius:6px;padding:6px 16px;font-size:13px;font-weight:500;transition:all .15s}.image-upload-tab:hover{color:var(--fg)}.image-upload-tab.active{background-color:var(--bg-elevated);color:var(--fg);box-shadow:var(--shadow-xs)}.image-upload-dropzone{border:2px dashed var(--border);border-radius:var(--radius);background-color:var(--bg-elevated);color:var(--fg-subtle);cursor:pointer;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:32px 16px;font-size:14px;transition:all .2s;display:flex}.image-upload-dropzone:hover{border-color:var(--border-hover);background-color:var(--bg-muted);color:var(--fg-muted)}.image-upload-dropzone.drag-over{border-color:var(--accent);background-color:var(--accent-light);color:var(--accent)}.image-upload-hint{color:var(--fg-subtle);font-size:12px}.image-upload-loading{color:var(--fg-muted);align-items:center;gap:8px;display:flex}.image-upload-spinner{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.image-upload-preview{border-radius:var(--radius);border:1px solid var(--border);background-color:var(--bg-muted);position:relative;overflow:hidden}.image-upload-preview img{object-fit:cover;width:100%;max-height:240px;display:block}.image-upload-remove{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;background-color:#0009;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:background-color .15s;display:flex;position:absolute;top:8px;right:8px}.image-upload-remove:hover{background-color:var(--error)}.image-upload-error{color:var(--error);margin-top:8px;font-size:13px}
