:root{--bg:#f6f8fb;--primary:#0d1b2a;--accent:#ffb020;--muted:#6b7280}
*{box-sizing:border-box}
body{font-family:Inter,Arial,Helvetica,sans-serif;margin:0;background:var(--bg);color:#0b1720}
.hidden{display:none!important}

/* header */
.site-header{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background:#fff;position:sticky;top:0;z-index:1100}
.brand{display:flex;align-items:center;gap:12px}
.logo{width:64px;height:64px;object-fit:contain;border-radius:0;background:transparent;padding:0}
.brand-text h1{margin:0;font-size:18px}
.tag{font-size:12px;color:#6b7280;margin-top:4px}
.actions{position:relative}
.btn{padding:8px 12px;border-radius:8px;border:0;cursor:pointer;background:#fff;color:var(--primary)}

/* nav */
.nav-menu{display:flex;gap:20px;align-items:center;margin-left:16px;flex:0 1 auto}
.nav-item{text-decoration:none;font-size:15px;font-weight:500;color:#0d1b2a;position:relative;padding:6px 0;transition:color .2s}
.nav-item:hover{color:#00796b}
.nav-item.active{color:#00796b;font-weight:600}
.nav-item.active::after{content:"";position:absolute;bottom:-4px;left:0;width:100%;height:2px;background:#00796b;border-radius:2px}

/* ticker */
.ticker{display:flex;align-items:center;gap:8px;margin-left:24px;margin-right:12px;flex:1 1 520px;min-width:380px;max-width:640px}
.flame{font-size:18px;line-height:1}
.ticker-viewport{overflow:hidden;border-radius:999px;background:rgba(255,255,255,.55);border:1px solid rgba(13,27,42,.06);padding:6px 12px;width:100%}
.ticker-track{display:inline-block;white-space:nowrap;will-change:transform;animation:ticker-move 18s linear infinite}
.tick{margin-right:48px;opacity:.92}
@keyframes ticker-move{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* connect btn */
#connectBtn{background:linear-gradient(135deg,#06b6d4 0%,#22c55e 100%);color:#fff;font-weight:700;letter-spacing:.2px;padding:10px 16px;border-radius:999px;border:0;outline:0;cursor:pointer;box-shadow:0 8px 20px rgba(6,182,212,.28),inset 0 0 0 1px rgba(255,255,255,.25);transition:transform .15s,filter .15s,box-shadow .2s;will-change:transform,filter,box-shadow}
#connectBtn:hover{transform:translateY(-1px);filter:brightness(1.03);box-shadow:0 12px 26px rgba(6,182,212,.34),inset 0 0 0 1px rgba(255,255,255,.35)}
#connectBtn:active{transform:translateY(0);filter:brightness(.98)}
#connectBtn:focus-visible{box-shadow:0 0 0 3px rgba(34,197,94,.35),0 8px 20px rgba(6,182,212,.28)}

/* wallet menu */
.wallet-menu{position:absolute;right:0;top:calc(100% + 8px);min-width:240px;padding:6px 0;z-index:1200;background:rgba(13,27,42,.88);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);border-radius:12px;box-shadow:0 12px 40px rgba(2,6,23,.35);transform-origin:90% 0}
.wallet-menu::before{content:"";position:absolute;right:18px;top:-6px;width:12px;height:12px;transform:rotate(45deg);background:rgba(13,27,42,.88);border-left:1px solid rgba(255,255,255,.08);border-top:1px solid rgba(255,255,255,.08)}
.wallet-item{display:flex;align-items:center;gap:10px;cursor:pointer;padding:10px 14px;color:#e6f7ff;font-size:14px;transition:background .15s ease,transform .15s ease,opacity .15s ease}
.wallet-item:hover{background:rgba(255,255,255,.06)}
.wallet-item:active{transform:translateY(.5px)}
.wallet-item.disconnect{color:#ffb4b4}
.menu-divider{height:1px;margin:4px 10px;background:linear-gradient(90deg,transparent,#ffffff22,transparent)}
.wallet-icon{width:18px;height:18px;object-fit:contain;flex:0 0 18px}

/* banner */
.banner-wrap{position:relative;width:100%;height:280px;overflow:hidden;margin:0 auto;display:flex;justify-content:center;align-items:center;background:#f9fafb}
.banner-wrap .banner-img{width:100%;height:100%;object-fit:cover}
.banner-wrap::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.24) 0%,rgba(255,255,255,.06) 60%,rgba(255,255,255,0) 100%);pointer-events:none}
.banner-wrap::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 60%,rgba(0,0,0,.10) 100%);pointer-events:none}
.banner-copy{position:absolute;left:50%;bottom:86px;transform:translateX(-50%);margin-left:-200px;text-align:center;z-index:1;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.25)}
.banner-copy h2{margin:0 0 10px 0;font-size:28px;line-height:1.35;font-weight:800;letter-spacing:.2px}
.banner-copy p{margin:0;font-size:16px;line-height:1.5;opacity:.95}

/* container */
.container{max-width:1100px;margin:20px auto;padding:0 20px}

/* hero */
.hero{background:linear-gradient(90deg,#e6f2ff,#f7fbff);padding:32px 24px;border-radius:12px;margin-top:20px}
.hero .hero-head{text-align:center;margin-bottom:16px}
.hero .hero-head h2{margin:0 0 6px 0;font-size:22px}
.hero .hero-head .sub{margin:0;color:#556;font-size:14px}
.hero .featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;margin-top:14px}
.hero .work-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 10px 28px rgba(10,10,10,.06);display:flex;flex-direction:column}
.hero .work-card .cover{position:relative;width:100%;height:180px;background:#f1f5f9}
.hero .work-card .cover-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.hero .work-card .work-content{padding:12px;display:flex;flex-direction:column;gap:8px}
.hero .work-card h4{margin:0;font-size:16px}
.hero .work-card p{margin:0;color:#4b5563;font-size:14px}
.hero .work-meta{display:flex;gap:12px;align-items:center;color:#6b7280;font-size:12px}
.hero .work-card .btn{align-self:flex-start}
.hero .cover.demo.bg1{background:linear-gradient(135deg,#29c1b4,#6be3d1)}
.hero .cover.demo.bg2{background:linear-gradient(135deg,#7aa8ff,#b0c6ff)}
.hero .cover.demo.bg3{background:linear-gradient(135deg,#ff9aa2,#ffc3a0)}
.hero .cover.demo.bg4{background:linear-gradient(135deg,#c2e59c,#64b3f4)}
.hero .cover.demo.bg5{background:linear-gradient(135deg,#f6d365,#fda085)}
.hero .cover.demo.bg6{background:linear-gradient(135deg,#a18cd1,#fbc2eb)}

/* cards */
.info-cards{display:flex;gap:18px;margin-top:18px}
.card{flex:1;background:#fff;padding:16px;border-radius:10px;box-shadow:0 8px 20px rgba(10,10,10,.04)}

/* publish */
.publish-area{text-align:right;margin-top:12px}
.publish-form{max-width:760px;margin:18px auto;background:#fff;padding:18px;border-radius:12px;box-shadow:0 12px 36px rgba(10,10,10,.04)}
.publish-form input,.publish-form textarea{width:100%;padding:10px;margin-top:6px;border:1px solid #e6eef6;border-radius:8px}
.image-preview{margin-top:10px;width:100%;height:220px;border:2px dashed #e6eef6;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden}

/* tables & mine */
.leaderboard-section,.mine-section{margin-top:28px}
.table-wrap{overflow:auto;background:#fff;border-radius:12px;box-shadow:0 12px 28px rgba(10,10,10,.04)}
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th,.table td{padding:12px 14px;border-bottom:1px solid #eef2f7;text-align:left;white-space:nowrap}
.table th{background:#f8fafc;color:#475569}
.table tr:last-child td{border-bottom:none}
.note{color:#6b7280;font-size:12px;margin-top:8px}
.mine-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.mini-list{margin:8px 0 0 0;padding-left:18px;color:#374151;font-size:14px}

/* ip lists */
.upcoming-list .cards,.ip-list .cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;margin-top:12px}
.ip-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 10px 28px rgba(10,10,10,.06)}
.ip-card .cover{position:relative;width:100%;height:180px;background:#f1f5f9}
.ip-card .cover-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ip-card .content{padding:12px}
.ip-card .title{font-weight:700;margin-bottom:6px}
.ip-card .desc{color:var(--muted);margin-bottom:10px}
.ip-card .meta{font-size:12px;color:#9aa0a6}
.upcoming-list .progress{width:100%;height:8px;background:#eef2f7;border-radius:999px;overflow:hidden;margin:6px 0 8px}
.upcoming-list .progress .bar{height:100%;width:0;background:linear-gradient(90deg,#06b6d4,#22c55e);box-shadow:inset 0 0 0 1px rgba(255,255,255,.25);border-radius:999px;transition:width .4s ease}

/* footer */
.site-footer{text-align:center;padding:28px;color:#6b7280;margin-top:40px}

/* responsive */
@media(max-width:1180px){.ticker{flex:1 1 420px;min-width:320px;max-width:520px}}
@media(max-width:1024px){.ticker{display:none}}
@media(max-width:760px){.nav-menu{display:none}.info-cards{flex-direction:column}#connectBtn{padding:8px 12px}.banner-copy h2{font-size:22px}.banner-copy p{font-size:14px}}

/* optional CTA block */
.between-cta{max-width:1100px;margin:18px auto 0;padding:0 20px;text-align:right}
.between-cta .btn{display:inline-flex;align-items:center}
.btn.cta{color:#fff;font-weight:800;letter-spacing:.3px;padding:12px 18px;border-radius:999px;border:0;outline:0;cursor:pointer;transition:transform .15s,filter .15s,box-shadow .2s}
.btn.cta.alt{background:linear-gradient(135deg,#ef4444 0%, #f59e0b 100%);box-shadow:0 14px 34px rgba(239,68,68,.28),0 10px 24px rgba(245,158,11,.22),inset 0 0 0 1px rgba(255,255,255,.38)}
.btn.cta.alt:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn.cta .icon{width:20px;height:20px;margin-right:8px}

/* modal */
#modalBackdrop{position:fixed;inset:0;z-index:1300;background:rgba(0,0,0,.45)}
#modalBackdrop.hidden{display:none!important}
.publish-form.as-modal{position:fixed;z-index:1310;top:50%;left:50%;transform:translate(-50%,-50%);width:min(92vw,760px);max-height:85vh;overflow:auto;background:#fff;padding:18px 18px 14px;border-radius:14px;box-shadow:0 24px 64px rgba(2,6,23,.35)}
.publish-form.as-modal .form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}
.publish-form.as-modal .modal-close{position:absolute;right:10px;top:10px;border:none;background:#f3f4f6;color:#111827;width:28px;height:28px;border-radius:8px;cursor:pointer}

/* skeletons */
.ip-card.skeleton{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 10px 28px rgba(10,10,10,.06)}
.ip-card.skeleton .cover{height:180px;background:linear-gradient(90deg,#f2f4f7 25%,#e9eef5 37%,#f2f4f7 63%);background-size:400% 100%;animation:skel 1.2s ease-in-out infinite}
.ip-card.skeleton .content{padding:12px}
.ip-card.skeleton .line{height:14px;border-radius:6px;background:linear-gradient(90deg,#f2f4f7 25%,#e9eef5 37%,#f2f4f7 63%);background-size:400% 100%;animation:skel 1.2s ease-in-out infinite;margin-bottom:10px}
.ip-card.skeleton .line.title{width:60%;height:16px}
.ip-card.skeleton .line.desc{width:90%}
.ip-card.skeleton .line.meta{width:40%;height:12px;margin-bottom:0}
@keyframes skel{0%{background-position:100% 50%}100%{background-position:0 50%}}
#leaderboard .skel-row td{padding:0;border-bottom:none}
#leaderboard .tbl-skel{height:36px;border-radius:8px;margin:6px 8px;background:linear-gradient(90deg,#f2f4f7 25%,#e9eef5 37%,#f2f4f7 63%);background-size:400% 100%;animation:skel 1.2s ease-in-out infinite}

/* =========================
   FAB（最终修正版）
   —— 关键修正：按钮在容器内用 position: relative !important
   ========================= */

/* 容器：固定右下角，垂直排列 */
#fabArea{position:fixed;right:28px;bottom:28px;display:flex;flex-direction:column;align-items:flex-end;gap:24px;z-index:1400;pointer-events:none}
#fabArea>*{pointer-events:auto}

/* 复位旧定位，且让按钮成为伪元素定位上下文 */
#fabArea>#showPublishBtn,#fabArea>#rewardsLink{
  position: relative !important;   /* ←← 这里从 static 改为 relative */
  inset:auto!important;top:auto!important;right:auto!important;bottom:auto!important;left:auto!important;
  margin:0!important;isolation:isolate
}

/* 按钮基线 */
#fabArea>#showPublishBtn,#fabArea>#rewardsLink{
  width:64px;height:64px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 10px 20px rgba(0,0,0,.18);border:0;box-sizing:border-box;font-size:0;line-height:0;color:transparent;
  overflow:visible;z-index:1;transition:transform .12s ease,filter .12s ease
}
#fabArea>#showPublishBtn:hover,#fabArea>#rewardsLink:hover{transform:translateY(-1px);filter:brightness(1.03)}

/* 上：发布（绿） */
#fabArea>#showPublishBtn{background:#10B981}
#fabArea>#showPublishBtn:hover{background:#059669}

/* “+”图标（单行 data-url，绝对居中） */
#fabArea>#showPublishBtn::before{
  content:"";display:block;position:absolute;left:50%;top:50%;width:28px;height:28px;transform:translate(-50%,-50%);
  pointer-events:none;z-index:2;background-repeat:no-repeat;background-position:center;background-size:contain;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 24 24'><path d='M12 5v14M5 12h14' stroke='white' stroke-width='2.4' stroke-linecap='round'/></svg>")
}

/* 下：钱包（橙） */
#fabArea>#rewardsLink{background:#F59E0B;text-decoration:none}
#fabArea>#rewardsLink:hover{background:#D97706}

/* 钱包图标（单行 data-url，绝对居中） */
#fabArea>#rewardsLink::before{
  content:"";display:block;position:absolute;left:50%;top:50%;width:28px;height:28px;transform:translate(-50%,-50%);
  pointer-events:none;z-index:2;background-repeat:no-repeat;background-position:center;background-size:contain;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 24 24'><path d='M3 7h16a2 2 0 0 1 2 2v6a2 2 0 0 1-2 2H3V7z' fill='none' stroke='white' stroke-width='2.2' stroke-linejoin='round'/><path d='M16 12h4' stroke='white' stroke-width='2.2' stroke-linecap='round'/><path d='M3 7V6a2 2 0 0 1 2-2h10' stroke='white' stroke-width='2.2' stroke-linecap='round'/></svg>")
}

/* mobile */
@media(max-width:768px){
  #fabArea{right:18px;bottom:18px;gap:18px}
  #fabArea>#showPublishBtn,#fabArea>#rewardsLink{width:60px;height:60px;border-radius:16px}
  #fabArea>#showPublishBtn::before,#fabArea>#rewardsLink::before{width:26px;height:26px}
}

/* ========== mine 管理面板（追加样式，不覆盖你现有规则） ========== */
.mine-manage-box{background:#fff;border-radius:12px;padding:16px;margin-top:12px;
  box-shadow:0 6px 18px rgba(2,6,23,.06)}
.mgr-note{color:#6b7280;font-size:14px}
.mgr-error{color:#ef4444;font-size:14px}
.mgr-table{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.mgr-row{display:grid;grid-template-columns:80px 1fr 180px 100px 220px;gap:10px;
  align-items:center;padding:10px;border-bottom:1px dashed #e5e7eb}
.mgr-head{font-weight:600;color:#111827;border-bottom:2px solid #e5e7eb}
.mgr-btn{padding:6px 10px;border:0;border-radius:8px;cursor:pointer;font-size:13px;margin-right:8px;color:#fff}
.mgr-btn.ok{background:#10b981}
.mgr-btn.ok:hover{background:#059669}
.mgr-btn.danger{background:#ef4444}
.mgr-btn.danger:hover{background:#dc2626}
.mgr-btn.mute{background:#6b7280}
.mgr-btn.mute:hover{background:#4b5563}
@media (max-width: 900px){
  .mgr-row{grid-template-columns:60px 1fr 120px 90px 1fr}
}

