@import "https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600&display=swap";:root{--bg-primary:#071019;--bg-secondary:#0d1822;--bg-card:#0b151fc7;--bg-card-hover:#0e1925f5;--text-primary:#f6efe6;--text-secondary:#c9d3dd;--text-muted:#98a7b6;--accent:#ff8a3d;--accent-hover:#79e4d4;--accent-glow:#ff8a3d24;--accent-glow-strong:rgba(#ff8a3d, .18);--border:#ffffff14;--border-hover:#ffffff29;--radius:.25vh;--transition:.25s ease}body{font-family:Poppins,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{color:#f6efe6;background:radial-gradient(circle at top,#79e4d414,#0000 28%),linear-gradient(#08111b 0%,#050b12 100%);min-height:100vh;overflow-x:hidden}body.modal-open{overflow:hidden}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{background:0 0;border:0}img,video,iframe{width:100%;display:block}ul{list-style:none}.container{width:min(1220px,100% - 48px);margin:0 auto}.bg-aurora,.bg-grid{pointer-events:none;z-index:-2;position:fixed;inset:0}.bg-aurora{filter:blur(120px);opacity:.28}.aurora-one{background:#ff8a3d;width:34rem;height:34rem;inset:-10% auto auto -8%}.aurora-two{background:#79e4d4;width:30rem;height:30rem;inset:auto -10% 8% auto}.bg-grid{z-index:-3;background-image:linear-gradient(#ffffff05 1px,#0000 1px),linear-gradient(90deg,#ffffff05 1px,#0000 1px);background-size:44px 44px;-webkit-mask-image:linear-gradient(#000000bf,#0000 80%);mask-image:linear-gradient(#000000bf,#0000 80%)}.cursor-dot,.cursor-ring{pointer-events:none;z-index:60;opacity:0;border-radius:999px;position:fixed;top:0;left:0;transform:translate(-120px,-120px)}.cursor-dot{background:#ff8a3d;width:10px;height:10px;margin:-5px 0 0 -5px}.cursor-ring{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ff8a3d14;border:1px solid #ff8a3d80;width:36px;height:36px;margin:-18px 0 0 -18px}.cursor-dot.is-active,.cursor-ring.is-active{opacity:1}.cursor-ring.is-hover{background:#79e4d41f;border-color:#79e4d4a6;width:54px;height:54px;margin:-27px 0 0 -27px}.section{padding:110px 0;position:relative}.hero{padding-top:72px}.hero-layout,.about-layout,.contact-layout,.modal-body{gap:28px;display:grid}.hero-layout{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);align-items:center}.hero-copy h1,.section-heading h2,.modal-main h3{letter-spacing:-.03em}.eyebrow,.section-kicker,.panel-label,.contact-label,.stat-label,.block-head p,.form-feedback,.modal-side-card span{color:#98a7b6}.eyebrow,.section-kicker{text-transform:uppercase;letter-spacing:.2em;align-items:center;gap:10px;margin-bottom:18px;font-size:.76rem;font-weight:700;display:inline-flex}.eyebrow:before,.section-kicker:before{content:"";background:linear-gradient(90deg,#ff8a3d,#0000);width:42px;height:1px}.hero-copy h1{max-width:11ch;font-size:clamp(3.4rem,8vw,6.6rem);line-height:.95}.hero-copy h1 span{color:#79e4d4;display:block}.hero-roles{align-items:baseline;gap:12px;min-height:48px;margin:28px 0 18px;font-size:1.2rem;display:flex}.role-prefix{color:#98a7b6}.role-text{color:#ff8a3d;opacity:0;transition:opacity .28s,transform .28s;position:relative;transform:translateY(8px)}.role-text:after{content:"";vertical-align:-.14em;background:currentColor;width:1px;height:1.1em;margin-left:6px;animation:1s step-end infinite blink;display:inline-block}.role-text.is-visible{opacity:1;transform:translateY(0)}.hero-description,.section-heading p,.about-copy p,.project-copy,.contact-copy p,.modal-main p{color:#c9d3dd;font-size:1.05rem;line-height:1.8}.hero-description{max-width:58ch}.hero-actions{flex-wrap:wrap;gap:14px;margin-top:34px;display:flex}.hero-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:42px;display:grid}.hero-metrics article,.panel-card,.stat-card,.skill-card,.contact-card,.contact-form,.projects-block,.project-card,.project-card-compact,.modal-side-card,.project-modal-dialog,.state-card{background:#13315c4d;border:.5px solid #f6efe680;box-shadow:0 10px 30px #00000038}.hero-metrics article,.panel-card,.stat-card,.skill-card,.contact-card,.project-card,.project-card-compact,.state-card,.modal-side-card{border-radius:.25vh}.hero-metrics article{padding:18px 20px}.hero-metrics strong{margin-bottom:6px;font-size:1.5rem;display:block}.hero-metrics span{color:#98a7b6;font-size:.92rem}.hero-panel{position:relative}.panel-card{padding:24px}.panel-card-large{background:#13315c4d;border-radius:.25vh;margin-bottom:16px}.panel-card p{color:#c9d3dd;line-height:1.7}.panel-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.panel-label{text-transform:uppercase;letter-spacing:.16em;margin-bottom:12px;font-size:.72rem;font-weight:700;display:block}.panel-card strong,.skill-card h3,.block-head h3,.contact-card strong,.footer-brand,.project-card h3,.project-card-compact h3{font-size:1.1rem}.section-heading{max-width:760px;margin-bottom:42px}.section-heading h2{margin-bottom:20px;font-size:clamp(2.5rem,5vw,4rem);line-height:1}.about-layout{grid-template-columns:minmax(0,1fr) minmax(320px,.9fr);align-items:start}.about-copy{gap:22px;display:grid}.about-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.stat-card{padding:26px}.stat-number{margin-bottom:8px;font-size:clamp(1.9rem,5vw,2.8rem);font-weight:700;display:block}.section-tinted:before,.section-contact:before{content:"";pointer-events:none;background:#f6efe604;border-top:1px solid #f6efe608;border-bottom:1px solid #f6efe608;position:absolute;inset:0}.projects-stack{gap:24px;display:grid}.projects-block{padding:28px}.block-head{justify-content:space-between;align-items:end;gap:20px;margin-bottom:22px;display:flex}.projects-grid{gap:18px;display:grid}.projects-grid-featured{grid-template-columns:repeat(2,minmax(0,1fr))}.projects-grid-compact{grid-template-columns:repeat(3,minmax(0,1fr))}.project-card,.project-card-compact{overflow:hidden}.project-card{grid-template-columns:minmax(180px,.85fr) minmax(0,1.15fr);display:grid}.project-media,.project-image,.project-placeholder,.modal-media,.modal-thumb{background:linear-gradient(135deg,#ff8a3d2e,#79e4d424)}.project-media,.project-image,.project-placeholder{min-height:220px}.project-media img,.project-image img,.project-media video,.project-image video{object-fit:cover;width:100%;height:100%;display:block}.project-image{background:linear-gradient(135deg,#ff8a3d2e,#79e4d424);border-radius:.25vh;min-height:220px;position:relative;overflow:hidden}.project-image-overlay{color:#f6efe6;opacity:0;pointer-events:none;background:linear-gradient(#0000,#00000047);justify-content:center;align-items:center;transition:opacity .2s,transform .2s;display:flex;position:absolute;inset:0}.project-card.custom-card:hover .project-image-overlay{opacity:1;pointer-events:auto}.project-image-overlay svg{color:#79e4d4;filter:drop-shadow(0 6px 18px #00000080);width:44px;height:44px}.project-placeholder{color:#f6efe6b8;justify-content:center;align-items:center;padding:30px;font-size:2rem;display:flex}.project-body,.project-card-compact{padding:24px}.project-card-compact{flex-direction:column;gap:18px;min-height:238px;display:flex}.project-tags,.modal-tags{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.project-tags span,.modal-tags span{color:#eef4ed;background:#02020280;border-radius:999px;align-items:center;min-height:32px;padding:0 12px;font-size:.82rem;font-weight:700;display:inline-flex}.project-body p,.project-card-compact p{color:#98a7b6;margin-top:12px;line-height:1.7}.project-actions{flex-wrap:wrap;gap:12px;margin-top:22px;display:flex}.project-link,.project-button{border-radius:.25vh;justify-content:center;align-items:center;min-height:42px;padding:0 16px;font-weight:700;display:inline-flex}.project-link{color:#79e4d4;background:#79e4d424}.project-button{color:#f6efe6;cursor:pointer;border:1px solid #ffffff14}.project-button:hover,.project-link:hover{transform:translateY(-1px)}.repo-meta{color:#98a7b6;flex-wrap:wrap;justify-content:space-between;gap:12px;margin-top:auto;font-size:.9rem;display:flex}.repo-meta span{align-items:center;gap:8px;display:inline-flex}.repo-meta span svg{flex-shrink:0}.state-card{color:#98a7b6;padding:24px}.skills-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;display:grid}.skill-card{padding:26px}.skill-card h3{margin-bottom:18px}.skill-card ul{gap:12px;display:grid}.skill-card li{color:#c9d3dd;border-bottom:1px solid #f6efe60f;padding-bottom:12px}.skill-card li:last-child{border-bottom:0;padding-bottom:0}.contact-layout{grid-template-columns:minmax(0,.95fr) minmax(320px,1.05fr);align-items:start}.contact-copy{gap:22px;display:grid}.contact-cards{gap:14px;display:grid}.contact-card{padding:20px 22px}.contact-card strong{margin-top:8px;display:block}.contact-form{border-radius:32px;gap:16px;padding:28px;display:grid}.contact-form label{gap:8px;display:grid}.contact-form span{color:#98a7b6;font-size:.92rem}.contact-form input,.contact-form textarea{color:#f6efe6;background:#f6efe608;border:1px solid #ffffff14;border-radius:16px;width:100%;padding:16px 18px}.contact-form input:focus,.contact-form textarea:focus{border-color:#ff8a3d61;outline:none;box-shadow:0 0 0 4px #ff8a3d14}.form-feedback{font-size:.92rem}.site-footer{padding:28px 0 40px}.footer-shell{border-top:1px solid #f6efe614;justify-content:space-between;align-items:center;gap:24px;padding:26px 0 0;display:flex}.footer-shell p,.footer-actions a{color:#98a7b6}.footer-actions{align-items:center;gap:14px;display:flex}.project-modal{z-index:80;position:fixed;inset:0}.project-modal[hidden]{display:none}.project-modal-backdrop{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#050a10d1;position:absolute;inset:0}.project-modal-dialog{background:#081018f5;border-radius:28px;width:min(980px,100% - 32px);max-height:calc(100vh - 32px);margin:16px auto;padding:22px;position:relative;overflow:auto}.modal-close{z-index:3;color:#f6efe6;cursor:pointer;border:1px solid #ffffff14;border-radius:999px;width:42px;height:42px;position:absolute;top:20px;right:20px}.modal-media-shell{position:relative}.modal-media{border:1px solid #ffffff14;border-radius:22px;min-height:360px;overflow:hidden}.modal-media img,.modal-media video,.modal-media iframe{object-fit:cover;border:0;min-height:360px}.modal-nav,.modal-counter{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#f6efe6;background:#f6efe6b8;border:1px solid #f6efe61f;border-radius:999px;position:absolute;top:18px}.modal-nav{cursor:pointer;width:48px;height:48px;top:calc(50% - 24px)}.modal-nav-prev{left:18px}.modal-nav-next{right:18px}.modal-counter{padding:10px 14px;font-size:.86rem;right:18px}.modal-thumbs{gap:10px;padding:16px 2px 0;display:flex;overflow-x:auto}.modal-thumb{cursor:pointer;border:2px solid #0000;border-radius:14px;width:88px;min-width:88px;height:60px;overflow:hidden}.modal-thumb.is-active{border-color:#ff8a3d}.modal-thumb img,.modal-thumb video{object-fit:cover;height:100%}.modal-body{grid-template-columns:minmax(0,1.3fr) minmax(240px,.7fr);margin-top:24px}.modal-main p+p{margin-top:18px}.modal-side{gap:16px;display:grid}.modal-side-card{padding:18px}.modal-side-card span{text-transform:uppercase;letter-spacing:.16em;margin-bottom:10px;font-size:.72rem;font-weight:700;display:block}.modal-side-card a{color:#79e4d4;word-break:break-word}.noscript-note{background:#ff8a3d2e;border:1px solid #ff8a3d3d;border-radius:16px;padding:14px 18px;position:fixed;bottom:16px;left:16px;right:16px}.reveal{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(30px)}.reveal.is-visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:80ms}.reveal-delay-2{transition-delay:.16s}.reveal-delay-3{transition-delay:.24s}.reveal-delay-4{transition-delay:.32s}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}@media (width<=1120px){.hero-layout,.about-layout,.contact-layout,.modal-body{grid-template-columns:1fr}.projects-grid-compact,.skills-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=920px){.site-header{padding:12px 0}.site-nav,.header-actions{display:none}.site-header.menu-open .header-shell{grid-template-columns:auto auto;align-items:center;display:grid}.site-header.menu-open .site-nav,.site-header.menu-open .header-actions{grid-column:1/-1;width:100%;display:flex}.site-header.menu-open .site-nav{flex-direction:column;align-items:flex-start;gap:16px;padding-top:10px}.site-header.menu-open .header-actions{flex-wrap:wrap;padding-top:8px}.projects-grid-featured,.projects-grid-compact,.panel-grid,.about-stats,.project-card{grid-template-columns:1fr}}@media (width<=720px){.container{width:min(var(--container), 100% - 32px)}.section{padding:88px 0}.hero-copy h1{font-size:clamp(2.7rem,16vw,4rem)}.hero-roles{flex-direction:column;align-items:flex-start;gap:4px}.hero-metrics,.skills-grid{grid-template-columns:1fr}.projects-block,.contact-form,.project-modal-dialog{padding:20px}.block-head,.footer-shell{flex-direction:column;align-items:flex-start}.modal-nav{top:auto;bottom:18px}.modal-counter{top:18px;bottom:auto}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.cursor-dot,.cursor-ring{display:none}}.site-header{z-index:40;padding:18px 0;position:sticky;top:0}.header-shell{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#071019b8;border:.5px solid #f6efe60f;border-radius:.25vh;justify-content:space-between;align-items:center;gap:24px;padding:16px 22px;transition:border-color .25s,background .25s,box-shadow .25s;display:flex;box-shadow:0 30px 80px #00000057}.brand{letter-spacing:.06em;text-transform:uppercase;align-items:center;gap:10px;font-weight:700;display:inline-flex}img{color:#79e4d4;background:#02020266;border-radius:.25vh;justify-content:center;align-items:center;width:42px;height:42px;display:inline-flex}.brand-text{font-size:.95rem}.site-nav{align-items:center;gap:22px;display:flex}.site-nav a,.ghost-link,.solid-link,.back-to-top{transition:transform .2s,background .2s,color .2s,border-color .2s}.site-nav a{color:#98a7b6;font-size:.95rem;position:relative}.site-nav a:after{content:"";transform-origin:0;background:#eef4ed;border-radius:.25vh;width:100%;height:2px;transition:transform .2s;position:absolute;bottom:-10px;left:0;transform:scaleX(0)}.site-nav a:hover,.site-nav a.is-current{color:#f6efe6}.site-nav a:hover:after,.site-nav a.is-current:after{transform:scaleX(1)}.header-actions{align-items:center;gap:12px;display:flex}.ghost-link,.solid-link,.button,.back-to-top{letter-spacing:.02em;border-radius:.25vh;justify-content:center;align-items:center;min-height:48px;padding:0 20px;font-weight:700;display:inline-flex}.ghost-link,.button-secondary,.back-to-top{color:#f6efe6;background:#f6efe608;border:1px solid #ffffff14}.solid-link,.button-primary{color:#111;background:linear-gradient(135deg,#0b2545,#134084);box-shadow:0 14px 30px #8da9c41a}.ghost-link:hover,.button-secondary:hover,.back-to-top:hover{background:#f6efe60f;border-color:#ffffff29;transform:translateY(-2px)}.solid-link:hover,.button-primary:hover{transform:translateY(-2px);box-shadow:0 20px 40px #8da9c438}.project-detail{min-height:100vh;padding-top:100px}.project-back{color:#98a7b6;align-items:center;gap:8px;margin-bottom:40px;font-size:.88rem;font-weight:500;transition:all .3s;display:inline-flex}.project-back:hover{color:#ff8a3d;transform:translate(-4px)}.project-detail-hero{border:1px solid #ffffff14;border-radius:.25vh;margin-bottom:48px;position:relative;overflow:hidden}.detail-media-main{aspect-ratio:16/9;background:#0b151fc7;position:relative;overflow:hidden}.detail-media-frame{object-fit:cover;border:none;width:100%;height:100%;display:block}.media-nav{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#f6efe6;cursor:pointer;opacity:0;z-index:5;background:#0000008c;border:1px solid #ffffff1a;border-radius:.25vh;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;transition:all .25s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.detail-media-main:hover .media-nav{opacity:1}.media-nav:hover{background:#000c}.media-prev{left:12px}.media-next{right:12px}.media-counter{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#f6efe6;z-index:5;background:#0000008c;border-radius:.25vh;padding:4px 12px;font-size:.78rem;font-weight:600;position:absolute;top:12px;right:12px}.detail-media-thumbs{background:#0b151fc7;gap:6px;padding:8px;display:flex;overflow-x:auto}.detail-media-thumbs::-webkit-scrollbar{height:3px}.detail-media-thumbs::-webkit-scrollbar-thumb{background:#ffffff29;border-radius:10px}.detail-thumb{cursor:pointer;opacity:.5;background:0 0;border:2px solid #0000;border-radius:.25vh;flex-shrink:0;width:64px;height:42px;padding:0;transition:all .2s;overflow:hidden}.detail-thumb.active{opacity:1;border-color:#ff8a3d}.detail-thumb:hover{opacity:.85}.detail-thumb img{object-fit:cover;width:100%;height:100%;display:block}.project-detail-hero-overlay{pointer-events:none;background:linear-gradient(#0000,#050505f2);padding:40px;position:absolute;bottom:0;left:0;right:0}.project-detail-hero-overlay h1{letter-spacing:-1.5px;margin-bottom:12px;font-size:2.5rem;font-weight:800}.project-detail-tags{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.project-detail-tags span{color:#eef4ed;background:#02020280;border-radius:.25vh;padding:5px 16px;font-size:.8rem;font-weight:600}.project-detail-content{grid-template-columns:2fr 1fr;gap:48px;display:grid}.project-detail-body h2{margin-bottom:16px;font-size:1.3rem;font-weight:700}.project-detail-body p{color:#c9d3dd;white-space:pre-wrap;font-size:1rem;line-height:1.9}.project-detail-sidebar{flex-direction:column;gap:16px;display:flex}.project-detail-card{background:#0b151fc7;border:1px solid #ffffff14;border-radius:.25vh;padding:24px}.project-detail-card h3{color:#98a7b6;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;font-size:.75rem;font-weight:600}.project-detail-card .detail-value{color:#f6efe6;font-size:.92rem;font-weight:500}.project-detail-card a{color:#ff8a3d;word-break:break-all;transition:all .18s}.project-detail-card a:hover{text-decoration:underline}.project-not-found{text-align:center;padding:100px 0}.project-not-found h1{color:#ffffff14;letter-spacing:-4px;font-size:6rem;font-weight:800}.project-not-found p{color:#98a7b6;margin:16px 0 32px;font-size:1.1rem}.project-detail-no-image{border-bottom:1px solid #ffffff14;margin-bottom:32px;padding:40px 0}.project-detail-no-image h1{letter-spacing:-1.5px;margin-bottom:16px;font-size:2.8rem;font-weight:800}@media (width<=768px){.detail-media-main{aspect-ratio:16/10}.project-detail-hero-overlay h1{font-size:1.8rem}.project-detail-content{grid-template-columns:1fr;gap:32px}.project-detail-no-image h1{font-size:2rem}}.tag-select{width:100%;position:relative}.tag-select-current{background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;border-radius:.25vh;align-items:center;gap:8px;min-height:46px;padding:8px 14px;transition:all .25s;display:flex}.tag-select-current:hover{border-color:var(--border-hover)}.tag-select-placeholder{color:var(--text-muted);flex:1;font-size:.88rem}.tag-select-pills{flex-wrap:wrap;flex:1;gap:6px;display:flex}.tag-pill{color:#eef4ed;cursor:pointer;background:#02020280;border-radius:.25vh;align-items:center;gap:4px;padding:3px 10px;font-size:.78rem;font-weight:600;transition:all .2s;display:inline-flex}.tag-pill:hover{background:#020202b3}.tag-pill svg{font-size:.7rem}.tag-select-arrow{color:var(--text-muted);flex-shrink:0;font-size:1rem;transition:transform .25s}.tag-select-arrow.open{transform:rotate(180deg)}.tag-select-dropdown{background:var(--bg-card);border:1px solid var(--border);z-index:50;border-radius:.25vh;animation:.2s tagDropIn;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden;box-shadow:0 12px 40px #00000080}@keyframes tagDropIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.tag-select-search{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text-primary);background:0 0;outline:none;padding:12px 14px;font-family:inherit;font-size:.88rem}.tag-select-options{max-height:200px;padding:6px;overflow-y:auto}.tag-select-options::-webkit-scrollbar{width:4px}.tag-select-options::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:10px}.tag-option{width:100%;color:var(--text-secondary);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:.25vh;padding:8px 12px;font-family:inherit;font-size:.85rem;transition:all .15s;display:block}.tag-option:hover{color:#eef4ed;background:#02020266}.tag-option-create{color:#eef4ed;border-bottom:1px solid var(--border);border-radius:0;margin-bottom:4px;font-weight:600}.tag-option-empty{text-align:center;color:var(--text-muted);padding:12px;font-size:.82rem}.modal-container *,.modal-container :before,.modal-container :after{box-sizing:border-box}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;padding:24px;animation:.25s modalFadeIn;display:flex;position:fixed;inset:0}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex-direction:column;width:min(680px,100%);max-height:90vh;animation:.3s cubic-bezier(.16,1,.3,1) modalSlideIn;display:flex;position:relative;overflow:hidden;box-shadow:0 24px 80px #0009}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-form{flex-direction:column;flex:1;width:100%;min-height:0;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{color:var(--text-primary);margin:0;font-size:1.15rem;font-weight:700}.modal-close{border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;transition:all .18s;display:flex}.modal-close:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-hover)}.modal-body{flex:1;width:100%;min-height:0;padding:24px;overflow-y:auto}.modal-error{color:#ef4444;background:#ef44441a;border:1px solid #ef444440;border-radius:6px;margin-bottom:18px;padding:10px 14px;font-size:.84rem}.modal-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:16px;width:100%;display:grid}.modal-field{min-width:0}.modal-field.full{grid-column:1/-1}.modal-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:4px;margin-bottom:6px;font-size:.75rem;font-weight:600;display:flex}.modal-field input[type=text],.modal-field input[type=url],.modal-field textarea{background:var(--bg-secondary);border:1px solid var(--border);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:6px;outline:none;padding:12px 16px;font-family:inherit;font-size:.95rem;line-height:1.5;transition:border-color .2s,box-shadow .2s;display:block}.modal-field input:focus,.modal-field textarea:focus{border-color:#0b2545}.modal-field textarea{resize:vertical;min-height:110px}.modal-field small{color:var(--text-muted);margin-top:5px;font-size:.73rem;display:block}.media-input-row{gap:8px;display:flex}.media-input-row input{flex:1;min-width:0}.media-add-btn{color:#fff;cursor:pointer;background:#13315c;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.1rem;transition:background .2s,transform .15s;display:flex}.media-add-btn:hover{background:#0b2545;transform:scale(1.05)}.media-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-top:12px;display:grid}.media-grid-item{border:1px solid var(--border);background:0 0;border-radius:6px;flex-direction:column;transition:border-color .2s;display:flex;overflow:hidden}.media-grid-item:hover{border-color:var(--border-hover)}.media-preview-item{aspect-ratio:16/10;background:var(--bg-secondary);width:100%;position:relative;overflow:hidden}.media-preview-item img,.media-preview-item video{object-fit:cover;width:100%;height:100%;display:block}.media-preview-item iframe{border:none;width:100%;height:100%}.media-type-badge{color:#fff;background:#0000008c;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:.65rem;display:flex;position:absolute;top:6px;left:6px}.media-remove{color:#fff;cursor:pointer;background:#ef4444d9;border:none;justify-content:center;align-items:center;width:100%;padding:7px 0;font-size:.85rem;transition:background .15s;display:flex}.media-remove:hover{background:#dc2626}.modal-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.modal-footer.mobile{display:none}button,input,textarea,select{font-family:inherit;font-size:1rem;transition:all .2s}.modal-cancel{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:.25vh;padding:9px 20px;font-weight:600}.modal-cancel:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-card)}.modal-submit{color:#fff;cursor:pointer;background:#13315c;border:none;border-radius:.25vh;align-items:center;gap:6px;padding:9px 24px;font-weight:700;display:flex;box-shadow:0 6px 20px #3b82f633}.modal-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 28px #3b82f647}.modal-submit:disabled{opacity:.55;cursor:not-allowed}@media (width<=640px){.modal-overlay{align-items:flex-end;padding:0}.modal-container{border-radius:12px 12px 0 0;max-height:95vh}.modal-grid{grid-template-columns:1fr}.modal-footer:not(.mobile){display:none}.modal-footer.mobile{justify-content:space-between;display:flex}}.admin{min-height:100vh;padding-top:100px}.admin-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:48px;display:flex}.admin-header h1{letter-spacing:-1px;font-size:2rem;font-weight:800}.admin-header h1 span{color:#eef4ed}.admin-header-actions{align-items:center;gap:10px;display:flex}.admin-header-actions .btn-primary,.admin-header-actions .btn-secondary,.admin-empty .btn-primary,.admin-lock .btn-primary{border-radius:.25vh;justify-content:center;align-items:center;gap:8px;padding:12px 18px;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex}.admin-header-actions .btn-primary,.admin-empty .btn-primary,.admin-lock .btn-primary{color:#fff;background:#13315c;border:1px solid #0000;box-shadow:0 14px 30px #3b82f61f}.admin-header-actions .btn-primary:hover,.admin-empty .btn-primary:hover,.admin-lock .btn-primary:hover{transform:translateY(-1px);box-shadow:0 18px 38px #3b82f62e}.admin-header-actions .btn-secondary{border:1px solid var(--border);color:var(--text-primary);background:#ffffff0d}.admin-header-actions .btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.admin-error{color:#ef4444;background:#ef44441a;border:1px solid #ef444440;border-radius:.25vh;margin-bottom:24px;padding:12px 18px;font-size:.85rem}.admin-lock{flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:60vh;display:flex}.admin-lock .lock-icon{color:#eef4ed;background:#02020280;border-radius:.25vh;justify-content:center;align-items:center;width:80px;height:80px;font-size:3rem;display:flex}.admin-lock p{color:#eef4ed;text-align:center;font-size:1.05rem}.admin-lock input{color:var(--text-primary);text-align:center;background:0 0;border:.5px solid #0000;border-radius:.25vh;outline:none;width:300px;max-width:100%;padding:14px 20px;font-family:inherit;font-size:.95rem;transition:all .3s}.admin-lock input:focus{border:.5px solid #13315c}.admin-lock .error{color:#ef4444;font-size:.85rem}.admin-projects-list{flex-direction:column;gap:10px;display:flex}.admin-project-item{background:var(--bg-card);border:1px solid var(--border);border-radius:.25vh;align-items:center;gap:16px;padding:16px 20px;transition:all .25s;display:flex;box-shadow:0 4px 15px #00000006}.admin-project-item:hover{border-color:var(--border-hover);background:var(--bg-card-hover);transform:translateY(-1px);box-shadow:0 16px 45px #00000014}.admin-project-thumb{object-fit:cover;background:var(--bg-secondary);border-radius:.25vh;flex-shrink:0;width:64px;height:44px}.admin-project-thumb.no-thumb{justify-content:center;align-items:center;display:flex}.admin-project-info{flex:1;min-width:0}.admin-project-info h4{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.admin-project-info p{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.admin-project-tags{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.admin-project-tags span{color:#eef4ed;background:#02020280;border-radius:.25vh;padding:2px 8px;font-size:.68rem;font-weight:600}.admin-project-actions{flex-shrink:0;gap:6px;display:flex}.btn-icon{border:1px solid var(--border);background:var(--bg-secondary);width:38px;height:38px;color:var(--text-muted);cursor:pointer;border-radius:.25vh;justify-content:center;align-items:center;font-size:1rem;transition:all .2s;display:flex}.btn-icon:hover{border-color:var(--border-hover);color:var(--text-primary);background:#ffffff14;transform:translateY(-1px)}.btn-icon.danger{color:var(--text-danger,#ef4444)}.btn-icon:hover{border-color:var(--border-hover);color:var(--text-primary);background:#ffffff08}.btn-icon.danger:hover{color:#ef4444;background:#ef44441a;border-color:#ef4444}.admin-empty{text-align:center;color:var(--text-muted);padding:48px}.admin-empty .empty-icon{opacity:.5;margin-bottom:12px;font-size:2.5rem}@media (width<=768px){.admin-header{flex-direction:column;align-items:flex-start}.admin-project-item{flex-wrap:wrap}}*,:before,:after{cursor:none!important}.cursor-dot{background:var(--accent,#ff7a3d);width:10px;height:10px;box-shadow:0 0 8px var(--accent,#ff7a3d), 0 0 20px #ff7a3d47;pointer-events:none;z-index:99999;will-change:transform;contain:layout style;border-radius:50%;transition:width .2s,height .2s,top .2s,left .2s,background .2s,box-shadow .2s;position:fixed;top:-5px;left:-5px}.cursor-trail{pointer-events:none;z-index:99998;will-change:transform;contain:layout style;background:#ff7a3d08;border:1px solid #ff7a3d38;border-radius:50%;width:36px;height:36px;transition:width .25s,height .25s,top .25s,left .25s,border-color .25s,background .25s;position:fixed;top:-18px;left:-18px}.cursor-dot.cursor-hover{width:16px;height:16px;box-shadow:0 0 12px var(--accent,#ff7a3d), 0 0 30px #ff7a3d80;background:#ff7a3d99;top:-8px;left:-8px}.cursor-trail.cursor-hover{background:#ff7a3d0f;border-color:#ff7a3d66;width:50px;height:50px;top:-25px;left:-25px}@media (hover:none),(pointer:coarse){.cursor-dot,.cursor-trail{display:none}*,:before,:after{cursor:auto!important}}
