*{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%}body{color:#2b2a28;-webkit-font-smoothing:antialiased;background:#f5f1ea;font-family:-apple-system,PingFang SC,Microsoft YaHei,Helvetica Neue,Arial,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}img{max-width:100%;display:block}:root{--ink:#2b2a28;--paper:#f5f1ea;--paper-2:#ece5d8;--line:#d9cfba;--accent:#b34a3a;--accent-2:#1f4e4a;--muted:#7a7368}.app-shell{flex-direction:column;min-height:100%;display:flex}.site-header{border-bottom:1px solid var(--line);z-index:50;background:#fffaf0;position:sticky;top:0}.header-inner{align-items:center;gap:28px;max-width:1180px;margin:0 auto;padding:14px 24px;display:flex}.brand{align-items:baseline;gap:10px;display:flex}.brand-cn{letter-spacing:4px;color:var(--accent);border-left:4px solid var(--accent);padding-left:10px;font-size:26px;font-weight:800}.brand-en{letter-spacing:3px;color:var(--muted);text-transform:uppercase;font-size:11px}.nav{flex:1;gap:4px;display:flex}.nav a{color:#4a443c;border-radius:6px;padding:8px 16px;font-size:15px;transition:all .2s;position:relative}.nav a:hover{background:var(--paper-2);color:var(--ink)}.nav a.router-link-active{color:var(--accent);font-weight:600}.nav a.router-link-active:after{content:"";background:var(--accent);border-radius:2px;height:2px;position:absolute;bottom:-2px;left:16px;right:16px}.header-right{align-items:center;gap:12px;display:flex}.avatar{background:var(--paper-2);object-fit:cover;border:2px solid #fff;border-radius:50%;width:36px;height:36px;box-shadow:0 1px 4px #00000014}.avatar.lg{width:84px;height:84px}.avatar.sm{width:28px;height:28px}.btn{border:1px solid #0000;border-radius:6px;padding:8px 18px;font-size:14px;font-weight:500;transition:all .2s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#9a3e30}.btn-ghost{border-color:var(--line);color:var(--ink);background:0 0}.btn-ghost:hover{background:var(--paper-2)}.btn-block{width:100%;padding:12px;font-size:15px}main{flex:1;width:100%;max-width:1180px;margin:0 auto;padding:28px 24px 60px}.site-footer{text-align:center;color:var(--muted);border-top:1px solid var(--line);background:#fffaf0;padding:24px;font-size:13px}.hero{color:#fff;background:linear-gradient(135deg,#b34a3aeb,#1f4e4ad9),url(https://images.unsplash.com/photo-1499209974431-9dddcece7f88?auto=format&fit=crop&w=1600&q=60) 50%/cover;border-radius:12px;margin-bottom:32px;padding:60px 40px;position:relative;overflow:hidden}.hero h1{letter-spacing:6px;margin-bottom:12px;font-size:38px;font-weight:800}.hero p{opacity:.9;letter-spacing:2px;font-size:15px}.hero .tag{letter-spacing:2px;border:1px solid #ffffff80;border-radius:999px;margin-top:18px;padding:6px 14px;font-size:12px;display:inline-block}.section-title{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-title h2{letter-spacing:2px;border-left:4px solid var(--accent);padding-left:12px;font-size:22px}.section-title .sub{color:var(--muted);font-size:13px}.grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px;display:grid}.card{border:1px solid var(--line);background:#fff;border-radius:10px;flex-direction:column;transition:transform .25s,box-shadow .25s;display:flex;overflow:hidden}.card:hover{transform:translateY(-4px);box-shadow:0 10px 24px #3228141f}.card-cover{aspect-ratio:16/10;object-fit:cover;background:var(--paper-2);width:100%}.card-body{flex-direction:column;flex:1;padding:16px;display:flex}.card-cat{letter-spacing:2px;color:var(--accent);margin-bottom:8px;font-size:11px;font-weight:600}.card-title{color:var(--ink);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-bottom:8px;font-size:17px;font-weight:700;line-height:1.4;display:-webkit-box;overflow:hidden}.card-desc{color:var(--muted);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;flex:1;font-size:13px;display:-webkit-box;overflow:hidden}.card-meta{border-top:1px dashed var(--line);color:var(--muted);align-items:center;gap:8px;margin-top:14px;padding-top:12px;font-size:12px;display:flex}.auth-wrap{border:1px solid var(--line);background:#fff;border-radius:12px;max-width:420px;margin:40px auto;padding:36px 32px;box-shadow:0 8px 30px #32281414}.auth-wrap h2{letter-spacing:4px;text-align:center;color:var(--accent);margin-bottom:6px;font-size:24px}.auth-wrap .sub{text-align:center;color:var(--muted);letter-spacing:2px;margin-bottom:28px;font-size:13px}.field{margin-bottom:16px}.field label{color:#4a443c;margin-bottom:6px;font-size:13px;font-weight:500;display:block}.field input,.field textarea,.field select{border:1px solid var(--line);width:100%;color:var(--ink);background:#fdfaf3;border-radius:6px;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent);background:#fff;outline:none}.field textarea{resize:vertical;min-height:90px}.auth-foot{text-align:center;color:var(--muted);margin-top:18px;font-size:13px}.auth-foot a{color:var(--accent);font-weight:500}.error-msg{color:var(--accent);margin-bottom:10px;font-size:13px}.detail{border:1px solid var(--line);background:#fff;border-radius:12px;overflow:hidden}.detail-cover{object-fit:cover;background:var(--paper-2);width:100%;max-height:420px}.detail-body{padding:32px 36px}.detail-cat{letter-spacing:2px;color:var(--accent);margin-bottom:10px;font-size:12px;font-weight:600;display:inline-block}.detail-title{letter-spacing:1px;margin-bottom:14px;font-size:30px;font-weight:800;line-height:1.3}.detail-author{border-bottom:1px solid var(--line);color:var(--muted);align-items:center;gap:10px;margin-bottom:22px;padding-bottom:18px;font-size:13px;display:flex}.detail-author .name{color:var(--ink);font-weight:600}.detail-intro{background:var(--paper);border-left:4px solid var(--accent);color:#4a443c;border-radius:4px;margin-bottom:22px;padding:14px 18px;font-size:15px;font-style:italic}.detail-content{color:#3a3530;white-space:pre-wrap;font-size:16px;line-height:1.9}.comments{border:1px solid var(--line);background:#fff;border-radius:12px;margin-top:36px;padding:24px 28px}.comments h3{border-left:3px solid var(--accent);margin-bottom:18px;padding-left:10px;font-size:18px}.comment-form{align-items:flex-start;gap:12px;margin-bottom:24px;display:flex}.comment-form .input-wrap{flex:1}.comment-form textarea{resize:vertical;border:1px solid var(--line);background:#fdfaf3;border-radius:6px;width:100%;min-height:70px;padding:10px 12px;font-family:inherit;font-size:14px}.comment-form textarea:focus{border-color:var(--accent);background:#fff;outline:none}.comment-form .actions{justify-content:flex-end;margin-top:8px;display:flex}.comment-list{flex-direction:column;gap:18px;display:flex}.comment-item{border-bottom:1px dashed var(--line);gap:12px;padding-bottom:18px;display:flex}.comment-item:last-child{border-bottom:none;padding-bottom:0}.comment-body{flex:1}.comment-head{align-items:center;gap:10px;margin-bottom:4px;display:flex}.comment-head .name{font-size:14px;font-weight:600}.comment-head .time{color:var(--muted);font-size:12px}.comment-text{color:#3a3530;font-size:14px}.empty{color:var(--muted);text-align:center;padding:24px;font-size:14px}.profile-card{border:1px solid var(--line);background:#fff;border-radius:12px;align-items:center;gap:28px;margin-bottom:24px;padding:32px;display:flex}.profile-card .info h2{margin-bottom:4px;font-size:24px}.profile-card .info p{color:var(--muted);font-size:13px}.upload-btn{color:var(--accent);cursor:pointer;margin-top:8px;font-size:12px;display:inline-block}.upload-btn input{display:none}.fab{background:var(--accent);color:#fff;text-align:center;z-index:30;border-radius:50%;width:56px;height:56px;font-size:28px;line-height:56px;transition:transform .2s;position:fixed;bottom:32px;right:32px;box-shadow:0 8px 20px #b34a3a66}.fab:hover{transform:scale(1.08)}.modal-mask{z-index:100;background:#140f0a8c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:12px;width:100%;max-width:540px;max-height:90vh;padding:28px 32px;overflow-y:auto}.modal h3{border-left:3px solid var(--accent);margin-bottom:18px;padding-left:10px;font-size:20px}.modal-foot{justify-content:flex-end;gap:10px;margin-top:16px;display:flex}@media (width<=720px){.header-inner{flex-wrap:wrap;gap:12px;padding:12px 16px}.nav{order:3;width:100%;overflow-x:auto}.hero{padding:36px 24px}.hero h1{font-size:26px}.detail-body{padding:22px}.detail-title{font-size:22px}.profile-card{text-align:center;flex-direction:column}main{padding:18px 14px 40px}}
