@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Noto+Sans+TC:wght@400;500;600;700;900&display=swap";:root{--bg:#07070a;--bg2:#0c0c10;--bg3:#131318;--bg4:#1a1a21;--surface:rgba(255,255,255,.03);--surface2:rgba(255,255,255,.05);--border:rgba(255,255,255,.06);--border2:rgba(255,255,255,.1);--border3:rgba(255,255,255,.15);--text:#f5f5f7;--text2:#a0a0ab;--text3:#64646e;--accent:#6d5cff;--accent2:#a78bfa;--accent-glow:rgba(109,92,255,.25);--green:#34d399;--yellow:#fbbf24;--red:#f87171;--r:14px;--rs:8px;--font:"Inter","Noto Sans TC",system-ui,-apple-system,sans-serif;--mono:"JetBrains Mono","Fira Code",monospace}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font);background:var(--bg);color:var(--text);letter-spacing:-.01em;line-height:1.5}a{color:inherit;text-decoration:none}::selection{background:var(--accent);color:#fff}.anim-up{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}.anim-up.visible{opacity:1;transform:translateY(0)}.d2{transition-delay:.12s}.nav{position:fixed;top:0;width:100%;z-index:200;background:#07070acc;-webkit-backdrop-filter:blur(24px) saturate(140%);backdrop-filter:blur(24px) saturate(140%);border-bottom:1px solid var(--border)}.nav-inner{max-width:1200px;margin:0 auto;padding:0 32px;height:60px;display:flex;align-items:center;justify-content:space-between}.nav-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:15px;letter-spacing:-.02em}.logo-img{width:28px;height:28px;border-radius:6px;object-fit:contain}.nav-links{display:flex;align-items:center;gap:32px;font-size:13px;color:var(--text2);font-weight:500}.nav-links a{transition:color .2s;position:relative}.nav-links a:hover{color:var(--text)}.nav-cta{background:var(--accent)!important;color:#fff!important;padding:7px 16px;border-radius:var(--rs);font-size:12px;font-weight:600;transition:all .2s!important}.nav-cta:hover{filter:brightness(1.15);transform:translateY(-1px)}.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.nav-burger span{width:18px;height:1.5px;background:var(--text2);border-radius:2px;transition:.3s}.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;border:none;padding:12px 28px;border-radius:var(--rs);font-weight:600;font-size:14px;font-family:var(--font);cursor:pointer;transition:all .25s;box-shadow:0 0 0 0 var(--accent-glow)}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 8px 32px var(--accent-glow)}.btn-primary svg{flex-shrink:0}.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--border2);color:var(--text2);padding:12px 28px;border-radius:var(--rs);font-weight:500;font-size:14px;font-family:var(--font);cursor:pointer;transition:all .25s}.btn-ghost:hover{border-color:var(--accent);color:var(--text);background:#6d5cff0a}.btn-full{width:100%;justify-content:center}.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.hero-bg-img{width:100%;height:100%;object-fit:cover;opacity:.35}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(7,7,10,.3) 0%,rgba(7,7,10,.85) 60%,var(--bg) 100%)}.hero-inner{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:140px 32px 80px;width:100%}.hero-content{max-width:680px}.hero-chip{display:inline-block;font-size:12px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent2);padding:6px 16px;border:1px solid rgba(167,139,250,.2);border-radius:100px;margin-bottom:28px;background:#6d5cff0f}.hero h1{font-size:clamp(36px,5.5vw,64px);font-weight:900;line-height:1.08;letter-spacing:-.04em;margin-bottom:24px}.hero-em{background:linear-gradient(135deg,var(--accent2),#60a5fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-desc{font-size:16px;color:var(--text2);line-height:1.7;margin-bottom:40px;max-width:520px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap}.hero-metrics{display:flex;align-items:center;gap:0;margin-top:80px;padding:24px 32px;background:var(--surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r)}.hm{text-align:center;flex:1}.hm-val{display:block;font-size:22px;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hm-label{font-size:11px;color:var(--text3);margin-top:2px;display:block}.hm-line{width:1px;height:32px;background:var(--border2);flex-shrink:0}.sec{padding:120px 32px}.sec-alt{background:var(--bg2)}.sec-inner{max-width:1200px;margin:0 auto}.sec-header{margin-bottom:56px}.sec-label{font-size:11px;text-transform:uppercase;letter-spacing:2.5px;color:var(--accent2);font-weight:600;display:block;margin-bottom:12px}.sec-header h2{font-size:clamp(28px,3.5vw,40px);font-weight:800;letter-spacing:-.035em;margin-bottom:12px;line-height:1.15}.sec-desc{font-size:15px;color:var(--text3);max-width:520px;line-height:1.7}.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.bento-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:32px 28px;transition:all .3s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.bento-card:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2));opacity:0;transition:.3s}.bento-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:0 16px 48px #0003}.bento-card:hover:after{opacity:1}.bento-lg{grid-column:span 2}.bc-icon{width:40px;height:40px;color:var(--accent2);margin-bottom:20px;opacity:.8}.bc-icon svg{width:100%;height:100%}.bento-card h3{font-size:18px;font-weight:700;margin-bottom:10px;letter-spacing:-.02em}.bento-card p{font-size:14px;color:var(--text2);line-height:1.65}.bc-chips{display:flex;gap:7px;margin-top:16px;flex-wrap:wrap}.bc-chips span{font-size:11px;color:var(--text3);padding:4px 12px;border-radius:100px;border:1px solid var(--border);background:var(--surface)}.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.sol-card{display:flex;align-items:center;gap:18px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:22px 24px;transition:all .3s cubic-bezier(.16,1,.3,1)}.sol-card:hover{border-color:var(--border2);transform:translateY(-3px);box-shadow:0 12px 40px #00000026}.sol-icon{width:28px;height:28px;color:var(--accent2);flex-shrink:0;opacity:.7}.sol-card h4{font-size:15px;font-weight:600;margin-bottom:2px}.sol-card span{font-size:12px;color:var(--text3)}.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.proc-card{text-align:center;padding:28px 16px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);transition:all .3s cubic-bezier(.16,1,.3,1)}.proc-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.pc-n{font-size:24px;font-weight:900;color:var(--accent);opacity:.35;margin-bottom:10px;font-variant-numeric:tabular-nums}.proc-card h4{font-size:14px;font-weight:600;margin-bottom:4px}.proc-card p{font-size:12px;color:var(--text3);line-height:1.4}.del-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.del-item{display:flex;align-items:center;gap:12px;padding:16px 18px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);transition:all .25s}.del-item:hover{border-color:var(--border2);transform:translateY(-2px)}.del-item svg{width:16px;height:16px;color:var(--green);flex-shrink:0}.del-item span{font-size:13px;font-weight:500}.works-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px}.work-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:all .3s cubic-bezier(.16,1,.3,1)}.work-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:0 16px 48px #0003}.wc-img{height:200px;background:var(--bg3);display:flex;align-items:center;justify-content:center;overflow:hidden}.wc-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}.work-card:hover .wc-img img{transform:scale(1.04)}.wc-ph{color:var(--text3);opacity:.2}.wc-ph svg{width:48px;height:48px}.wc-body{padding:22px 24px}.wc-tag{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--accent2);font-weight:600}.wc-body h3{font-size:16px;font-weight:600;margin:6px 0 8px;letter-spacing:-.02em}.wc-body p{font-size:13px;color:var(--text3);line-height:1.5}.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.testi-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:32px;transition:all .25s;position:relative}.testi-card:hover{border-color:var(--border2)}.testi-card:before{content:"“";position:absolute;top:16px;left:24px;font-size:56px;font-weight:900;color:var(--accent);opacity:.1;line-height:1;font-family:Georgia,serif}.tc-stars{color:var(--yellow);font-size:13px;letter-spacing:3px;margin-bottom:16px}.testi-card blockquote{font-size:14px;color:var(--text2);line-height:1.75;margin-bottom:20px;border:none;padding:0}.tc-author{display:flex;align-items:center;gap:12px}.tc-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg4);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--accent2)}.tc-author strong{font-size:13px;display:block}.tc-author span{font-size:11px;color:var(--text3)}.contact-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:56px}.c-form{display:flex;flex-direction:column}.f-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.f-g{margin-bottom:16px}.f-g label{display:block;font-size:12px;color:var(--text3);margin-bottom:6px;font-weight:500;letter-spacing:.3px}.f-g input,.f-g textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);padding:12px 16px;color:var(--text);font-size:14px;font-family:var(--font);outline:none;transition:all .2s}.f-g input:focus,.f-g textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}.f-g textarea{resize:vertical;min-height:100px}.f-g input::placeholder,.f-g textarea::placeholder{color:var(--text3)}.f-msg{padding:12px;border-radius:var(--rs);font-size:13px;margin-bottom:14px}.f-ok{background:#34d39914;border:1px solid rgba(52,211,153,.15);color:var(--green)}.f-err{background:#f8717114;border:1px solid rgba(248,113,113,.15);color:var(--red)}.c-info{display:flex;flex-direction:column;gap:14px;padding-top:6px}.ci-card{display:flex;align-items:center;gap:16px;padding:18px 22px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);transition:.2s}.ci-card:hover{border-color:var(--border2)}.ci-card svg{width:20px;height:20px;color:var(--accent2);flex-shrink:0;opacity:.7}.ci-card strong{font-size:13px;display:block}.ci-card p{font-size:12px;color:var(--text3);margin:0}.footer{border-top:1px solid var(--border);padding:32px}.footer-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.footer-brand{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--text2)}.footer-logo{width:22px;height:22px;border-radius:4px;opacity:.7}.footer p{font-size:11px;color:var(--text3)}.float-cta{position:fixed;bottom:28px;right:28px;z-index:999;width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 24px var(--accent-glow);transition:all .25s}.float-cta:hover{transform:scale(1.08);box-shadow:0 8px 32px var(--accent-glow)}.float-cta.active{background:var(--bg4);border:1px solid var(--border2);box-shadow:none}.float-panel{position:fixed;bottom:84px;right:28px;z-index:998;display:flex;flex-direction:column;gap:8px;opacity:0;pointer-events:none;transform:translateY(8px);transition:.25s}.float-panel.show{opacity:1;pointer-events:all;transform:translateY(0)}.float-panel a{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);font-size:13px;font-weight:500;color:var(--text2);transition:.2s;box-shadow:0 4px 20px #0006}.float-panel a:hover{border-color:var(--accent);color:var(--text)}.float-panel a svg{width:16px;height:16px;flex-shrink:0;color:var(--accent2)}.loading-t{text-align:center;padding:48px;color:var(--text3);font-size:13px}.empty-t{text-align:center;color:var(--text3);padding:56px;font-size:14px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative}.login-card{position:relative;z-index:1;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:44px 40px;width:100%;max-width:400px;box-shadow:0 16px 64px #0006}.login-back{font-size:12px;color:var(--text3);display:block;margin-bottom:28px;transition:.2s}.login-back:hover{color:var(--accent2)}.login-header{text-align:center;margin-bottom:32px}.login-header .logo-img{width:40px;height:40px;border-radius:8px;margin:0 auto 14px;display:block}.login-header h1{font-size:22px;font-weight:700;letter-spacing:-.02em}.login-header p{font-size:12px;color:var(--text3);margin-top:6px}.login-footer{text-align:center;color:var(--text3);font-size:11px;margin-top:24px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;color:var(--text3);margin-bottom:6px;font-weight:500}.form-group input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);padding:12px 16px;color:var(--text);font-size:14px;font-family:var(--font);outline:none;transition:.2s}.form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}.form-err{background:#f8717114;border:1px solid rgba(248,113,113,.15);color:var(--red);padding:10px 14px;border-radius:var(--rs);font-size:12px;margin-top:10px}.portal{min-height:100vh;display:flex;flex-direction:column}.portal-nav{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:56px;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;gap:12px}.nav-right{display:flex;align-items:center;gap:12px}.user-pill{font-size:12px;background:var(--bg3);padding:5px 14px;border-radius:100px;color:var(--text2);border:1px solid var(--border)}.admin-pill{background:var(--accent);color:#fff;padding:4px 12px;border-radius:100px;font-size:10px;font-weight:600;letter-spacing:.3px}.btn-sm-outline{background:none;border:1px solid var(--border);color:var(--text3);padding:5px 12px;border-radius:6px;font-size:11px;font-family:var(--font);cursor:pointer;transition:.2s}.btn-sm-outline:hover{border-color:var(--red);color:var(--red)}.chat-title{font-size:13px;color:var(--text2);flex:1;text-align:center}.portal-main{flex:1;max-width:1200px;margin:0 auto;width:100%;padding:28px}.portal-footer{text-align:center;padding:20px;color:var(--text3);font-size:11px;border-top:1px solid var(--border)}.portal-tabs{display:flex;gap:2px;background:var(--bg2);border-radius:var(--rs);padding:3px;margin-bottom:28px;border:1px solid var(--border);overflow-x:auto}.tab{flex:1;padding:9px 14px;background:none;border:none;color:var(--text3);font-size:12px;font-weight:500;font-family:var(--font);border-radius:6px;cursor:pointer;transition:.2s;white-space:nowrap}.tab.active{background:var(--accent);color:#fff}.tab:hover:not(.active){background:var(--bg3)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.project-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:28px;transition:.2s}.project-card:hover{border-color:var(--border2)}.pc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.pc-icon{font-size:28px;background:var(--bg3);width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--rs);border:1px solid var(--border)}.pc-status{font-size:11px;font-weight:500;padding:4px 12px;border-radius:100px;border:1px solid var(--border)}.project-card h3{font-size:17px;font-weight:600;margin-bottom:4px;letter-spacing:-.02em}.pc-desc{font-size:12px;color:var(--text3);margin-bottom:16px;line-height:1.5}.pc-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:11px;color:var(--text3);margin-bottom:18px}.pc-actions{display:flex;gap:8px}.btn-sm{padding:9px 16px;font-size:12px}.btn-disabled{opacity:.3;pointer-events:none!important}.badge{background:var(--red);color:#fff;font-size:9px;padding:2px 7px;border-radius:100px;font-weight:600;margin-left:6px}.chat-main{flex:1;display:flex;flex-direction:column;max-width:760px;margin:0 auto;width:100%;padding:20px}.chat-messages{flex:1;overflow-y:auto;padding:20px;max-height:calc(100vh - 160px);display:flex;flex-direction:column;gap:14px}.msg{max-width:72%}.msg-right{align-self:flex-end}.msg-left{align-self:flex-start}.msg-name{font-size:10px;color:var(--text3);margin-bottom:4px}.msg-time{font-size:9px;opacity:.4;margin-left:6px}.msg-bubble{background:var(--bg3);border:1px solid var(--border);padding:12px 16px;border-radius:var(--r);font-size:13px;line-height:1.65}.msg-right .msg-bubble{background:#6d5cff1a;border-color:#6d5cff26}.msg-right .msg-name{text-align:right}.chat-input{display:flex;gap:10px;padding:14px 0}.chat-input input{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);padding:12px 16px;color:var(--text);font-size:13px;font-family:var(--font);outline:none}.chat-input input:focus{border-color:var(--accent)}.changelog-list{display:flex;flex-direction:column}.cl-item{display:flex;gap:18px;padding:16px 0;border-bottom:1px solid var(--border)}.cl-date{font-size:12px;color:var(--text3);min-width:48px;font-weight:500;font-variant-numeric:tabular-nums}.cl-proj{font-size:12px;font-weight:600;color:var(--accent2)}.cl-ver{border:1px solid rgba(109,92,255,.15);color:var(--accent2);padding:2px 8px;border-radius:100px;font-size:10px;margin-left:8px}.cl-body p{font-size:13px;color:var(--text2);margin-top:4px;line-height:1.5}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:28px}.s-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:20px 24px;text-align:center;transition:.2s}.s-card:hover{border-color:var(--border2)}.s-card strong{font-size:28px;font-weight:800;display:block;letter-spacing:-.02em}.s-card span{font-size:11px;color:var(--text3)}.s-alert{border-color:#f8717126}.s-alert strong{color:var(--red)}.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.toolbar h3{font-size:14px;color:var(--text2);font-weight:500}.table-wrap{overflow-x:auto}.tbl{width:100%;border-collapse:collapse;font-size:12px}.tbl th{text-align:left;padding:10px 14px;color:var(--text3);font-size:10px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);white-space:nowrap}.tbl td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text2)}.tbl tr:hover td{background:#ffffff03}.tbl code{background:var(--bg);padding:2px 8px;border-radius:4px;font-size:10px;font-family:var(--mono)}.link-s{color:var(--accent2);font-size:11px}.link-s:hover{text-decoration:underline}.acts{display:flex;gap:4px;white-space:nowrap}.btn-xs{padding:4px 10px;border-radius:4px;font-size:10px;font-family:var(--font);cursor:pointer;border:1px solid var(--border);background:var(--bg);color:var(--text3);transition:.2s}.btn-xs:hover{border-color:var(--accent);color:var(--accent2)}.btn-r:hover{border-color:var(--red)!important;color:var(--red)!important}.badge-s{padding:3px 10px;border-radius:100px;font-size:10px;font-weight:500}.bg{background:#34d39914;color:var(--green)}.br{background:#f8717114;color:var(--red)}.tr-unread{background:#6d5cff08}.td-msg{max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-proj-list{display:flex;flex-direction:column;gap:4px;margin-bottom:18px}.msg-proj-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);cursor:pointer;transition:.2s;font-size:13px}.msg-proj-item:hover{border-color:var(--border2);background:var(--bg3)}.admin-chat-area{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:20px;min-height:200px}.admin-chat-area h4{font-size:14px;margin-bottom:14px;font-weight:600}.admin-chat-area .chat-messages{max-height:360px}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-box{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:32px;width:100%;max-width:460px;max-height:90vh;overflow-y:auto;box-shadow:0 16px 64px #0006}.modal-box h3{font-size:17px;font-weight:600;margin-bottom:24px;letter-spacing:-.02em}.fg{margin-bottom:14px}.fg label{display:block;font-size:11px;color:var(--text3);margin-bottom:5px;font-weight:500}.fg input,.fg select,.fg textarea{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--rs);padding:10px 14px;color:var(--text);font-size:12px;font-family:var(--font);outline:none;transition:.2s}.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}.fg textarea{resize:vertical;min-height:60px}.fr2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.mf{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}.icon-row{display:flex;gap:4px;flex-wrap:wrap}.ib{width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:15px;background:var(--bg);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:.2s}.ib:hover,.ib.sel{border-color:var(--accent);background:#6d5cff14}.empty-box{text-align:center;padding:56px 24px;color:var(--text3);font-size:13px;background:var(--bg2);border-radius:var(--r);border:1px dashed var(--border)}.err{text-align:center;color:var(--red);padding:24px;font-size:13px}.loading{text-align:center;padding:48px;color:var(--text3);font-size:13px}@media(max-width:768px){.nav-links{display:none;position:absolute;top:60px;left:0;right:0;background:#07070af2;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);flex-direction:column;padding:20px 28px;gap:14px}.nav-links.open,.nav-burger{display:flex}.hero-inner{padding-top:100px}.hero h1{font-size:32px}.hero-metrics{flex-wrap:wrap;gap:16px;padding:20px}.hm-line{display:none}.hm{min-width:40%}.bento{grid-template-columns:1fr}.bento-lg{grid-column:span 1}.sol-grid,.testi-grid{grid-template-columns:1fr}.proc-grid,.del-grid{grid-template-columns:repeat(2,1fr)}.contact-grid,.f-row,.projects-grid,.works-grid{grid-template-columns:1fr}.footer-inner{flex-direction:column;gap:10px;text-align:center}.admin-stats{grid-template-columns:repeat(3,1fr)}.sec{padding:80px 20px}}@media(max-width:480px){.hero h1{font-size:28px}.hero-actions{flex-direction:column;width:100%}.hero-actions a{text-align:center}.proc-grid,.del-grid{grid-template-columns:1fr}.admin-stats{grid-template-columns:repeat(2,1fr)}.client-cards{grid-template-columns:1fr!important}}.quick-actions{background:linear-gradient(135deg,#6d5cff0f,#60a5fa0a);border:1px solid rgba(109,92,255,.12);border-radius:var(--r);padding:24px 28px;margin-bottom:28px}.quick-actions h3{font-size:14px;font-weight:600;margin-bottom:16px;color:var(--accent2)}.qa-steps{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}.qa-step{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);padding:14px 18px;text-align:center;flex:1;min-width:140px}.qa-num{display:block;font-size:20px;font-weight:800;color:var(--accent);margin-bottom:4px}.qa-step>span:nth-child(2){display:block;font-size:13px;font-weight:600}.qa-sub{display:block;font-size:10px;color:var(--text3);margin-top:2px}.qa-arrow{color:var(--text3);font-size:18px;font-weight:700}.qa-btns{display:flex;gap:10px}.client-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.client-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:24px;transition:all .25s}.client-card:hover{border-color:var(--border2);box-shadow:0 8px 32px #00000026}.cc-header{display:flex;align-items:center;gap:14px;margin-bottom:18px}.cc-avatar{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff;flex-shrink:0}.cc-info{flex:1;min-width:0}.cc-info strong{display:block;font-size:15px;letter-spacing:-.02em}.cc-company{font-size:11px;color:var(--text3);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cc-cat{font-size:10px;font-weight:600;padding:3px 10px;border-radius:100px;white-space:nowrap}.cc-details{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;padding:14px;background:var(--bg3);border-radius:var(--rs);border:1px solid var(--border)}.cc-row{display:flex;align-items:center;justify-content:space-between;font-size:12px}.cc-label{color:var(--text3);font-weight:500}.cc-row code{background:var(--bg);padding:2px 8px;border-radius:4px;font-family:var(--mono);font-size:10px;color:var(--accent2)}.cc-count{color:var(--accent2);font-weight:600}.cc-status{margin-bottom:14px}.cc-actions{display:flex;gap:6px;flex-wrap:wrap}.cred-card{background:var(--bg2);border:1px solid rgba(52,211,153,.15);border-radius:var(--r);padding:20px;margin-bottom:20px}.cred-title{font-size:12px;font-weight:600;color:var(--green);margin-bottom:14px}.cred-body{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.cred-row{display:flex;align-items:center;justify-content:space-between;font-size:13px}.cred-row span{color:var(--text3)}.cred-row code{background:var(--bg);padding:4px 12px;border-radius:6px;font-family:var(--mono);font-size:12px;color:var(--text)}.cred-copy{width:100%}.copy-ok{text-align:center;color:var(--green);font-size:12px;margin-top:10px;font-weight:500}.proj-group{margin-bottom:24px}.pg-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs) var(--rs) 0 0;border-bottom:2px solid var(--accent)}.pg-avatar{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.pg-header strong{font-size:13px}.pg-count{font-size:11px;color:var(--text3);margin-left:auto}.proj-group .table-wrap{border:1px solid var(--border);border-top:0;border-radius:0 0 var(--rs) var(--rs);overflow:hidden}.type-tag{font-size:10px;font-weight:600;padding:3px 10px;border-radius:100px;white-space:nowrap;letter-spacing:.3px}.toolbar-right{display:flex;align-items:center;gap:10px}.filter-select{background:var(--bg);border:1px solid var(--border);border-radius:var(--rs);padding:7px 12px;color:var(--text);font-size:11px;font-family:var(--font);outline:none;cursor:pointer;transition:.2s;min-width:140px}.filter-select:focus{border-color:var(--accent)}.filter-active{display:flex;align-items:center;gap:10px;padding:8px 14px;background:#6d5cff0f;border:1px solid rgba(109,92,255,.12);border-radius:var(--rs);font-size:12px;color:var(--accent2);margin-bottom:16px}.filter-active strong{color:var(--text)}.confirm-dialog{text-align:center;padding:8px 0}.confirm-icon{font-size:40px;margin-bottom:12px}.confirm-dialog h3{font-size:17px;font-weight:600;margin-bottom:8px}.confirm-desc{font-size:13px;color:var(--text3);line-height:1.6;margin-bottom:4px}
