:root{--bg: #08131f;--bg-soft: #102033;--panel: rgba(10, 20, 33, .92);--panel-soft: rgba(16, 32, 51, .92);--panel-light: rgba(255, 255, 255, .08);--line: rgba(193, 216, 242, .16);--line-strong: rgba(193, 216, 242, .28);--text: #f4f8ff;--text-soft: #d9e7f7;--muted: #a9bfd8;--brand: #67d09b;--brand-deep: #1f9b6a;--accent: #79b8ff;--danger: #ff8787;--warning: #ffd36f;--shadow: 0 18px 50px rgba(0, 0, 0, .32)}*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{font-family:Microsoft YaHei UI,PingFang SC,Segoe UI,sans-serif;color:var(--text);background:radial-gradient(circle at top right,rgba(121,184,255,.24),transparent 24%),radial-gradient(circle at left center,rgba(103,208,155,.18),transparent 30%),linear-gradient(180deg,#07121d,#0d1828 55%,#08131f)}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}img{max-width:100%}.container{width:min(1200px,calc(100% - 32px));margin:0 auto}.page-shell{padding-bottom:48px}.section{padding:16px 0 10px}.card{background:var(--panel);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow)}.navbar{position:sticky;top:0;z-index:30;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#050c14e6;border-bottom:1px solid var(--line)}.navbar-inner{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;min-height:74px}.logo{display:flex;align-items:center;gap:12px;font-weight:700}.logo-mark{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--accent));color:#062012;font-weight:800}.nav-subtitle{font-size:12px}.logo>div>div:first-child{line-height:1.2}.nav-links,.nav-actions,.hero-actions,.action-row,.row,.price-row{display:flex;align-items:center;gap:12px}.nav-links{justify-content:center;flex-wrap:wrap}.nav-actions{justify-content:flex-end;flex-wrap:wrap}.nav-links a{padding:10px 14px;border-radius:999px;color:var(--text-soft)}.nav-links a.router-link-active{background:#67d09b26;color:var(--text)}.btn,.tab-btn,.icon-btn{border:none;cursor:pointer;transition:transform .18s ease,opacity .18s ease,background .18s ease,border-color .18s ease}.btn:hover,.tab-btn:hover,.icon-btn:hover{transform:translateY(-1px)}.btn{border-radius:14px;padding:11px 16px}.btn.primary{background:linear-gradient(135deg,var(--brand),var(--brand-deep));color:#05170d;font-weight:700}.btn.secondary{background:#ffffff12;color:var(--text);border:1px solid var(--line)}.btn.danger{background:#ff878729;color:#ffe2e2}.full-width{width:100%}.hero{padding:34px 0 24px}.hero-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:22px}.hero-card,.side-stat,.side-banner,.feature-card,.product-card,.custom-card,.form-card,.chat-card,.profile-card,.admin-card,.profile-side-card,.overview-card,.auth-intro,.auth-card{padding:22px}.hero-card{min-height:430px;position:relative;overflow:hidden}.hero-card:after{content:"";position:absolute;inset:auto -60px -60px auto;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(103,208,155,.26),transparent 70%)}.hero-card>*{position:relative;z-index:1}.hero-side{display:grid;gap:18px}.eyebrow{display:inline-flex;padding:8px 12px;border-radius:999px;background:#79b8ff24;color:#d7eaff;font-size:13px}.hero-title{font-size:clamp(34px,6vw,58px);line-height:1.05;margin:16px 0}.hero-text,.section-head p,.muted{color:var(--muted)}.hero-text{line-height:1.85;max-width:720px}.hero-actions{margin-top:26px;flex-wrap:wrap}.hero-copy-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:22px}.hero-copy-item{padding:14px 16px;border-radius:18px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08)}.hero-copy-item strong{display:block;margin-bottom:8px;color:var(--text)}.hero-copy-item span{display:block;color:var(--text-soft);line-height:1.6;font-size:14px}.side-banner-title{color:var(--text);font-size:24px;font-weight:700;margin:16px 0 10px}.side-banner .btn{margin-top:10px}.stats-grid,.feature-grid,.product-grid,.grid-2,.grid-3,.admin-overview-grid,.admin-main-grid,.auth-layout,.user-grid{display:grid;gap:18px}.stats-grid{grid-template-columns:repeat(2,1fr);margin-top:16px}.stat-item,.summary-box,.user-item{padding:14px;border-radius:18px;background:var(--panel-light);border:1px solid rgba(255,255,255,.06)}.stat-item strong{display:block;font-size:24px;margin-bottom:6px}.section-head{display:flex;justify-content:space-between;align-items:end;gap:14px;margin-bottom:18px}.section-head h2,.section-head h3,h3{margin:0 0 6px}.section-head h2{font-size:28px}p{margin:0}.card p+.btn,.card p+.action-row,.card .muted+.btn,.card .muted+.action-row,.card .summary-box+.btn,.card .summary-box+.action-row{margin-top:14px}.carousel-stage{min-height:270px;border-radius:22px;padding:24px;display:flex;flex-direction:column;justify-content:flex-end;background-size:cover;background-position:center;position:relative;overflow:hidden}.carousel-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#00000014,#000000a3)}.carousel-stage>*{position:relative;z-index:1}.carousel-dots{display:flex;gap:10px}.carousel-dots button{width:11px;height:11px;padding:0;border-radius:50%;border:none;background:#ffffff3d}.carousel-dots button.active{background:var(--brand)}.feature-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.feature-card{min-height:220px;background:linear-gradient(180deg,#102033f0,#09121ef5)}.feature-card h3{font-size:22px;margin:14px 0 10px}.feature-card p{line-height:1.75}.product-card h3{margin:10px 0 8px}.form-card h3,.profile-card h3,.admin-card h3,.profile-side-card h3,.auth-card h3,.auth-intro h2{margin:0}.auth-intro p{line-height:1.8}.product-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.product-card{display:flex;flex-direction:column}.add-cart-btn{font-size:14px;padding:9px 12px;white-space:nowrap}.product-card img,.feature-thumb img,.preview-image{width:100%;border-radius:18px;display:block;object-fit:cover}.product-card img,.feature-thumb img{height:210px}.preview-image{max-height:220px}.preview-dark{background:#081019;object-fit:contain}.tag,.pill{display:inline-flex;padding:6px 10px;border-radius:999px;font-size:12px}.tag{background:#67d09b24;color:#d8ffe8}.pill{background:#ffffff17;color:var(--text-soft)}.price-row,.row{justify-content:space-between}.price{font-size:28px;font-weight:700;color:#d9ffe8}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-1{display:grid;gap:16px}.field{display:grid;gap:8px}.field span{color:var(--text-soft);font-size:14px}.field input,.field textarea,.field select{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--line);background:#ffffff0f;color:var(--text)}.field select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:linear-gradient(45deg,transparent 50%,#d9e7f7 50%),linear-gradient(135deg,#d9e7f7 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:36px}.field select option{color:#08131f;background:#f4f8ff}.field select:focus{outline:none;border-color:#79b8ff8c;box-shadow:0 0 0 3px #79b8ff29}.field input::placeholder,.field textarea::placeholder{color:#c4d4e6;opacity:.75}.field input:disabled,.field textarea:disabled,.field select:disabled{color:#d6e4f5;background:#ffffff14}.field textarea{min-height:96px;resize:vertical}.shop-layout,.community-layout,.profile-layout{display:grid;grid-template-columns:1fr 360px;gap:20px}.community-info-card{margin-bottom:20px}.community-layout-single{grid-template-columns:1fr}.community-head-meta{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.custom-page-grid{grid-template-columns:1fr}.customize-shell{display:grid;gap:18px}.customize-hero{padding:24px 26px;background:radial-gradient(circle at 84% 18%,rgba(121,184,255,.26),transparent 44%),radial-gradient(circle at 20% 80%,rgba(103,208,155,.16),transparent 38%),linear-gradient(155deg,#0f2134f2,#081320f5);border-radius:24px}.customize-hero-title{margin:12px 0 10px;font-size:clamp(26px,4vw,36px);line-height:1.18}.customize-hero-text{color:var(--text-soft);line-height:1.75}.customize-projects{padding:22px;border-radius:24px;background:linear-gradient(170deg,#102134f0,#08131ffa)}.custom-project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.custom-project-card{min-height:172px;border-radius:20px;border:1px solid rgba(193,216,242,.16);background:#ffffff0a;color:var(--text);padding:16px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:8px;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease}.custom-project-card strong{font-size:17px;line-height:1.35}.custom-project-card p{line-height:1.62;font-size:13px}.custom-project-pill{display:inline-flex;align-items:center;justify-content:center;min-width:106px;border-radius:999px;font-size:12px;color:#dcecff;border:1px solid rgba(193,216,242,.28);background:#79b8ff1a;padding:5px 10px}.custom-project-card:hover{transform:translateY(-2px);border-color:#1fe3d385;box-shadow:0 12px 32px #060f186b}.custom-project-card.active{border-color:#1fe3d3b3;background:linear-gradient(145deg,#0d2b37d6,#081622e6);box-shadow:0 14px 34px #0000005c}.customize-form{padding:24px;background:linear-gradient(178deg,#0d1b2af5,#08121efa);border-radius:24px}.custom-upload-row{display:grid;gap:10px}.custom-label{font-size:14px;font-weight:700;color:#ddedff}.upload-hidden-input{display:none}.upload-dropzone{border:2px dashed rgba(31,227,211,.8);border-radius:26px;background:linear-gradient(165deg,#162331f0,#121f2cf5);min-height:178px;width:100%;cursor:pointer;display:grid;place-items:center;gap:8px;padding:22px 16px;color:#e8f7ff;transition:border-color .22s ease,transform .22s ease,box-shadow .22s ease,background .22s ease}.upload-dropzone:hover{border-color:#1fe3d3;box-shadow:0 0 0 4px #1fe3d324,0 18px 36px #050d1661;transform:translateY(-1px)}.upload-icon{width:44px;height:44px;color:#1fe3d3;animation:uploadPulse 2.3s ease-in-out infinite}.upload-icon svg{width:100%;height:100%;fill:currentColor}.upload-title{font-size:23px;font-weight:800;letter-spacing:.3px}.upload-hint{font-size:13px;color:#b4d8e6}.upload-file{margin-top:4px;font-size:12px;padding:6px 10px;border-radius:999px;border:1px solid rgba(31,227,211,.45);background:#1fe3d31a;color:#cefdf7}.upload-preview-image{width:min(260px,100%);max-height:138px;object-fit:contain;border-radius:14px;border:1px solid rgba(31,227,211,.4);background:#09131f}@keyframes uploadPulse{0%,to{transform:scale(1);opacity:.95}50%{transform:scale(1.08);opacity:1}}.customize-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.customize-form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.custom-field>span{font-weight:600;color:#dfeeff}.custom-field input,.custom-field textarea,.custom-field select{border-radius:16px;border-color:#c1d8f242;background:#08131fa3;box-shadow:inset 0 1px #ffffff14}.custom-field input:focus,.custom-field textarea:focus,.custom-field select:focus{border-color:#79b8ffa8;box-shadow:0 0 0 4px #79b8ff24;outline:none}.custom-field textarea{min-height:118px}.customize-dynamic-block{margin-top:16px}.form-swap-enter-active,.form-swap-leave-active{transition:all .22s ease}.form-swap-enter-from,.form-swap-leave-to{opacity:0;transform:translateY(10px) scale(.98)}.customize-common-wrap{margin-top:8px;border-radius:18px;border:1px solid rgba(193,216,242,.16);background:#ffffff08;padding:16px}.customize-common-wrap h4{margin:0;font-size:16px;color:#eaf4ff}.customize-action{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.customize-submit{min-width:164px}.checkout-panel{position:sticky;top:96px;align-self:start}.cart-list,.user-list,.profile-page-stack,.auth-highlights{display:grid;gap:12px}.mobile-cart-fab{position:fixed;right:16px;bottom:18px;z-index:45;border:1px solid rgba(103,208,155,.6);background:linear-gradient(135deg,#67d09bf2,#1f9b6af2);color:#05170d;border-radius:999px;padding:10px 14px;font-size:13px;font-weight:700;box-shadow:0 14px 26px #00000059}.mobile-cart-fab-count{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;border-radius:999px;background:#ff8787;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;border:1px solid rgba(255,255,255,.6)}.order-confirm-modal{max-height:min(86vh,860px);overflow-y:auto}.order-modal-items,.order-items,.order-list{display:grid;gap:10px}.order-modal-item,.order-item-line{display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.07)}.payment-guide h4{margin:0 0 8px}.pay-code-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.pay-code-card{padding:12px;border-radius:14px;border:1px solid var(--line);background:#ffffff0d;display:grid;gap:10px}.pay-code-image{width:100%;max-width:220px;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.order-card{padding:16px;border-radius:16px;border:1px solid var(--line);background:#ffffff0a}.order-log-line{display:grid;gap:2px;color:var(--text-soft);font-size:13px}.status-pill{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:5px 10px;font-size:12px;border:1px solid transparent}.status-pill.pending{color:#fff4cf;background:#ffd36f29;border-color:#ffd36f52}.status-pill.processing{color:#dcecff;background:#79b8ff24;border-color:#79b8ff52}.status-pill.info{color:#d9f4ff;background:#50b6ef33;border-color:#50b6ef5c}.status-pill.success{color:#ddffec;background:#67d09b29;border-color:#67d09b52}.status-pill.danger{color:#ffe2e2;background:#ff878729;border-color:#ff878747}.auth-highlights{margin-top:18px}.chat-card{display:flex;flex-direction:column;max-height:78vh}.chat-window{padding:16px;border-radius:18px;flex:1;min-height:320px;overflow:auto;background:linear-gradient(180deg,#060a10f5,#0c121cfa);border:1px solid rgba(255,255,255,.1)}.message-item{padding:5px 0;line-height:1.7;display:flex}.message-bubble{max-width:min(78%,720px);padding:10px 14px;border-radius:16px;position:relative;word-break:break-word}.message-normal{color:#f7fbff;background:#ffffff14;border-top-left-radius:6px}.message-self{color:#dff7ea;font-weight:700;background:#67d09b29;border-top-right-radius:6px;margin-left:auto;text-align:left}.message-announcement{color:#ffe07b;background:#ffd36f1a;margin:0 auto}.message-action{margin-left:10px;padding:4px 8px;vertical-align:middle}.chat-compose{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:end}.chat-input{width:100%;height:54px;min-height:54px;max-height:54px;padding:15px 16px;resize:none;border-radius:16px;border:1px solid var(--line);background:#ffffff0f;color:var(--text);overflow-y:auto}.chat-input::placeholder{color:#c4d4e6;opacity:.8}.chat-send-btn{min-width:96px;height:54px}.chat-status-slot{min-height:44px}.connection-badge{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid var(--line);color:var(--text-soft);background:#ffffff0f}.connection-badge.connected{color:#042114;background:#67d09bf2;border-color:#67d09b99}.connection-badge.polling{color:#fff4cf;background:#ffd36f29;border-color:#ffd36f52}.connection-badge.connecting{color:#dcecff;background:#79b8ff24;border-color:#79b8ff52}.alert{padding:12px 14px;border-radius:14px;background:#79b8ff24;color:#eff6ff;border:1px solid rgba(121,184,255,.2)}.success{background:#67d09b24;border-color:#67d09b38;color:#ecfff4}.warning{background:#ffd36f29;border-color:#ffd36f3d;color:#fff2c8}.auth-section{padding-top:28px}.auth-single-wrap{display:flex;justify-content:center}.auth-layout{grid-template-columns:1fr minmax(320px,420px);align-items:stretch}.auth-intro{background:linear-gradient(160deg,#102033f5,#08131ff5);display:flex;flex-direction:column;justify-content:space-between}.auth-card-single{width:min(520px,100%)}.auth-switch{display:inline-flex;width:fit-content;padding:6px;margin-top:18px;border-radius:999px;background:#ffffff0f;border:1px solid var(--line)}.tab-btn{padding:10px 18px;border-radius:999px;background:transparent;color:var(--text-soft)}.tab-btn.active{background:linear-gradient(135deg,#67d09be6,#1f9b6ae6);color:#05170d;font-weight:700}.auth-card .btn,.profile-card .btn,.admin-card .btn,.profile-side-card .btn,.form-card .btn{margin-top:14px}.profile-side-card,.admin-card,.overview-card{background:var(--panel-soft)}.admin-dashboard{display:grid;gap:22px}.admin-tabbar{display:flex;gap:10px;flex-wrap:wrap}.admin-tabbar .tab-btn{background:#ffffff12;border:1px solid var(--line);color:var(--text-soft)}.admin-tabbar .tab-btn.active{background:linear-gradient(135deg,#67d09bf5,#1f9b6af5);border-color:#67d09b99;color:#04140b;font-weight:700;box-shadow:0 10px 24px #1f9b6a38}.admin-profile-row{width:100%}.admin-toolbar{display:flex;justify-content:flex-start;gap:14px;flex-wrap:wrap}.admin-search-field{width:min(420px,100%)}.inline-field{width:180px}.summary-line,.user-meta-row{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.overview-card strong{display:block;margin:12px 0 6px;font-size:34px}.overview-label{color:var(--text-soft);font-size:13px}.admin-overview-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-main-grid{grid-template-columns:minmax(0,1.05fr) minmax(0,1fr)}.user-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.compact-user-item{background:#ffffff0a}.product-toolbar{align-items:end}.product-admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}.product-admin-card{padding:18px;border-radius:20px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08)}.product-admin-image{width:100%;height:180px;object-fit:cover;border-radius:16px}.product-check{display:inline-flex;align-items:center;gap:8px;color:var(--text-soft);font-size:13px}.product-check input{width:16px;height:16px}.file-btn{position:relative;overflow:hidden}.file-btn input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.modal-card-wide{width:min(760px,100%)}.user-item-head{align-items:flex-start}.admin-card-head{align-items:start}.admin-tools{padding-top:6px;border-top:1px solid var(--line)}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#030910b8;display:grid;place-items:center;padding:20px}.modal-card{width:min(560px,100%);background:#102033;color:var(--text);border:1px solid var(--line-strong);border-radius:24px;padding:24px;box-shadow:0 24px 80px #00000073}.icon-btn{width:38px;height:38px;border-radius:999px;background:#ffffff14;color:var(--text)}.space-top{margin-top:16px}.footer{padding:26px 0 40px;color:var(--muted);text-align:center}@media (max-width: 1040px){.hero-grid,.shop-layout,.community-layout,.profile-layout,.auth-layout,.admin-main-grid{grid-template-columns:1fr}.feature-grid,.product-grid,.grid-3,.admin-overview-grid,.hero-copy-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.navbar-inner{grid-template-columns:1fr;gap:12px;padding:10px 0 12px}.checkout-panel{position:static}.custom-project-grid,.customize-form-grid.three{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 720px){.container{width:min(100% - 20px,1200px)}.feature-grid,.product-grid,.grid-2,.grid-3,.admin-overview-grid,.hero-copy-grid,.pay-code-grid{grid-template-columns:1fr}.hero-card,.side-stat,.side-banner,.feature-card,.product-card,.custom-card,.form-card,.chat-card,.profile-card,.admin-card,.profile-side-card,.overview-card,.auth-intro,.auth-card,.modal-card{padding:18px}.navbar{position:sticky}.navbar-inner{grid-template-columns:1fr auto;grid-template-areas:"logo actions" "nav nav";gap:10px 12px;min-height:auto;padding:8px 0 10px;align-items:center}.logo{grid-area:logo}.nav-actions{grid-area:actions}.nav-links{grid-area:nav}.logo{gap:10px}.logo-mark{width:36px;height:36px;border-radius:12px}.nav-subtitle{font-size:11px}.hero-actions,.action-row{justify-content:flex-start}.nav-actions{justify-content:flex-end;align-self:center}.nav-links{justify-content:flex-start;gap:8px;overflow-x:auto;flex-wrap:nowrap;padding:2px 0;scrollbar-width:none}.nav-links::-webkit-scrollbar{display:none}.nav-links a{padding:8px 12px;font-size:13px;white-space:nowrap}.nav-actions{gap:8px}.nav-actions .pill{display:none}.nav-actions .btn{padding:8px 12px}.mobile-cart-fab{display:inline-flex;align-items:center;justify-content:center}.section-head,.summary-line,.user-meta-row,.row,.price-row{align-items:flex-start}.hero-title{font-size:34px}.hero-text{margin-bottom:0}.hero-copy-grid{margin-top:18px}.hero-actions{margin-top:20px}.side-banner-title{font-size:21px}.section-head{margin-bottom:14px}.section-head h2{font-size:24px}.feature-card h3{font-size:20px}.auth-switch{width:100%}.tab-btn{flex:1;text-align:center}.inline-field{width:100%}.product-admin-grid{grid-template-columns:1fr}.message-bubble{max-width:88%}.chat-compose{grid-template-columns:1fr auto}.chat-send-btn{min-width:82px}.chat-card{max-height:72vh}.chat-window{min-height:260px}.customize-hero-title{font-size:29px}.customize-hero{padding:20px}.custom-project-grid{grid-template-columns:1fr}.custom-project-card{min-height:150px}.customize-form-grid,.customize-form-grid.three{grid-template-columns:1fr}.customize-projects,.customize-form{padding:18px}.upload-dropzone{min-height:158px}.upload-title{font-size:20px}.community-head-meta{justify-content:flex-start}.btn{position:relative;overflow:hidden;transform:translateY(0);transition:transform .2s cubic-bezier(.2,.9,.4,1.1),background .2s ease,box-shadow .2s ease}.btn:active{transform:scale(.96);transition-duration:.05s}.ripple{position:absolute;border-radius:50%;background:#ffffff80;transform:scale(0);animation:ripple-animation .5s linear;pointer-events:none}@keyframes ripple-animation{to{transform:scale(4);opacity:0}}.feature-card,.product-card,.custom-project-card,.order-card,.user-item,.product-admin-card{transition:transform .25s cubic-bezier(.2,.9,.4,1.1),box-shadow .25s ease,border-color .2s ease}.feature-card:hover,.product-card:hover,.order-card:hover,.user-item:hover,.product-admin-card:hover{transform:translateY(-4px);box-shadow:0 20px 35px -12px #00000059}.custom-project-card{transition:transform .2s ease,border-color .2s ease,background .2s ease}.custom-project-card:active{transform:scale(.98)}.modal-mask{transition:backdrop-filter .2s ease}.modal-card{animation:modal-pop .25s cubic-bezier(.34,1.2,.64,1);transform-origin:center}@keyframes modal-pop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.cart-item,.message-item,.order-card{animation:fade-slide-up .2s ease-out}@keyframes fade-slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.price,.cart-count{transition:all .2s ease}.price-update{animation:price-pop .2s cubic-bezier(.34,1.2,.64,1)}@keyframes price-pop{0%{transform:scale(1)}50%{transform:scale(1.08);color:var(--brand)}to{transform:scale(1)}}.field input:focus,.field textarea:focus,.field select:focus{transition:border-color .15s ease,box-shadow .15s ease;transform:translateY(-1px)}.nav-links a,.router-link-active{transition:background .2s ease,transform .1s ease}.nav-links a:active{transform:scale(.96)}html{scroll-behavior:smooth}}.image-placeholder[data-v-47e5e550]{width:100%;height:210px;background:linear-gradient(145deg,#ffffff14,#0003);border-radius:18px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px}.image-placeholder[data-v-47e5e550]:before{content:"📷 图片占位";opacity:.5}.image-placeholder[data-v-f4dd9c15]{width:100%;height:180px;background:linear-gradient(145deg,#ffffff14,#0003);border-radius:18px;display:flex;align-items:center;justify-content:center;color:var(--muted)}.image-placeholder[data-v-f4dd9c15]:before{content:"🖼️ 图片占位";opacity:.5}.avatar-placeholder[data-v-3a8fbca5]{width:100%;height:210px;background:radial-gradient(circle at 30% 30%,rgba(103,208,155,.2),transparent);border-radius:18px;display:flex;align-items:center;justify-content:center;color:var(--muted)}.avatar-placeholder[data-v-3a8fbca5]:before{content:"👤 头像占位";opacity:.5}.image-placeholder[data-v-6c5fa87f]{width:100%;height:160px;background:linear-gradient(145deg,#ffffff14,#0003);border-radius:18px;display:flex;align-items:center;justify-content:center;color:var(--muted)}.image-placeholder[data-v-6c5fa87f]:before{content:"📱 微信二维码占位";opacity:.5}
