/* ============================================================
   谢毛毛AI工作室 · 高端编辑/画廊 · 明亮设计系统
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,500&family=DM+Mono:wght@400;500&display=swap');

:root{
  --paper:#f6f3ec;
  --paper-2:#fbf9f4;
  --card:#ffffff;
  --ink:#16140d;
  --ink-2:#3a362c;
  --soft:#605b4e;
  --muted:#938c7b;
  --faint:#bdb6a4;
  --line:#e6e1d4;
  --line-2:#d8d2c2;
  --accent:#2f5b43;       /* 深松绿 */
  --accent-soft:#5c8a6e;
  --accent-wash:#e9efe8;
  --clay:#b6603a;          /* 陶土,极少量点缀 */
  --serif:'Fraunces',Georgia,'Songti SC','SimSun',serif;
  --cjk-serif:'Songti SC','SimSun','Source Han Serif SC',serif;
  --sans:-apple-system,'PingFang SC','Microsoft YaHei',system-ui,sans-serif;
  --mono:'DM Mono',ui-monospace,monospace;
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative;
}
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(60vw 46vh at 84% -6%, rgba(47,91,67,.07), transparent 60%),
    radial-gradient(46vw 36vh at 4% 2%, rgba(182,96,58,.05), transparent 55%),
    linear-gradient(180deg,#f8f5ee,#f3efe6 70%);
}
body::after{ /* 极淡纸纹 */
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
::selection{background:var(--accent);color:#fff}
/* 后台公告条 */
.announce-bar{position:sticky;top:0;z-index:50;background:var(--accent);color:#fff;
  font-size:13.5px;padding:9px 44px 9px 18px;line-height:1.5;text-align:center}
.announce-bar b{font-weight:700;margin-right:6px}
.announce-bar .ad{opacity:.8;margin-left:8px;font-size:12px}
.announce-bar .ax{position:absolute;right:14px;top:50%;transform:translateY(-50%);cursor:pointer;font-size:18px;opacity:.85}
.announce-bar .ax:hover{opacity:1}
::-webkit-scrollbar{width:11px}
::-webkit-scrollbar-track{background:var(--paper)}
::-webkit-scrollbar-thumb{background:#d8d2c2;border-radius:8px;border:2px solid var(--paper)}
::-webkit-scrollbar-thumb:hover{background:#c4bda9}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px}
.mono{font-family:var(--mono)}
.kicker{font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent)}

/* ---------------- 顶栏 ---------------- */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px) saturate(1.4);
  background:rgba(246,243,236,.78);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-weight:600;font-size:21px;letter-spacing:-.01em}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);flex:0 0 auto}
.brand small{font-family:var(--mono);font-size:10px;color:var(--faint);letter-spacing:.2em;font-weight:400}
.nav-links{display:flex;gap:30px;align-items:center;font-size:14px;color:var(--soft)}
.nav-links a:hover{color:var(--accent)}
.nav-cta{font-family:var(--mono);font-size:12px;letter-spacing:.04em;padding:9px 18px;border:1px solid var(--ink);border-radius:999px;color:var(--ink);transition:.2s}
.nav-cta:hover{background:var(--ink);color:var(--paper-2)}

/* ---------------- Hero ---------------- */
.hero{padding:96px 0 56px;position:relative}
.hero .wrap{position:relative}
.hero-grid-line{position:absolute;inset:0;z-index:-1;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:58px 58px;mask-image:radial-gradient(68% 60% at 28% 24%,#000,transparent);opacity:.7}
.h-kicker{display:inline-flex;align-items:center;gap:10px;margin-bottom:26px}
.h-kicker .pulse{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(47,91,67,.4)}50%{opacity:.55;box-shadow:0 0 0 6px rgba(47,91,67,0)}}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(42px,6.6vw,88px);line-height:1.02;letter-spacing:-.025em;max-width:15ch;color:var(--ink)}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero h1 .u{position:relative;white-space:nowrap;font-style:normal;color:var(--accent)}
.hero h1 .u::after{content:"";position:absolute;left:0;right:0;bottom:.08em;height:.5em;background:rgba(182,96,58,.18);z-index:-1;border-radius:2px}
.hero p.sub{margin-top:30px;font-size:clamp(16px,1.7vw,19px);color:var(--soft);max-width:50ch;line-height:1.7}
.hero .meta{margin-top:32px;display:flex;gap:10px;flex-wrap:wrap}
.tagpill{font-family:var(--mono);font-size:12px;color:var(--soft);background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:7px 14px}
.tagpill b{color:var(--accent);font-weight:500}

/* ---------------- 搜索 ---------------- */
.searchbar{margin:48px 0 8px;position:relative;max-width:560px}
.searchbar input{width:100%;background:var(--card);border:1px solid var(--line-2);border-radius:14px;
  padding:17px 20px 17px 52px;color:var(--ink);font-family:var(--sans);font-size:15px;outline:none;transition:.2s;box-shadow:0 2px 20px -16px rgba(22,20,13,.4)}
.searchbar input::placeholder{color:var(--faint)}
.searchbar input:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(47,91,67,.1)}
.searchbar svg{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:var(--muted)}

/* ---------------- 区头 + 产品卡 ---------------- */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin:70px 0 28px;border-bottom:1px solid var(--line);padding-bottom:16px}
.sec-head h2{font-family:var(--serif);font-weight:500;font-size:32px;letter-spacing:-.02em}
.sec-head .count{font-family:var(--mono);font-size:12px;color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:24px;padding-bottom:96px}
.card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:18px;overflow:hidden;
  transition:.3s cubic-bezier(.2,.7,.3,1);display:flex;flex-direction:column;box-shadow:0 1px 2px rgba(22,20,13,.03)}
.card:hover{transform:translateY(-6px);border-color:var(--line-2);box-shadow:0 30px 60px -34px rgba(22,20,13,.28)}
.card-cover{height:178px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(130% 130% at 82% 6%, color-mix(in srgb,var(--cardacc,var(--accent)) 16%,transparent), transparent 56%),
    linear-gradient(180deg,#fcfbf7,#f4f1e8);
  border-bottom:1px solid var(--line)}
.card-cover .cov{width:100%;height:100%;object-fit:cover;object-position:left top;display:block}
.card:hover .card-cover .cov{transform:scale(1.03)}
.card-cover .cov{transition:transform .4s cubic-bezier(.2,.7,.3,1)}
.card-cover .mark{font-family:var(--serif);font-style:italic;font-weight:500;font-size:38px;color:var(--cardacc,var(--accent));opacity:.9;letter-spacing:-.02em;text-align:center;padding:0 18px}
.card-cover .scan{position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(0,0,0,.02) 1px,transparent 1px);background-size:14px 100%;opacity:.5}
.card-status{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  background:var(--card);border:1px solid var(--line-2);color:var(--accent);padding:4px 10px;border-radius:999px}
.card-body{padding:22px;display:flex;flex-direction:column;gap:11px;flex:1}
.card-body h3{font-family:var(--serif);font-weight:600;font-size:23px;letter-spacing:-.01em;display:flex;align-items:baseline;gap:9px}
.card-body h3 .lat{font-family:var(--mono);font-size:10px;color:var(--faint);letter-spacing:.12em;font-weight:400}
.card-body .desc{font-size:14px;color:var(--soft);line-height:1.6}
.card-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto;padding-top:8px}
.card-tags span{font-family:var(--mono);font-size:11px;color:var(--muted);border:1px solid var(--line);border-radius:6px;padding:3px 9px}
.card-foot{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-top:1px solid var(--line);background:var(--paper-2)}
.card-foot .price{font-family:var(--mono);font-size:13px;color:var(--muted)}
.card-foot .price b{font-family:var(--serif);font-size:22px;color:var(--ink);font-weight:600}
.card-foot .go{font-family:var(--mono);font-size:13px;color:var(--soft);display:flex;align-items:center;gap:6px}
.card:hover .card-foot .go{color:var(--accent)}
.card:hover .card-foot .go .arr{transform:translateX(3px)}
.card-foot .go .arr{transition:.2s}
.empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:70px 0;font-family:var(--mono);font-size:14px}

/* ---------------- 页脚 ---------------- */
.foot{border-top:1px solid var(--line);padding:48px 0 64px;color:var(--muted);font-size:13px;background:var(--paper-2)}
.foot .wrap{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.foot .mono{font-size:12px;color:var(--faint)}

/* ---------------- 进场动画 ---------------- */
.reveal{opacity:0;transform:translateY(16px);animation:rise .8s cubic-bezier(.2,.7,.3,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}

/* ================= 产品详情页 ================= */
.back{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:13px;color:var(--muted);margin:38px 0 6px}
.back:hover{color:var(--accent)}
.p-hero{padding:32px 0 18px;display:grid;grid-template-columns:1.1fr .9fr;gap:52px;align-items:center}
.p-hero .lat{font-family:var(--mono);font-size:12px;letter-spacing:.22em;color:var(--pacc,var(--accent))}
.p-hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(40px,5.4vw,68px);line-height:1.02;letter-spacing:-.03em;margin:16px 0 20px}
.p-hero .tl{font-size:20px;color:var(--soft);max-width:42ch;line-height:1.6}
.p-hero .tags{margin-top:24px;display:flex;gap:8px;flex-wrap:wrap}
.p-hero .tags span{font-family:var(--mono);font-size:12px;color:var(--muted);border:1px solid var(--line-2);border-radius:7px;padding:5px 12px}
.p-visual{aspect-ratio:4/3;border-radius:20px;border:1px solid var(--line-2);overflow:hidden;position:relative;
  background:radial-gradient(130% 130% at 76% 4%, color-mix(in srgb,var(--pacc,var(--accent)) 18%,transparent), transparent 55%),linear-gradient(180deg,#fcfbf7,#f3f0e7);
  display:flex;align-items:center;justify-content:center;box-shadow:0 30px 70px -40px rgba(22,20,13,.3)}
.p-visual.has-img{padding:0;background:#0e0c08}
.p-visual .cov{width:100%;height:100%;object-fit:cover;object-position:left top;display:block}
.p-visual .mark{font-family:var(--serif);font-style:italic;font-weight:500;font-size:54px;color:var(--pacc,var(--accent));letter-spacing:-.02em;text-align:center;padding:0 26px}
.p-visual .scan{position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(0,0,0,.02) 1px,transparent 1px);background-size:16px 100%;opacity:.5}
.p-visual .browser{position:absolute;top:0;left:0;right:0;height:36px;background:rgba(252,251,247,.7);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:7px;padding:0 14px}
.p-visual .browser i{width:9px;height:9px;border-radius:50%;background:var(--line-2);display:inline-block}

.summary{font-size:18px;color:var(--ink-2);line-height:1.85;max-width:74ch;margin:44px 0 8px;padding-left:20px;border-left:2px solid var(--pacc,var(--accent))}

.flow{display:flex;flex-wrap:wrap;gap:9px;align-items:center;margin:34px 0}
.flow .st{font-family:var(--sans);font-size:14px;background:var(--card);border:1px solid var(--line);border-radius:9px;padding:10px 14px;color:var(--ink-2);box-shadow:0 1px 2px rgba(22,20,13,.03)}
.flow .st b{font-family:var(--mono);color:var(--pacc,var(--accent));margin-right:7px;font-weight:500}
.flow .ar{color:var(--faint);font-family:var(--mono)}

.feats{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px;margin:18px 0 10px}
.feat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;transition:.22s;box-shadow:0 1px 2px rgba(22,20,13,.03)}
.feat:hover{border-color:var(--line-2);transform:translateY(-3px);box-shadow:0 20px 40px -28px rgba(22,20,13,.22)}
.feat .k{font-family:var(--serif);font-weight:600;font-size:18px;margin-bottom:8px;display:flex;align-items:center;gap:10px}
.feat .k::before{content:"";width:7px;height:7px;border-radius:2px;background:var(--pacc,var(--accent));transform:rotate(45deg)}
.feat .v{font-size:14px;color:var(--muted);line-height:1.65}

/* 界面预览画廊 */
.shots-gal{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,440px),1fr));gap:18px;margin:18px 0 10px}
.shot{margin:0;border:1px solid var(--line-2);border-radius:14px;overflow:hidden;background:#0e0c08;box-shadow:0 22px 50px -36px rgba(22,20,13,.35);transition:.28s cubic-bezier(.2,.7,.3,1)}
.shot:hover{transform:translateY(-5px);box-shadow:0 34px 64px -36px rgba(22,20,13,.45)}
.shot img{width:100%;display:block}

.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:24px 0 10px}
.plan{position:relative;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:30px 26px;display:flex;flex-direction:column;gap:16px;transition:.25s;box-shadow:0 1px 2px rgba(22,20,13,.03)}
.plan:hover{border-color:var(--line-2);transform:translateY(-4px);box-shadow:0 30px 60px -36px rgba(22,20,13,.26)}
.plan.pop{border-color:var(--pacc,var(--accent));box-shadow:0 0 0 1px var(--pacc,var(--accent)),0 34px 70px -40px color-mix(in srgb,var(--pacc,var(--accent)) 55%,transparent)}
.plan .badge{position:absolute;top:-12px;left:26px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;background:var(--pacc,var(--accent));color:#fff;font-weight:500;padding:5px 12px;border-radius:999px}
.plan .pn{font-family:var(--serif);font-weight:600;font-size:21px}
.plan .pp{display:flex;align-items:baseline;gap:5px}
.plan .pp .cur{font-family:var(--serif);font-size:20px;color:var(--soft)}
.plan .pp .num{font-family:var(--serif);font-weight:600;font-size:50px;letter-spacing:-.03em;line-height:1}
.plan .pp .un{font-family:var(--mono);font-size:12px;color:var(--muted)}
.plan .note{font-family:var(--mono);font-size:12px;color:var(--pacc,var(--accent))}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:14px;color:var(--ink-2)}
.plan ul li{display:flex;gap:10px;align-items:flex-start}
.plan ul li::before{content:"→";color:var(--pacc,var(--accent));font-family:var(--mono);flex:0 0 auto}
.buy{margin-top:auto;text-align:center;font-family:var(--mono);font-size:14px;padding:14px;border-radius:11px;border:1px solid var(--ink);
  color:var(--ink);cursor:pointer;transition:.2s;background:transparent;width:100%}
.buy:hover{background:var(--ink);color:var(--paper-2)}
.plan.pop .buy{background:var(--pacc,var(--accent));color:#fff;border-color:var(--pacc,var(--accent));font-weight:500}
.plan.pop .buy:hover{filter:brightness(1.08)}

.p-cta{margin:58px 0 84px;background:var(--ink);color:var(--paper-2);border-radius:20px;
  padding:42px 44px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.p-cta h3{font-family:var(--serif);font-weight:500;font-size:26px;color:var(--paper)}
.p-cta p{color:#b8b2a2;font-size:14px;margin-top:8px;max-width:46ch}
.btn-dl{font-family:var(--mono);font-size:14px;padding:14px 28px;border-radius:11px;background:var(--paper);color:var(--ink);font-weight:500}
.btn-dl.ghost{background:transparent;color:var(--paper-2);border:1px solid #4a463c}
.btn-dl:hover{filter:brightness(1.04)}

h2.block{font-family:var(--serif);font-weight:500;font-size:28px;letter-spacing:-.02em;margin:58px 0 8px}
h2.block .lab{font-family:var(--mono);font-size:12px;color:var(--faint);letter-spacing:.16em;margin-left:12px}

.modal{position:fixed;inset:0;z-index:100;background:rgba(22,20,13,.42);backdrop-filter:blur(5px);display:none;align-items:center;justify-content:center;padding:24px}
.modal.on{display:flex}
.modal .box{background:var(--card);border:1px solid var(--line-2);border-radius:18px;max-width:390px;width:100%;padding:32px;text-align:center;box-shadow:0 40px 80px -30px rgba(22,20,13,.4)}
.modal .box h4{font-family:var(--serif);font-weight:600;font-size:23px;margin-bottom:12px}
.modal .box p{color:var(--soft);font-size:14px;line-height:1.75}
.modal .box .x{margin-top:24px;font-family:var(--mono);font-size:13px;border:1px solid var(--ink);border-radius:9px;padding:11px 22px;cursor:pointer;color:var(--ink);transition:.2s}
.modal .box .x:hover{background:var(--ink);color:var(--paper-2)}

@media(max-width:860px){
  .p-hero{grid-template-columns:1fr;gap:28px}
  .plans{grid-template-columns:1fr}
  .nav-links{display:none}
}
