:root{--bg:#f7faf9;--paper:#fff;--ink:#101827;--muted:#667386;--line:#dfe7ea;--teal:#079b95;--teal-dark:#017f78;--teal-soft:#e1f7f5;--blue:#2b7be4;--orange:#f59e25;--purple:#8457e8;--shadow:0 14px 38px #0f172a14;--radius:8px;color:var(--ink);background:var(--bg);font-family:Inter,PingFang SC,Microsoft YaHei,Arial,sans-serif}*{box-sizing:border-box}body{background:radial-gradient(circle at 20% 0%, #089b950d, transparent 22%), var(--bg);min-width:1120px;margin:0;overflow-x:hidden}button,input,textarea,select{font:inherit}button{cursor:pointer;color:inherit;background:0 0;border:0}button:disabled{cursor:not-allowed;opacity:.55}input,textarea,select{border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);background:#fff;outline:none}input:focus,textarea:focus,select:focus{border-color:var(--teal);box-shadow:0 0 0 3px #079b951f}.public-header{z-index:20;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffeb;grid-template-columns:minmax(300px,.9fr) minmax(320px,1.1fr) minmax(280px,.9fr);align-items:center;height:76px;padding:0 clamp(28px,4vw,70px);display:grid;position:sticky;top:0}.public-header.article-header{grid-template-columns:minmax(280px,.9fr) minmax(300px,1.1fr) minmax(280px,.9fr)}.public-header.floating-header{border:1px solid var(--line);width:calc(100% - 20px);box-shadow:var(--shadow);border-radius:8px;margin:8px auto 18px;top:8px}.brand{text-align:left;align-items:center;gap:14px;display:flex}.brand-mark{color:#fff;background:linear-gradient(135deg,#08766f,#12b9b2);border-radius:10px;place-items:center;width:48px;height:48px;font-size:22px;font-weight:800;display:grid;box-shadow:0 10px 20px #079b9540}.brand-mark.has-logo{color:#0000;background-position:50%;background-repeat:no-repeat;background-size:cover}.brand strong{letter-spacing:0;font-size:24px;display:block}.brand small{color:var(--muted);margin-top:2px;display:block}.public-header nav{justify-content:center;gap:44px;height:100%;display:flex}.public-header.article-header nav{gap:34px}.public-header nav button{padding:0 6px;font-size:16px;position:relative}.public-header nav button.active{color:var(--teal-dark);font-weight:700}.public-header nav button.active:after{content:"";background:var(--teal);border-radius:3px;height:3px;position:absolute;bottom:6px;left:0;right:0}.mobile-bottom-nav{display:none}.header-tools{justify-content:flex-end;align-items:center;gap:14px;display:flex}.search-mini{border:1px solid var(--line);background:#fff;border-radius:8px;align-items:center;width:220px;height:38px;padding:0 12px;display:flex}.search-mini input{min-width:0;box-shadow:none;border:0;flex:1}.admin-search{width:min(360px,42vw);position:relative}.admin-search-panel{z-index:40;border:1px solid var(--line);max-height:360px;box-shadow:var(--shadow);background:#fff;border-radius:8px;gap:4px;padding:8px;display:grid;position:absolute;top:calc(100% + 8px);left:0;right:0;overflow:auto}.admin-search-panel button{text-align:left;border-radius:7px;gap:4px;padding:10px 12px;display:grid}.admin-search-panel button:hover{background:#eefaf8}.admin-search-panel b{color:#172033;font-size:14px}.admin-search-panel small,.admin-search-panel p{color:var(--muted);margin:0;font-size:12px}.round,.avatar{border:1px solid var(--line);background:#fff;border-radius:50%;place-items:center;display:grid}.round,.avatar.sm{width:42px;height:42px}.admin-entry-button{min-width:58px;height:38px;color:var(--teal-dark);background:#e9fbf8;border:1px solid #079b9552;border-radius:8px;padding:0 14px;font-weight:800}.admin-entry-button:hover{background:#dcf7f4;border-color:#079b9585}.avatar{color:#fff;aspect-ratio:1;background:radial-gradient(circle at 50% 34%,#f2c5a6 0 18%,#0000 19%),radial-gradient(circle at 50% 78%,#f4f7fb 0 30%,#0000 31%),linear-gradient(135deg,#1d4f7a,#9fd4e5);flex:none;font-weight:700;position:relative;overflow:hidden}.avatar:after{content:"";background:#1f2937;border-radius:50% 50% 35% 35%;height:16%;position:absolute;top:20%;left:26%;right:26%}.avatar{text-indent:-999px;text-shadow:none}.avatar.xs:after{display:none}.avatar.xs{text-indent:0;text-shadow:0 1px 2px #00000059;width:24px;height:24px;margin-right:8px;font-size:12px;display:inline-grid}.avatar.lg{width:74px;height:74px;margin:0 auto;font-size:24px}.author .avatar.author-photo{background-position:50% 28%;background-repeat:no-repeat;background-size:cover}.author .avatar.author-photo:after{display:none}.author .avatar.author-photo img{object-fit:cover;object-position:center 28%;width:100%;height:100%;display:block}.page{width:min(100% - 44px,1484px);margin:24px auto;padding:0}.home-landing{width:min(100% - 48px,1488px);margin:22px auto 54px;padding:0}.public-footer{color:#6b7a8d;flex-wrap:wrap;justify-content:center;align-items:center;gap:18px;width:min(100% - 48px,1488px);margin:0 auto 32px;padding:0;font-size:13px;display:flex}.public-footer a{color:inherit}.public-footer a:hover{color:var(--teal-dark)}.home-landing>.note{margin:0 0 14px}.home-hero-shell{min-height:clamp(560px,38vw,720px);box-shadow:var(--shadow);background:#fff;border:1px solid #cbdee2e6;border-radius:8px;place-items:center;display:grid;position:relative;overflow:hidden}.home-hero-blank{background-color:#0000;background-image:radial-gradient(circle at 14% 26%,#fffffff0 0 42px,#0000 43px),radial-gradient(circle at 88% 34%,#ffffffdb 0 64px,#0000 65px),linear-gradient(#c9f0fb 0%,#e8fbff 58%,#fff 100%);background-position:50%;background-repeat:repeat,repeat,repeat;background-size:cover;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;position:absolute;inset:0;overflow:hidden}.home-hero-blank.has-image{background-position:50%;background-repeat:no-repeat;background-size:cover}.home-hero-blank.has-video{background:#d8f5fb}.home-hero-video{object-fit:cover;transform-origin:50%;width:100%;height:100%;position:absolute;inset:0}.home-hero-overlay{z-index:1;pointer-events:none;background:#000;position:absolute;inset:0}.home-hero-blank:before,.home-hero-blank:after{content:"";filter:blur(.2px);background:#ffffffbd;border-radius:50%;position:absolute}.home-hero-blank:before{width:10px;height:10px;top:26%;left:18%;box-shadow:180px -70px #ffffff9e,420px 42px #ffffffad,710px -18px #ffffffb3,940px 72px #ffffffb8}.home-hero-blank:after{width:8px;height:8px;top:20%;right:16%;box-shadow:-160px 124px #ffffffb3,-420px -20px #ffffff9e,-620px 126px #ffffffa8}.home-hero-orbit{opacity:.75;border:1px solid #079b9529;border-radius:50%;width:260px;height:260px;position:absolute}.home-hero-orbit.one{bottom:86px;left:-80px}.home-hero-orbit.two{border-color:#2b7be41f;width:320px;height:320px;top:98px;right:-90px}.home-hero-horizon{background:linear-gradient(#cbeeb4c7,#ffffffeb);border-radius:50% 50% 0 0;height:230px;position:absolute;bottom:-82px;left:-4%;right:-4%}.home-hero-content{z-index:2;text-align:center;max-width:720px;padding:82px 24px 144px;position:relative}.home-hero-content h1{letter-spacing:0;color:#081827;margin:0;font-size:52px;line-height:1.18}.home-hero-subtitle{color:#173047;margin:18px 0 0;font-size:24px;font-weight:700}.home-hero-copy{color:#405669;max-width:620px;margin:20px auto 0;font-size:17px;line-height:1.9}.home-hero-actions{justify-content:center;gap:16px;margin-top:30px;display:flex}.home-primary-action,.home-secondary-action{border-radius:8px;justify-content:center;align-items:center;min-width:132px;min-height:48px;padding:0 24px;font-weight:800;display:inline-flex}.home-primary-action{color:#fff;background:linear-gradient(135deg, var(--teal), #02a7a0);box-shadow:0 14px 26px #079b9533}.home-secondary-action{color:var(--teal-dark);background:#ffffff9e;border:1px solid #079b956b}.home-entry-grid{z-index:2;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1280px;margin:-72px auto 0;padding:0 22px;display:grid;position:relative}.home-entry-card{text-align:left;background:#fffffff0;border:1px solid #dce6eaeb;border-radius:8px;grid-template-columns:64px 1fr;align-items:start;gap:20px;min-height:188px;padding:28px;transition:transform .18s,box-shadow .18s,border-color .18s;display:grid;box-shadow:0 18px 48px #0f172a14}.home-entry-card:hover{border-color:#079b9547;transform:translateY(-3px);box-shadow:0 24px 56px #0f172a1c}.home-entry-card b{color:#102033;margin-top:4px;font-size:22px;display:block}.home-entry-card small{color:#5c6c7e;margin-top:10px;line-height:1.75;display:block}.home-entry-card em{color:var(--teal-dark);margin-top:22px;font-style:normal;font-weight:800;display:inline-flex}.password-gate{text-align:center;gap:16px;width:min(720px,100vw - 48px);margin:72px auto;padding:34px;display:grid}.password-gate h1{letter-spacing:0;margin:0;font-size:32px}.password-gate p{color:var(--muted);margin:0;line-height:1.8}.password-gate .password-hint{color:#314359;font-weight:700}.password-gate form{grid-template-columns:minmax(0,1fr) auto;gap:10px;width:100%;max-width:460px;margin:0 auto;display:grid}.password-gate input{min-height:44px;padding:0 14px}.password-gate form button{color:#fff;background:var(--teal);border-radius:7px;min-height:44px;padding:0 18px;font-weight:800}.password-gate .text-link{color:var(--teal-dark);justify-self:center;font-weight:800}.home-entry-icon{width:56px;height:56px;color:var(--teal);background:#e7f8f6;border-radius:8px;place-items:center;display:grid;position:relative}.home-entry-icon:before{content:"";border:2px solid;border-radius:6px;width:24px;height:24px;display:block}.home-entry-icon.doc:after{content:"";background:currentColor;width:18px;height:2px;position:absolute;top:24px;left:19px;box-shadow:0 7px}.home-entry-icon.cube{color:#2b7be4;background:#eaf3ff}.home-entry-icon.cube:before{border-radius:5px;transform:rotate(45deg)}.home-entry-icon.user{color:#d97706;background:#fff2df}.home-entry-icon.user:before{border-radius:50%;width:24px;height:24px;box-shadow:0 20px 0 -4px}.home-quiet-panel{background:#ffffffe6;border:1px solid #dce6eae6;border-radius:8px;grid-template-columns:minmax(0,1fr) 430px;align-items:center;gap:28px;max-width:1236px;margin:28px auto 0;padding:28px 34px;display:grid;box-shadow:0 10px 34px #0f172a0d}.home-quiet-panel h2{margin:0 0 10px;font-size:24px}.home-quiet-panel p{color:#5a6b7c;margin:0;line-height:1.8}.home-mini-stats{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.home-mini-stats span{background:linear-gradient(135deg,#f5fbfc,#fff);border:1px solid #edf3f5;border-radius:8px;place-items:center;min-height:82px;display:grid}.home-mini-stats b{color:#102033;font-size:22px}.home-mini-stats small{color:#667386}.home.page{max-width:1420px;padding:0 28px}.two-col{grid-template-columns:minmax(0,1fr) 400px;gap:22px;display:grid}.home.two-col{grid-template-columns:minmax(0,1fr) 412px;gap:22px}.main-flow,.side-stack{flex-direction:column;gap:16px;display:flex}.card,.hero-card,.featured-card,.article-row,.paper,.message-form{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:#ffffffeb}.card{padding:18px}.card header,.title-row,.row-between{justify-content:space-between;align-items:center;gap:14px;display:flex}.card h3,.section-title{margin:0 0 14px;font-size:18px}.card header button,.link{color:var(--teal-dark)}.hero-card{background:linear-gradient(105deg,#eaf8f6,#fff 62%,#f5efe4);grid-template-columns:1fr 430px;align-items:center;height:226px;padding:36px 42px;display:grid;overflow:hidden}.home .hero-card{grid-template-columns:1fr 465px}.hero-card h1{margin:0 0 18px;font-size:30px}.hero-card p{color:#3e5266;font-size:17px;line-height:1.8}.chip-row,.tag-cloud,.skill-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.tag{color:#057a75;background:var(--teal-soft);white-space:nowrap;border-radius:7px;align-items:center;min-height:26px;padding:4px 12px;font-size:13px;display:inline-flex}.tag.green{color:#1e7b4d;background:#e7f5ec}.tag.orange{color:#91520b;background:#fff1dc}.tag.blue{color:#1769c2;background:#e8f2ff}.tag.purple{color:#6c41d8;background:#f0eaff}.tag.pink{color:#9b3348;background:#ffe8ec}.tag.gray{color:#435266;background:#eef2f5}.laptop-scene{background:url(/assets/home-hero-scene.png) 100%/cover no-repeat;align-self:stretch;height:auto;min-height:226px;margin:-36px -42px -36px 0;position:relative}.laptop-scene span,.laptop-scene:before,.laptop-scene:after{display:none}.section-title{margin:10px 0 0}.featured-card,.article-row{grid-template-columns:310px 1fr 100px;align-items:center;gap:24px;padding:14px;display:grid;position:relative}.featured-card h2,.article-row h3{margin:0 0 8px;font-size:21px}.featured-card p,.article-row p,.soft-text{color:#4a5b6c;line-height:1.8}.featured-card .chip-row{margin-top:10px}.article-row{box-shadow:none;grid-template-columns:180px 1fr 110px}.featured-card .art{height:162px}.article-row .art{height:110px}.article-row+.article-row{border-top:1px solid var(--line);border-radius:0}.meta{color:#7a8796;flex-wrap:wrap;gap:16px;margin-top:12px;font-size:13px;display:flex}.art{color:#fff;background:#102337;border-radius:7px;height:132px;padding:28px 22px;position:relative;overflow:hidden}.art.wide{height:140px}.art b{z-index:1;max-width:180px;font-size:26px;line-height:1.15;display:block;position:relative}.art span{z-index:1;opacity:.9;position:relative}.art-grid{background:radial-gradient(circle at 78%,#0000 0 34px,#20e0d7e6 35px 36px,#0000 37px),radial-gradient(circle at 80%,#089b9538,#0000 58px),repeating-linear-gradient(170deg,#0000 0 26px,#14d0c838 27px 29px);position:absolute;inset:0}.art.next .art-grid:after{content:"N";color:#fff;border:1px solid #5fe8e0;border-radius:50%;place-items:center;width:72px;height:72px;font-size:46px;display:grid;position:absolute;top:36px;right:46px}.art.wide.next .art-grid:after,.mini-list .art.next .art-grid:after{opacity:.75;width:52px;height:52px;font-size:32px;top:36px;right:24px}.art.docker{background:#073559}.art.docker .art-grid:after{content:"";opacity:.9;background-color:#0000;background-image:linear-gradient(#149bd7 0 0),linear-gradient(#149bd7 0 0),linear-gradient(#149bd7 0 0),linear-gradient(#149bd7 0 0),linear-gradient(#149bd7 0 0);background-position:0 0,22px 0,44px 0,11px 18px,33px 18px;background-repeat:no-repeat;background-size:18px 14px,18px 14px,18px 14px,18px 14px,18px 14px;background-attachment:scroll,scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box,border-box;width:84px;height:46px;position:absolute;top:42px;left:42px}.art.vue{color:#143d39;background:linear-gradient(135deg,#eff5f3,#dfe7e6)}.art.vue .art-grid:after{content:"V";color:#16a06e;font-size:78px;font-weight:900;position:absolute;top:24px;left:52px}.art.linux{background:#123b47}.art.linux .art-grid:after{content:"";background:radial-gradient(circle at 32% 24%,#fff 0 3px,#0000 4px),radial-gradient(circle at 68% 24%,#fff 0 3px,#0000 4px),linear-gradient(#111,#111);border-radius:50% 50% 42% 42%;width:46px;height:62px;position:absolute;bottom:18px;right:48px}.art.code{background:#102b34}.art.dashboard{color:#0f3048;background:#dceef4}.art.next,.art.docker,.art.vue,.art.linux,.art.custom-cover{background-position:50%;background-repeat:no-repeat;background-size:cover;padding:0}.art.next{background-image:url(/assets/thumb-next.png)}.art.docker{background-image:url(/assets/thumb-docker.png)}.art.vue{background-image:url(/assets/thumb-vue.png)}.art.linux{background-image:url(/assets/thumb-linux.png)}.art.next .art-grid,.art.docker .art-grid,.art.vue .art-grid,.art.linux .art-grid,.art.custom-cover .art-grid,.art.next b,.art.docker b,.art.vue b,.art.linux b,.art.custom-cover b,.art.next span,.art.docker span,.art.vue span,.art.linux span,.art.custom-cover span{display:none}.dots{text-align:center}.dots i{background:#c9d1d8;border-radius:50%;width:9px;height:9px;margin:0 6px;display:inline-block}.dots .on{background:var(--teal)}.search-box{grid-template-columns:1fr 54px;gap:10px;display:grid}.search-box input,.search-line input{height:42px;padding:0 14px}.search-box button,.primary,.message-form button,.author button,.subscribe button,.title-row button{background:linear-gradient(135deg, var(--teal), #02a7a0);color:#fff;border-radius:7px;padding:11px 18px;font-weight:700}.category-grid{grid-template-columns:1fr 1fr;gap:14px 26px;display:grid}.category-grid span{color:#314359;grid-template-columns:28px minmax(70px,1fr) 34px;align-items:center;gap:10px;display:grid}.category-grid span b{text-align:right;color:#344b68}.category-grid .icon{color:#058f88;background:#dff7f4;border-radius:9px;width:28px;height:28px;font-size:13px}.mini-list{flex-direction:column;gap:10px;display:flex}.mini-list button{text-align:left;grid-template-columns:76px 1fr;align-items:center;gap:12px;display:grid}.mini-list .art{height:56px;padding:10px}.mini-list .art b{font-size:12px}.mini-list small{color:var(--muted);margin-top:6px;display:block}.stat-grid,.about-stats,.admin-stats{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.stat-grid div,.about-stats div{text-align:center;background:linear-gradient(135deg,#f3f8ff,#fff);border-radius:7px;padding:18px 10px}.about-stats{grid-template-columns:repeat(2,1fr);gap:10px 12px}.about-stats div{text-align:left;white-space:pre-line;background:#fff;border:1px solid #eef2f4;align-items:center;min-height:66px;padding:14px 10px 10px 66px;line-height:1.25;display:flex;position:relative}.about-stats div:before{content:"";background-position:50%;background-repeat:no-repeat;background-size:contain;width:42px;height:42px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.about-stats div:first-child:before{background-image:url(/assets/about-stat-doc.png)}.about-stats div:nth-child(2):before{background-image:url(/assets/about-stat-folder.png)}.about-stats div:nth-child(3):before{background-image:url(/assets/about-stat-tag.png)}.about-stats div:nth-child(4):before{background-image:url(/assets/about-stat-comment.png)}.about-stats div:nth-child(5):before{background-image:url(/assets/about-stat-message.png)}.about-stats div:nth-child(6):before{background-image:url(/assets/about-stat-eye.png)}.stat-grid div{flex-direction:column;justify-content:center;align-items:center;gap:7px;min-height:132px;display:flex}.stat-grid .icon{border-radius:8px;width:34px;height:34px}.stat-grid span{color:#314359;word-break:keep-all;justify-content:center;align-items:center;min-height:34px;font-size:13px;line-height:1.25;display:flex}.stat-grid b{margin-top:0;font-size:24px;line-height:1.05;display:block}.article-layout{grid-template-columns:minmax(210px,.24fr) minmax(0,850px) minmax(280px,.34fr);align-items:start;gap:22px;width:min(100% - 36px,1504px);margin:20px auto;padding:0;display:grid}.mobile-toc{display:none}.toc{flex-direction:column;max-height:calc(100vh - 118px);display:flex;position:sticky;top:96px;overflow:hidden}.toc h3{flex:none;margin:0 0 12px}.toc-list{scrollbar-width:none;min-height:0;padding-right:2px;overflow-y:auto}.toc-list::-webkit-scrollbar{display:none}.toc-list button,.toc-top{color:#4e5c6a;text-align:left;cursor:pointer;-webkit-line-clamp:2;border-left:3px solid #0000;border-radius:0;-webkit-box-orient:vertical;width:100%;padding:8px 10px;line-height:1.45;display:-webkit-box;overflow:hidden}.toc-list button:hover,.toc-top:hover{color:var(--teal-dark);background:#f4fbfa}.toc-list button.active{color:var(--teal-dark);background:var(--teal-soft);border-color:var(--teal);font-weight:800}.toc-list .toc-level-3{color:#617083;padding-left:22px;font-size:14px}.toc-list .toc-level-3:before{content:"";vertical-align:2px;background:#b8c6ce;border-radius:50%;width:6px;height:6px;margin-right:7px;display:inline-block}.toc-top{color:var(--ink);-webkit-line-clamp:1;border-left-color:#0000;flex:none;margin-top:10px;display:block}.article-section{scroll-margin-top:96px}.paper{overflow:hidden}.cover{height:102px}.mountain{background:radial-gradient(circle at 78% 30%,#ffd697e6 0 28px,#0000 29px),linear-gradient(145deg,#0000 0 35%,#1f6055d9 36% 38%,#0000 39%),linear-gradient(160deg,#0000 0 43%,#2e7060b3 44% 47%,#0000 48%),linear-gradient(#b9d9d4 0%,#dcebdc 48%,#f3d6a4 100%)}.cover.mountain{background:url(/assets/article-cover.png) 50%/cover no-repeat}.cover-thumb.mountain{background:url(/assets/editor-cover.png) 50%/cover no-repeat}.paper-body{padding:20px 28px 28px}.paper h1{margin:0 0 12px;font-size:28px}.article-actions{flex-wrap:wrap;gap:10px;margin:16px 0 8px;display:flex}.article-actions button{border:1px solid var(--line);color:#314359;background:#fff;border-radius:7px;align-items:center;gap:8px;min-height:40px;padding:8px 14px;display:inline-flex}.article-actions button:hover:not(:disabled),.article-actions button.liked{color:var(--teal-dark);background:var(--teal-soft);border-color:#079b9559}.article-actions span{color:#fff;background:var(--teal);border-radius:50%;place-items:center;min-width:22px;height:22px;font-size:13px;line-height:1;display:inline-grid}blockquote,.note{color:#4f5c6c;background:#f2f4f8;border-radius:7px;padding:14px 18px}.note{background:#fff4df}pre{color:#c7f5e9;background:#111827;border-radius:7px;margin:14px 0;padding:18px;position:relative;overflow:auto}pre button{color:#fff;border:1px solid #526071;border-radius:6px;padding:5px 10px;position:absolute;top:10px;right:12px}.pager{grid-template-columns:1fr 1fr;gap:12px;margin:20px 0;display:grid}.pager button{border:1px solid var(--line);text-align:left;background:#fff;border-radius:7px;padding:14px}.article-related-bottom{border:1px solid var(--line);background:#fbfdfe;border-radius:8px;gap:14px;margin:30px 0;padding:22px;display:grid}.article-related-bottom h3{margin:0}.article-related-bottom>div{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.article-related-bottom button{text-align:left;background:#fff;border:1px solid #e4edf1;border-radius:7px;gap:6px;padding:14px;display:grid}.article-related-bottom button:hover{background:#f0fbf9;border-color:#079b9559}.article-related-bottom small{color:var(--muted)}.comment-input{grid-template-columns:44px 1fr 110px;align-items:start;gap:10px;display:grid}.comment-compose{border:1px solid var(--line);background:#fff;border-radius:7px;overflow:hidden}.comment-meta{border-bottom:1px solid var(--line);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.comment-meta input+input{border-left:1px solid var(--line)}.comment-meta input{width:100%;height:42px;box-shadow:none;border:0;padding:0 14px}.comment-compose>textarea{resize:vertical;width:100%;min-height:78px;box-shadow:none;border:0;border-radius:0;padding:12px 14px;line-height:1.75}.comment-tools{color:#667386;border-top:1px solid #edf2f4;flex-wrap:wrap;align-items:center;gap:8px 12px;min-height:40px;padding:6px 14px;font-size:13px;display:flex}.comment-tools small{white-space:nowrap;margin-left:auto}.emoji-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.emoji-row span{color:#536273;font-size:13px;font-weight:800}.emoji-row button{background:#fff;border:1px solid #e1eaee;border-radius:999px;place-items:center;width:30px;height:30px;font-size:15px;line-height:1;display:inline-grid}.emoji-row button:hover,.emoji-row button:focus-visible{background:#e9fbf8;border-color:#079b955c}.comment-input>button{background:var(--teal);color:#fff;border-radius:7px;height:40px}.comment-closed{color:#536273;background:#f6faf9;border:1px solid #dbe7ea;border-radius:7px;margin:10px 0;padding:14px 16px}.comment-thread{flex-direction:column;gap:10px;margin-top:12px;display:flex}.friendly-empty{color:var(--muted);text-align:center;background:#fbfefe;border:1px dashed #d5e5e6;border-radius:8px;justify-items:center;gap:6px;padding:22px 16px;display:grid}.friendly-empty b{color:#172033}.friendly-empty span{max-width:420px;line-height:1.7}.comment-row{color:#27384d;grid-template-columns:28px 1fr;gap:10px;display:grid}.comment-row p{margin:0 0 4px}.comment-row small{color:#667386;font-size:12px}.comment-reply{border-left:1px dashed #cbd8df;grid-template-columns:24px 1fr;gap:8px;margin-top:10px;padding-left:18px;display:grid}.list-count{color:var(--muted);text-align:center;margin:10px 0 0;font-size:13px}.load-more{border:1px solid var(--line);min-height:38px;color:var(--teal-dark);background:#fff;border-radius:7px;justify-content:center;align-items:center;margin:12px auto 0;padding:0 16px;font-weight:800;display:inline-flex}.load-more:hover:not(:disabled){background:#e9fbf8;border-color:#079b955c}.author{text-align:center}.author-stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);grid-template-columns:repeat(3,1fr);margin:16px 0;padding:12px 0;display:grid}.author-stats span{color:var(--muted);font-size:12px;font-weight:400;display:block}.ghost-purple{width:100%;color:var(--purple);background:#faf7ff;border:1px solid #dacdff;border-radius:7px;padding:10px}.rank-list li{color:#3d4b5b;margin:12px 0}.rank-list time{float:right;color:var(--muted)}.float-actions{gap:12px;display:grid;position:fixed;bottom:70px;left:38px}.float-actions button{border:1px solid var(--line);width:46px;height:46px;box-shadow:var(--shadow);background:#fff;border-radius:14px}.archive-layout{grid-template-columns:286px minmax(0,1fr);align-items:start;gap:28px;display:grid}.filter{box-shadow:none}.archive-category-panel{position:sticky;top:112px}.archive-category-panel p{color:#5f6f80;margin:-4px 0 16px;line-height:1.7}.filter button{color:#536273;text-align:left;border-radius:6px;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:11px 10px;display:flex}.filter button small{color:#7f8b98}.filter button.active{color:var(--teal-dark);background:#eef8f6;font-weight:700}.filter button.active small{color:var(--teal-dark)}.archive-main{gap:20px;min-width:0;display:grid}.archive-search-panel{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:#fffffff5;gap:10px;padding:18px 20px;display:grid}.archive-search-form{grid-template-columns:92px minmax(0,1fr);align-items:center;gap:12px;display:grid}.archive-search-form label{color:#25364a;font-weight:800}.archive-search-form div{grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;display:grid}.archive-search-form input{border-radius:7px;width:100%;height:44px;padding:0 14px}.archive-search-form button{color:#fff;background:linear-gradient(135deg, var(--teal), #02a7a0);white-space:nowrap;border-radius:7px;min-height:44px;padding:0 18px;font-weight:800}.archive-search-form button.ghost{color:var(--teal-dark);background:#f4fbfa;border:1px solid #079b954d}.archive-active-filter{color:var(--muted);flex-wrap:wrap;align-items:center;gap:8px 12px;margin:0 0 0 104px;font-size:13px;display:flex}.archive-active-filter b{color:var(--teal-dark)}.archive-active-filter span{color:#526273}.archive-hero{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:linear-gradient(120deg,#f1fbfa,#fff 58%,#f5fbff);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:24px;padding:34px 38px;display:grid}.archive-hero h1{letter-spacing:0;margin:0 0 10px;font-size:36px}.archive-hero p{color:#506174;max-width:680px;margin:0;line-height:1.85}.archive-hero button,.archive-result-head button{color:#fff;background:linear-gradient(135deg, var(--teal), #02a7a0);white-space:nowrap;border-radius:7px;min-height:44px;padding:0 18px;font-weight:800}.archive-featured-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.archive-featured-card{border:1px solid var(--line);border-radius:var(--radius);text-align:left;background:#fffffff0;grid-template-columns:178px minmax(0,1fr);gap:18px;min-height:156px;padding:14px;transition:transform .16s,border-color .16s,box-shadow .16s,background-color .16s;display:grid;box-shadow:0 12px 28px #0f172a0f}.archive-featured-card:hover,.archive-featured-card:focus-visible{background:#fff;border-color:#079b9594;transform:translateY(-4px);box-shadow:0 22px 46px #079b9524,0 14px 30px #0f172a1a}.archive-featured-card:focus-visible{outline-offset:2px;outline:3px solid #079b9533}.archive-featured-card .art{height:128px}.archive-featured-card span{align-content:start;gap:8px;min-width:0;display:grid}.archive-featured-card b{color:#132238;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:19px;line-height:1.35;display:-webkit-box;overflow:hidden}.archive-featured-card small{color:#526273;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.65;display:-webkit-box;overflow:hidden}.archive-featured-card mark{color:#0f766e;background:#d9fbf4;border-radius:4px;padding:0 3px}.archive-featured-card .archive-match{color:#435669;-webkit-line-clamp:3;background:#f6fffd;border:1px solid #e2f1ef;border-radius:7px;padding:8px 10px}.archive-featured-card em{color:#7a8796;font-size:13px;font-style:normal}.archive-pagination{border:1px solid var(--line);background:#fff;border-radius:8px;justify-content:center;align-items:center;gap:14px;margin-top:20px;padding:16px;display:flex}.archive-pagination button{border:1px solid var(--line);min-height:38px;color:var(--teal-dark);background:#fff;border-radius:7px;padding:0 16px;font-weight:800}.archive-pagination button:not(:disabled):hover{background:#e9fbf8;border-color:#079b9566}.archive-pagination span{color:#536477;font-weight:700}.archive-sort-toolbar{min-height:44px;color:var(--muted);justify-content:flex-end;align-items:center;gap:8px;padding:4px 0;display:flex}.archive-sort-toolbar span{margin-right:2px;font-size:13px;font-weight:800}.archive-sort-toolbar button{border:1px solid var(--line);color:#526273;background:#fff;border-radius:7px;min-width:64px;min-height:36px;padding:0 14px;font-weight:800}.archive-sort-toolbar button.active{color:#fff;border-color:var(--teal);background:var(--teal);box-shadow:0 10px 22px #079b952e}.archive-empty-state{border-radius:var(--radius);color:var(--muted);text-align:center;background:#ffffffe0;border:1px dashed #079b9559;justify-items:center;gap:10px;padding:44px 24px;display:grid}.archive-empty-state h3{color:#172033;margin:0;font-size:20px}.archive-empty-state p{max-width:460px;margin:0;line-height:1.75}.archive-empty-state button{color:#fff;background:var(--teal);border-radius:7px;min-height:42px;margin-top:6px;padding:0 18px;font-weight:800}.archive-result-panel{gap:14px;margin-top:4px;display:grid}.archive-result-head{border:1px solid var(--line);border-radius:var(--radius);background:#fff;justify-content:space-between;align-items:center;gap:18px;padding:18px 22px;display:flex}.archive-result-head h2{margin:0 0 4px;font-size:22px}.archive-result-head p{color:var(--muted);margin:0}.tabs{align-items:center;gap:10px;margin:22px 0;display:flex}.tabs button{background:#eef1f3;border-radius:7px;padding:10px 18px}.tabs button.active{background:var(--teal);color:#fff}.tabs span{color:var(--muted);margin-left:auto}.timeline{border-left:2px solid #52c5bd;padding-left:34px;position:relative}.year-badge{background:var(--teal);color:#fff;border-radius:18px;align-items:center;gap:12px;margin:10px 0;padding:8px 16px;font-size:20px;font-weight:800;display:inline-flex}.year-badge small{font-size:13px;font-weight:400}.month{grid-template-columns:76px 1fr;gap:20px;margin:12px 0;display:grid}.month-label{text-align:center;color:#785314}.month-label b{background:#fff1d8;border-radius:8px;padding:6px 12px;display:inline-block}.month-label span{color:#516174;margin-top:10px;display:block}.month-card{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;padding:16px 22px}.archive-item{border-bottom:1px solid var(--line);grid-template-columns:1fr auto;gap:6px 18px;padding:12px 0 12px 20px;display:grid;position:relative}.archive-item:before{content:"";background:#9aa8b5;border-radius:50%;width:6px;height:6px;position:absolute;top:20px;left:2px}.archive-item small{color:var(--muted)}.archive-item span{grid-row:1/span 2;align-self:center;align-items:center;gap:8px;display:flex}.subscribe{background:#fffaf0;border-color:#f5dcab}.subscribe input{width:100%;height:40px;margin:10px 0;padding:0 12px}.subscribe button{width:100%}.subscribe button:disabled{opacity:.55;cursor:not-allowed}.empty{text-align:center;color:var(--muted)}.about-layout{grid-template-columns:1fr 430px;gap:18px;display:grid}.profile{grid-template-columns:minmax(210px,30%) 1fr;grid-template-areas:"portrait text";align-items:stretch;gap:18px 40px;display:grid}.portrait{aspect-ratio:4/5;object-fit:cover;object-position:center 30%;background:#eef3f5;border:1px solid #e1e8ed;border-radius:8px;grid-area:portrait;width:100%;max-width:280px;min-height:320px;margin:0 auto;box-shadow:0 14px 30px #10203314}.profile-text{border-left:1px solid var(--line);grid-area:text;padding-left:42px}.profile-text h1{font-size:34px}.profile-text p{line-height:1.9}.contact{color:#536273;flex-wrap:wrap;gap:10px 16px;margin-top:22px;display:flex}.contact span{color:#536273;align-items:center;gap:6px;min-height:24px;display:inline-flex}.skill-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.skill-chip{color:#172033;background:#fff;border:1px solid #e7eef2;border-radius:6px;align-items:center;gap:5px;min-height:24px;padding:3px 6px;font-size:13px;font-weight:700;display:inline-flex;box-shadow:0 3px 8px #0f172a08}.skill-chip b{width:16px;height:16px;color:var(--teal-dark);background:#e8f7f5;border-radius:5px;justify-content:center;align-items:center;font-size:8px;font-weight:900;display:inline-flex}.socials button{border:1px solid var(--line);background:#fff;border-radius:8px;padding:10px 18px}.about-socials{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.about-socials button{color:#27364a;align-content:center;justify-items:center;gap:8px;min-height:82px;padding:12px 10px;font-weight:800;display:grid}.about-socials button:hover{background:#f4fbfa;border-color:#079b9559;transform:translateY(-1px)}.social-icon{border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:900;display:inline-flex}.github-icon{color:#111827;background:#f3f6f8}.wechat-icon{color:#fff;background:#18bf62}.project-grid{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}.project-grid article{border:1px solid var(--line);border-radius:var(--radius);padding-bottom:14px;overflow:hidden}.project-grid h4,.project-grid p,.project-grid div,.project-grid small{margin-left:14px;margin-right:14px}.project-grid p{color:#536273;min-height:54px;line-height:1.6}.project-grid div:not(.art){flex-wrap:wrap;gap:6px;display:flex}.project-grid article .art{background-position:50%;background-repeat:no-repeat;background-size:cover;height:144px;padding:0}.project-grid article .art>*{display:none}.project-grid article .project-cover{position:relative}.project-grid article .project-cover img{object-fit:cover;width:100%;height:100%;display:block}.project-grid article .project-cover img,.project-grid article .project-cover>span{display:block}.project-grid article .project-cover>span{color:#fff;background:var(--teal);border-radius:6px;padding:5px 8px;font-size:12px;font-weight:800;display:inline-flex;position:absolute;top:10px;left:10px}.project-grid article:first-child .art{background-image:url(/assets/about-project-blogcore.png)}.project-grid article:nth-child(2) .art{background-image:url(/assets/about-project-plando.png)}.project-grid article:nth-child(3) .art{background-image:url(/assets/about-project-devnote.png)}.cooperate{border:1px solid var(--line);background:linear-gradient(90deg,#eefaf9,#fff);border-radius:8px;grid-template-columns:180px 1fr 140px;align-items:center;gap:20px;margin-top:28px;padding:20px;display:grid}.cooperate span{color:#0000;text-align:center;background:url(/assets/about-cooperate-art.png) 50%/contain no-repeat;height:72px;font-size:0}.cooperate button{color:#fff;background:var(--teal);border-radius:7px;padding:13px}.intro-line{gap:14px;display:grid}.intro-line p{border-left:2px solid #96d6d0;grid-template-columns:64px 1fr;gap:2px 14px;margin:0;padding-left:18px;display:grid;position:relative}.intro-line p:before{content:"";background:var(--teal);border-radius:50%;width:8px;height:8px;position:absolute;top:11px;left:-5px}.intro-line b{width:52px;color:var(--teal-dark);text-align:center;background:#e8f7f5;border-radius:999px;grid-row:1/span 2;align-self:start;padding:7px 0}.intro-line span{color:#172033;font-weight:800}.intro-line small{color:var(--muted);line-height:1.6}.message-title{justify-content:space-between;align-items:center;margin:20px 0 8px;display:flex}.message-title h1{align-items:center;gap:14px;margin:0;font-size:36px;display:flex}.message-title-icon{border:3px solid #0f172a;border-radius:8px;flex:none;width:42px;height:34px;position:relative}.message-title-icon:before{content:"";background:var(--bg);border-bottom:3px solid #0f172a;border-left:3px solid #0f172a;width:12px;height:12px;position:absolute;bottom:-10px;left:8px;transform:skew(-20deg)}.message-title-icon:after{content:"";background:#6b7280;border-radius:3px;height:3px;position:absolute;top:9px;left:8px;right:8px;box-shadow:0 7px #6b7280}.message-title span{color:var(--teal-dark)}.message-form{padding:22px}.form-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.message-form label{color:#334155;gap:10px;font-weight:600;display:grid}.message-form input{height:46px;padding:0 14px}.message-form textarea{resize:vertical;min-height:120px;padding:14px}.message-form footer{align-items:center;gap:16px;display:flex}.message-form footer small{color:var(--muted);margin-left:auto}.message-compose-tools .emoji-row{flex:auto}.message-compose-tools>button{flex:none}.message-form button:disabled{opacity:.58;cursor:not-allowed}.form-notice{color:#9f2f24;background:#fff7f6;border:1px solid #f4c7c3;border-radius:7px;margin:10px 0 0;padding:10px 12px;font-size:13px}.message-tabs{border-bottom:1px solid var(--line);align-items:center;gap:28px;display:flex}.message-tabs button{color:#536273;padding:14px 0}.message-tabs button.active{color:var(--teal-dark);border-bottom:3px solid var(--teal)}.message-tabs b{background:#eef3f3;border-radius:12px;padding:3px 8px}.message-tabs select{height:40px;margin-left:auto;padding:0 12px}.message-item{box-shadow:none;grid-template-columns:56px 1fr;gap:14px;display:grid;position:relative}.message-list>.message-item:before{content:"";border-left:1px dashed #d6e1e5;position:absolute;top:82px;bottom:22px;left:45px}.message-item>.avatar{width:56px;height:56px}.message-list>.message-item:first-child>.avatar{background:url(/assets/message-avatar-user1.png) 50%/cover no-repeat}.message-list>.message-item:first-child .message-item:first-of-type>.avatar{background:url(/assets/message-avatar-admin.png) 50%/cover no-repeat}.message-list>.message-item:first-child .message-item:nth-of-type(2)>.avatar{background:url(/assets/message-avatar-user1.png) 50%/cover no-repeat}.message-list>.message-item:nth-child(2)>.avatar{background:url(/assets/message-avatar-user2.png) 50%/cover no-repeat}.message-item .message-item{background:#fffdf8;border-color:#f0d49a;margin-top:18px}.message-item .message-item:before{content:"";border-top:1px dashed #d6e1e5;width:28px;position:absolute;top:31px;left:-38px}.message-item .message-item>.avatar{width:48px;height:48px}.message-item h3{margin:0}.message-item .approved{color:#2d9b50;background:#eaf8ee;border-radius:6px;padding:5px 10px;position:absolute;top:56px;right:18px}.rule-card{background:linear-gradient(135deg,#f4fffe,#fff);border-color:#bfe4df}.comment-mini p{color:#526273;line-height:1.5}.message-page .author .avatar.lg{background-position:50% 28%;background-repeat:no-repeat;background-size:cover;width:84px;height:84px}.message-page .author .avatar.author-photo:after{display:none}.message-page .comment-mini p:first-child .avatar{background:url(/assets/message-comment-1.png) 50%/cover no-repeat}.message-page .comment-mini p:nth-child(2) .avatar{background:url(/assets/message-comment-2.png) 50%/cover no-repeat}.message-page .comment-mini p:nth-child(3) .avatar{background:url(/assets/message-comment-3.png) 50%/cover no-repeat}.message-page .comment-mini p:nth-child(4) .avatar{background:url(/assets/message-comment-4.png) 50%/cover no-repeat}.login-page{background:radial-gradient(circle at 10% 48%,#5f5bff14,#0000 16%),#fbfcfd;grid-template-columns:minmax(0,1fr) minmax(360px,500px);justify-content:center;align-items:center;gap:clamp(32px,5vw,72px);min-height:100vh;padding:clamp(28px,4vw,44px);display:grid;overflow-x:hidden}.login-copy{min-width:0;max-width:760px}.login-copy h1{margin:12px 0;font-size:50px}.path{color:#4e55e8;font-size:22px;font-weight:800}.feature-row{grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px);margin:40px 0;display:grid}.feature-row span{min-width:0;padding-left:60px;font-weight:700;display:block;position:relative}.feature-row span:before{content:"";background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:11px;width:52px;height:52px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.feature-row span:first-child:before{background-image:url(/assets/login-feature-site.png)}.feature-row span:nth-child(2):before{background-image:url(/assets/login-feature-security.png)}.feature-row span:nth-child(3):before{background-image:url(/assets/login-feature-manage.png)}.feature-row small{color:var(--muted);font-weight:400;display:block}.dashboard-preview{border:1px solid var(--line);max-width:760px;box-shadow:var(--shadow);background:#fff;border-radius:10px;grid-template-columns:150px 1fr;padding:16px;display:grid;position:relative}.dashboard-preview:after{content:"最新文章\a \a 如何搭建一个高性能的个人博客系统      05-13\a 使用 Markdown 写作的最佳实践      05-12\a 从 0 到 1 设计一个评论系统      05-11";white-space:pre-line;border:1px solid var(--line);width:230px;min-height:152px;box-shadow:var(--shadow);color:#344357;background:#fffffff5;border-radius:8px;padding:18px;font-size:13px;line-height:1.8;position:absolute;top:34px;right:-86px}.dashboard-preview aside{color:#526273;flex-direction:column;gap:14px;display:flex}.dashboard-preview .stat-grid{grid-template-columns:repeat(4,1fr)}.chart-line{background:linear-gradient(#0000,#eef4f6),linear-gradient(160deg,#0000 0 20%,#4285ff 21% 23%,#0000 24% 45%,#0fa7a0 46% 48%,#0000 49%);border-radius:8px;height:120px;margin-top:14px}.dashboard-preview{max-width:100%;height:294px;box-shadow:none;background:url(/assets/login-preview.png) 0/contain no-repeat;border:0;border-radius:14px;padding:0;display:block}.dashboard-preview:after,.dashboard-preview>*{display:none}.security-tip,.warning{color:#7b4d12;background:#fff7ea;border:1px solid #f1cc91;border-radius:8px;margin-top:56px;padding:18px 20px 18px 58px;line-height:1.6;position:relative}.security-tip:before,.warning:before{content:"";background:#fff1d8;border-radius:50%;width:30px;height:30px;position:absolute;top:50%;left:18px;transform:translateY(-50%);box-shadow:inset 0 0 0 1px #f0c57d}.security-tip:after,.warning:after{content:"🔒";font-size:15px;position:absolute;top:50%;left:25px;transform:translateY(-52%)}.login-card{border:1px solid var(--line);min-height:clamp(620px,100vh - 88px,760px);box-shadow:var(--shadow);background:#fff;border-radius:18px;flex-direction:column;gap:18px;padding:clamp(36px,4vw,58px) clamp(32px,5vw,70px);display:flex}.login-card .brand-mark{color:#0000;width:66px;height:66px;box-shadow:none;background:url(/assets/login-card-logo.png) 50%/cover no-repeat;margin:0 auto}.login-card h2{text-align:center;margin:0;font-size:34px}.login-card p{text-align:center;color:var(--muted)}.login-card input{height:54px;padding:0 16px}.login-card>label:first-of-type input{background-image:url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='12' cy='8' r='4' stroke='%2396A0AC' stroke-width='2'/%3E%3Cpath d='M4 21c1.6-4.4 4.2-6.5 8-6.5s6.4 2.1 8 6.5' stroke='%2396A0AC' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");background-position:16px;background-repeat:no-repeat;background-size:20px 20px;padding-left:46px}.login-card>label:nth-of-type(2) input{background-image:url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='5' y='10' width='14' height='10' rx='2' stroke='%2396A0AC' stroke-width='2'/%3E%3Cpath d='M8 10V7a4 4 0 0 1 8 0v3' stroke='%2396A0AC' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");background-position:16px;background-repeat:no-repeat;background-size:20px 20px;padding-left:46px}.login-card label{gap:10px;font-weight:700;display:grid}.password-field{grid-template-columns:minmax(0,1fr) auto;gap:8px;display:grid}.password-field input{width:100%}.password-field button{border:1px solid var(--line);min-height:40px;color:var(--teal-dark);background:#fff;border-radius:7px;padding:0 12px;font-weight:800}.password-field button:hover{background:#e9fbf8;border-color:#079b9559}.check{grid-template-columns:20px 1fr;align-items:center;font-weight:400!important;display:flex!important}.check input{height:auto}.divider{color:#96a0ac;justify-content:center;align-items:center;gap:14px;display:flex}.divider:before,.divider:after{content:"";background:var(--line);flex:1;height:1px}.ghost{border:1px solid var(--line);background:#fff;border-radius:8px;height:48px}.admin-app{background:#f7faf9;grid-template-columns:216px minmax(0,1fr);min-height:100vh;display:grid}.admin-editor-app{grid-template-columns:190px 1fr}.admin-main{min-width:0}.admin-mobile-bar,.admin-mobile-backdrop{display:none}.admin-side{border-right:1px solid var(--line);background:#fff;flex-direction:column;height:100vh;padding:18px 10px;display:flex;position:sticky;top:0}.admin-side .brand strong{font-size:20px}.admin-side .brand small{font-size:12px}.admin-side nav{flex-direction:column;gap:8px;margin-top:28px;display:flex}.admin-side nav button{color:#2f3d4d;border-radius:7px;justify-content:space-between;align-items:center;height:46px;padding:0 14px;display:flex}.admin-side nav button.active{color:var(--teal-dark);background:linear-gradient(90deg,#dff6f3,#eefbf9);font-weight:800}.admin-side nav small{color:#738092;background:#eef2f4;border-radius:12px;min-width:24px;padding:3px 7px}.admin-user{border:1px solid var(--line);border-radius:8px;align-items:center;gap:10px;margin-top:auto;padding:12px;display:flex}.admin-user small{color:var(--muted);display:block}.admin-top{border-bottom:1px solid var(--line);background:#fff;grid-template-columns:1fr 330px 42px 42px;align-items:center;gap:18px;height:66px;padding:0 28px;display:grid}.bell{border-radius:50%;width:42px;height:42px;position:relative}.bell b{color:#fff;background:#ef4444;border-radius:12px;padding:1px 5px;font-size:12px;position:absolute;top:0;right:0}.admin-content{background:#f5f8fb;grid-template-columns:minmax(0,1.35fr) minmax(260px,.86fr) minmax(280px,1fr);align-items:start;gap:16px;min-width:0;padding:22px 28px 32px;display:grid}.title-row,.admin-stats{grid-column:1/-1}.title-row{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.title-row h1{color:#172033;letter-spacing:0;margin:0;font-size:24px;line-height:40px}.title-row button{color:#fff;background:linear-gradient(135deg, var(--teal), #029a93);border:0;border-radius:7px;align-items:center;height:40px;padding:0 18px;display:inline-flex;box-shadow:0 10px 18px #009a932e}.title-actions{flex-wrap:wrap;align-items:center;gap:8px;display:inline-flex}.title-actions button{border:1px solid var(--line);color:#314359;background:#fff}.title-actions button:first-child{color:#fff;background:linear-gradient(135deg, var(--teal), #02a7a0);border-color:#0000}.admin-hint{color:#536273;background:#f6faf9;border:1px solid #dbe7ea;border-radius:7px;grid-column:1/-1;margin:-6px 0 4px;padding:10px 12px}.media-upload-strip{align-items:center;gap:12px;display:flex}.media-upload-strip button{background:var(--teal);color:#fff;cursor:pointer;border:0;border-radius:7px;padding:9px 14px;font-weight:700}.media-upload-strip button:disabled{opacity:.62;cursor:not-allowed}.media-upload-strip span{color:#55706f}.media-filter-bar,.moderation-filter-bar{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:auto minmax(220px,1fr) auto;align-items:center;gap:10px;padding:12px;display:grid}.media-type-tabs{background:#f2f6f7;border-radius:8px;gap:6px;padding:4px;display:inline-flex}.media-type-tabs button,.media-clear-filter{color:#536273;border-radius:7px;min-height:34px;padding:0 12px;font-weight:800}.media-type-tabs button.active{color:#fff;background:var(--teal)}.media-filter-bar input,.moderation-filter-bar input{border-radius:7px;width:100%;height:38px;padding:0 12px}.media-clear-filter{border:1px solid var(--line);color:var(--teal-dark);background:#fff}.admin-stats{grid-template-columns:repeat(5,minmax(0,1fr));gap:15px}.admin-stat{text-align:center;background:#fff;border:1px solid #e5edf1;border-radius:10px;grid-template-rows:54px 20px 36px 22px;align-content:center;place-items:center;gap:3px;min-height:128px;padding:16px 18px 18px;display:grid;box-shadow:0 10px 26px #263f530d}.admin-stat .icon{width:54px;height:54px;box-shadow:none;background-color:#0000;background-position:50%;background-repeat:no-repeat;background-size:64px 64px;grid-row:1}.admin-stat .icon:before{display:none}.admin-stats .admin-stat:first-child .icon{background-image:url(/assets/dashboard-stat-doc.svg)}.admin-stats .admin-stat:nth-child(2) .icon{background-image:url(/assets/dashboard-stat-eye.svg)}.admin-stats .admin-stat:nth-child(3) .icon{background-image:url(/assets/dashboard-stat-chat.svg)}.admin-stats .admin-stat:nth-child(4) .icon{background-image:url(/assets/dashboard-stat-mail.svg)}.admin-stats .admin-stat:nth-child(5) .icon{background-image:url(/assets/dashboard-stat-like.svg)}.admin-stat>span:not(.icon){color:#6a7786;grid-row:2;font-size:13px;line-height:20px}.admin-stat>b{color:#172033;grid-row:3;font-size:30px;line-height:36px}.admin-stat>small{color:#7a8795;white-space:nowrap;grid-row:4;line-height:20px}.icon{background:var(--teal-soft);width:42px;height:42px;color:var(--teal);border-radius:10px;place-items:center;display:inline-grid}.icon:before{content:"•";font-weight:800}.icon-doc:before{content:"▤"}.icon-eye:before{content:"◎"}.icon-chat:before{content:"☷"}.icon-mail:before{content:"✉"}.icon-like:before{content:"♡"}.icon-shield:before{content:"◆"}.icon-dot:before{content:"◇"}.left-stack{flex-direction:column;gap:16px;min-width:0;display:flex}.chart{min-height:354px}.chart.card,.donut.card,.site-status.card,.review.card,.activity.card,.hot.card,.pending.card,.quick.card{background:#fff;border:1px solid #e5edf1;border-radius:10px;box-shadow:0 12px 28px #263f530e}.chart header{margin-bottom:14px}.chart header h3,.donut.card h3,.site-status h3,.review h3,.activity h3,.hot h3,.pending h3,.quick h3{color:#182638;font-size:16px}.chart select{color:#5c6c7b;background:#fbfdfe;border-color:#dce7eb;border-radius:7px;height:34px}.seg{margin-bottom:8px}.seg button{color:#617181;background:#fff;border:1px solid #dce7eb;padding:8px 22px}.seg .active{background:var(--teal);color:#fff;border-color:var(--teal);box-shadow:0 8px 18px #009a9329}.line-chart{background:repeating-linear-gradient(0deg,#edf3f5 0 1px,#0000 1px 47px);border-bottom:1px solid #dfe9ed;align-items:end;gap:9%;height:238px;padding:34px 34px 0;display:flex;position:relative}.line-chart:before{content:"";pointer-events:none;border-left:1px solid #dfe9ed;position:absolute;inset:34px 34px 0}.line-chart i{background:linear-gradient(#08a69f,#bcefe9);border:0;border-radius:9px 9px 0 0;flex:1;min-width:10px;max-width:18px;display:block;position:relative;box-shadow:0 10px 18px #08a69f2e}.line-chart i:after{content:"";background:#fff;border:3px solid #079b95;border-radius:50%;width:12px;height:12px;position:absolute;top:-7px;left:50%;transform:translate(-50%)}.line-chart b{background:var(--teal);color:#fff;white-space:nowrap;border-radius:6px;padding:4px 8px;position:absolute;top:-34px;left:50%;transform:translate(-50%)}.chart-empty{place-items:center;margin:0;display:grid;position:absolute;inset:0}.donut.card{grid-template-columns:150px 1fr;align-items:center;gap:8px 18px;min-height:226px;display:grid}.donut.card h3{grid-column:1/-1;margin-bottom:0}.donut-ring{background:conic-gradient(#0ab887 0 70%, #f59e0b 70% 88%, #42a5ff 88% 96%, #c9d3da 96%);border-radius:50%;grid-row:2/span 4;place-items:center;width:148px;height:148px;margin:8px 0 0;display:grid;box-shadow:inset 0 0 0 1px #fff6,0 12px 22px #2c4b5d14}.donut-ring b{background:#fff;border-radius:50%;place-items:center;width:94px;height:94px;font-size:28px;display:grid}.donut-ring small{color:var(--muted);font-size:12px;display:block}.donut.card p{color:#334155;grid-column:2;margin:8px 0;font-size:14px}.review .comment-mini p:nth-of-type(n+4){display:none}.middle-stack,.right-stack{flex-direction:column;gap:16px;min-width:0;display:flex}.site-status{grid-template-columns:1fr;gap:10px;min-height:112px;display:grid}.site-status h3{grid-column:1/-1}.site-status div{background:#fbfdfe;border:1px solid #e8f0f3;border-radius:8px;grid-template-columns:86px 1fr;align-items:center;gap:12px;padding:10px 12px;display:grid}.site-status div:last-child{border-right:1px solid #e8f0f3}.site-status b,.site-status span{min-width:0;display:block}.site-status b{color:#172033;white-space:nowrap}.site-status span{color:#536273;overflow-wrap:anywhere;font-size:13px}.activity p,.hot p{color:#465568;border-bottom:1px solid #e7eef2;justify-content:space-between;align-items:center;gap:14px;padding:12px 0;display:flex}.activity p span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.activity time,.hot span{color:#7a8795;flex:none;font-size:12px}.hot p b{color:#0b938d;background:#e7f8f5;border-radius:50%;flex:none;place-items:center;width:24px;height:24px;font-size:12px;display:inline-grid}.hot p{justify-content:flex-start}.hot p span{margin-left:auto}.quick{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.quick h3{grid-column:1/-1}.quick button{color:#0d6f6a;background:#eaf8f6;border-radius:8px;min-height:48px;padding:13px;font-weight:800}.quick button:nth-of-type(2){color:#2f6fb7;background:#edf5ff}.quick button:nth-of-type(3){color:#8b5f13;background:#fff7e8}.quick button:nth-of-type(4){color:#6c5aab;background:#f3f0ff}.quick button:nth-of-type(5){color:#b54e5e;background:#fff0f2}.quick button:nth-of-type(6){color:#536273;background:#f1f5f7}.pending p{color:#465568;border-bottom:1px solid #e7eef2;grid-template-columns:1fr auto;gap:4px 12px;padding:12px 0;display:grid}.pending small{color:#536273;grid-column:1/-1}.text-link{width:100%;color:var(--teal-dark);text-align:center;margin-top:10px}.editor{grid-template-columns:minmax(620px,1fr) 320px 220px;align-items:start;gap:18px;padding:22px 24px;display:grid;position:relative}.editor-core,.preview-pane,.markdown-pane{min-width:0}.editor-title{align-items:center;gap:20px;min-height:36px;padding-right:430px;display:flex}.editor-title h1{margin:0;font-size:26px;line-height:32px}.editor-title span{color:#5f7a70;font-size:13px}.title-input{width:100%;height:48px;margin-top:8px;padding:0 16px;font-size:18px;font-weight:700}.editor-tabs{border-bottom:1px solid var(--line);margin-top:10px}.editor-tabs button{color:#526273;padding:12px 18px}.editor-tabs .active{color:var(--teal);border-bottom:2px solid var(--teal);font-weight:800}.editor-split{border:1px solid var(--line);border-radius:var(--radius);background:#fff;grid-template-columns:minmax(0,1fr) minmax(320px,.92fr);display:grid;overflow:hidden;box-shadow:0 12px 24px #0f172a0a}.toolbar{border-bottom:1px solid var(--line);background:#fbfdfe;align-items:center;gap:8px;height:50px;padding:8px 12px;display:flex}.markdown-pane{border-right:1px solid var(--line);background:#fff;position:relative}.markdown-editor-shell{grid-template-columns:42px 1fr;height:560px;display:grid}.line-numbers{color:#a8b2bd;text-align:right;-webkit-user-select:none;user-select:none;background:#fbfdff;border-right:1px solid #edf2f4;padding:18px 0;font:13px/1.9 Consolas,SFMono-Regular,monospace;overflow:hidden}.line-numbers span{height:24.7px;padding-right:12px;display:block}.markdown-pane textarea{resize:none;color:#244164;width:100%;height:100%;box-shadow:none;border:0;padding:18px 22px;font-family:Consolas,SFMono-Regular,monospace;font-size:14px;line-height:1.9}.markdown-pane textarea:focus{box-shadow:none;border-color:#0000}.markdown-pane footer{min-height:42px;color:var(--muted);border-top:1px solid var(--line);background:#fbfdfe;padding:10px 16px;font-size:13px}.preview-pane{background:#fbfcfd;padding:0;line-height:1.9}.preview-doc{background:#fff;min-height:100%;padding:30px 34px}.preview-kicker{color:var(--teal-dark);font-size:13px;font-weight:800}.preview-doc h1{margin:6px 0 12px;font-size:28px;line-height:1.35}.preview-doc h2,.article-markdown h2{margin:24px 0 10px;font-size:22px;line-height:1.4}.preview-doc h3,.article-markdown h3{margin:20px 0 8px;font-size:18px;line-height:1.45}.preview-doc h4,.article-markdown h4{margin:18px 0 6px;font-size:16px;line-height:1.5}.preview-doc p,.article-markdown p{color:#465568;margin:10px 0;line-height:1.9}.preview-doc a,.article-markdown a{color:var(--blue);overflow-wrap:anywhere;border-bottom:1px solid #2b7be447;text-decoration:none}.preview-doc a:hover,.article-markdown a:hover{color:var(--teal-dark);border-bottom-color:currentColor}.preview-doc strong,.article-markdown strong{color:#172033;font-weight:800}.preview-doc em,.article-markdown em{color:#334155}.preview-doc .note{color:#526273;background:#f2f5f7;border-radius:7px;margin:14px 0 18px;padding:14px 16px}.preview-doc blockquote,.article-markdown blockquote{border-left:3px solid var(--teal);color:#425466;background:#eefaf8;margin:14px 0;padding:10px 14px}.preview-doc pre,.code-block{color:#e9f5f5;background:#102337;border-radius:7px;padding:0;overflow:auto}.preview-doc code{font-family:Consolas,SFMono-Regular,monospace}.preview-doc p code,.preview-doc li code,.preview-doc blockquote code,.article-markdown p code,.article-markdown li code,.article-markdown blockquote code{color:#0f766e;background:#e8f7f5;border-radius:5px;padding:2px 6px}.code-block{border:1px solid #ffffff14;max-width:100%;display:grid;position:relative}.code-block-head{z-index:1;color:#b7d8d8;background:#0b1b2a;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-family:inherit;font-size:12px;display:flex;position:sticky;left:0}.code-block-head b{text-transform:uppercase;letter-spacing:.08em}.code-block-head button{color:#e9f5f5;background:#ffffff14;border:1px solid #ffffff2e;border-radius:6px;min-height:30px;padding:0 10px;font-weight:800}.code-block code{white-space:pre;tab-size:2;min-width:max-content;padding:12px 0;font-family:Consolas,SFMono-Regular,monospace;display:grid}.code-line{grid-template-columns:46px minmax(0,1fr);min-height:22px;line-height:1.7;display:grid}.code-line:hover{background:#ffffff0a}.code-line-number{color:#668195;text-align:right;-webkit-user-select:none;user-select:none;border-right:1px solid #ffffff14;padding:0 12px}.code-line-content{padding:0 16px}.code-token.keyword{color:#93c5fd;font-weight:800}.code-token.string{color:#86efac}.code-token.number{color:#fbbf24}.code-token.comment{color:#7d93a8;font-style:italic}.preview-inline-image{border:1px solid var(--line);object-fit:cover;border-radius:7px;max-width:100%;max-height:220px;margin:12px 0;display:block}.markdown-image-button{cursor:zoom-in;background:0 0;border:0;border-radius:7px;width:fit-content;max-width:100%;margin:12px 0;padding:0;display:block}.markdown-image-button .preview-inline-image{margin:0;transition:box-shadow .18s,transform .18s}.markdown-image-button:hover .preview-inline-image{transform:translateY(-1px);box-shadow:0 16px 34px #0f172a24}.markdown-table-scroll{border:1px solid var(--line);background:#fff;border-radius:7px;max-width:100%;margin:14px 0;overflow-x:auto}.preview-table{border-collapse:collapse;width:100%;min-width:max-content;font-size:14px;overflow:hidden}.preview-table th,.preview-table td{border-bottom:1px solid var(--line);text-align:left;padding:10px 12px}.preview-table th{color:#1f3348;background:#f5f8fa;font-weight:800}.preview-table tr:last-child td{border-bottom:0}.preview-list:before{content:"•";color:var(--teal);margin-right:8px}.preview-check{color:#465568;align-items:center;gap:8px;display:flex}.preview-check input{accent-color:var(--teal)}.article-markdown{overflow-wrap:break-word;gap:12px;min-width:0;display:grid}.article-markdown>*{min-width:0}.article-markdown .preview-inline-image{object-fit:contain;width:auto;height:auto;max-height:none}.article-markdown .markdown-list{gap:8px;margin:0;padding-left:22px;display:grid}.article-markdown .markdown-ordered-list{list-style:decimal}.article-markdown .markdown-list li{color:#465568;line-height:1.9}.article-markdown .markdown-checklist{gap:8px;display:grid}.article-markdown .preview-check{color:#32475b;align-items:center;gap:8px;display:flex}.article-markdown .preview-check input{flex:none;width:18px;height:18px;min-height:18px}.publish-panel,.ai-panel{height:max-content}.publish-panel{margin-top:38px;padding:16px}.publish-panel .card{box-shadow:none;border:0;padding:0}.publish-panel .card:has(.cover-thumb){grid-template-columns:178px 1fr;align-items:center;gap:10px 14px;display:grid}.publish-panel .card:has(.cover-thumb) header{grid-column:1/-1;margin-bottom:0}.publish-panel .card:has(.cover-thumb) button{border:1px solid var(--line);color:#314359;background:#fff;border-radius:7px;height:40px}.cover-thumb{background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:7px;height:94px;margin-bottom:0}.cover-actions{align-content:center;gap:8px;display:grid}.cover-actions small{color:var(--muted);word-break:break-all}.version-list{gap:8px;display:grid}.version-list button{border:1px solid var(--line);text-align:left;background:#fff;border-radius:7px;gap:5px;padding:10px;display:grid}.version-list button:hover{background:#f0fbf9;border-color:#079b9559}.version-list small{color:var(--muted);line-height:1.5}.publish-panel h3,.ai-panel h3{margin:14px 0 8px}.publish-panel label{color:#39495a;gap:8px;margin:14px 0;display:grid}.publish-panel input,.publish-panel textarea,.publish-panel select{min-height:40px;padding:10px}.publish-panel input:disabled{color:#9aa8b5;cursor:not-allowed;background:#f3f6f8}.publish-panel textarea{resize:vertical;min-height:78px}.publish-panel .text-link{text-align:left;width:auto;margin:0}.field-help{color:var(--muted);font-size:12px;font-weight:600;line-height:1.6;display:block}.publish-radio{align-items:center;gap:18px;display:flex}.publish-radio label{grid-auto-flow:column;align-items:center;gap:7px;margin:0;display:inline-flex}.publish-radio input{min-height:auto;accent-color:var(--teal)}.switch{justify-content:space-between;align-items:center;display:flex!important}.switch input[type=checkbox]{width:22px;height:22px;min-height:22px;accent-color:var(--teal);cursor:pointer;padding:0}.visually-hidden{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.ai-panel{flex-direction:column;gap:12px;padding:14px;display:flex}.ai-panel header{align-items:center}.ai-status-row{background:#f8fbfc;border:1px solid #e5eaf0;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:8px;display:flex}.ai-status-row span{min-width:0;font-size:12px;font-weight:800}.ai-status-row .ready{color:var(--teal-dark)}.ai-status-row .warn{color:#b45309}.ai-status-row button{color:#526273;background:#fff;border-radius:6px;min-height:28px;padding:0 10px}.ai-history{background:#fbfdff;border:1px solid #e6eef3;border-radius:8px;gap:8px;padding:10px;display:grid}.ai-history-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.ai-history-head b{color:#172033;font-size:13px}.ai-history-head button{color:#536273;background:#fff;border:1px solid #e1e8ef;border-radius:6px;min-height:28px;padding:0 9px;font-size:12px;font-weight:800}.ai-history-head button:disabled{opacity:.62;cursor:wait}.ai-history-list{gap:7px;max-height:236px;display:grid;overflow:auto}.ai-history-list button{text-align:left;background:#fff;border:1px solid #edf1f5;border-radius:7px;gap:6px;min-width:0;padding:9px;transition:transform .18s,border-color .18s,box-shadow .18s;display:grid}.ai-history-list button:hover{border-color:#6a3de23d;transform:translateY(-1px);box-shadow:0 10px 22px #0f172a14}.ai-history-list span{justify-content:space-between;align-items:center;gap:8px;min-width:0;display:flex}.ai-history-list b{color:#172033;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:13px;overflow:hidden}.ai-history-list small{color:#7c8794;flex:none;font-size:11px}.ai-history-list i{color:#536273;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;font-style:normal;line-height:1.45;display:-webkit-box;overflow:hidden}.ai-history-empty{color:#7c8794;margin:0;font-size:12px;line-height:1.5}.ai-mode-tabs{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:grid}.ai-mode-tabs button{color:#536273;background:#fff;border:1px solid #e5eaf0;border-radius:8px;min-width:0;min-height:58px;padding:8px 6px;font-weight:900}.ai-mode-tabs button.active{color:#6a3de2;background:#f6f1ff;border-color:#6a3de25c;box-shadow:inset 0 0 0 1px #6a3de214}.ai-mode-tabs small{color:#7c8794;margin-top:4px;font-size:11px;font-weight:600;line-height:1.25;display:block}.ai-workspace{background:linear-gradient(#fff,#fbfcff);border:1px solid #e4eaf0;border-radius:8px;gap:10px;padding:12px;display:grid}.ai-workspace h3{color:#172033;margin:0;font-size:16px}.ai-feedback{color:#536273;background:#f7f9fb;border:1px solid #edf1f5;border-radius:7px;padding:9px 10px;font-size:12px;line-height:1.55}.ai-feedback.success{color:#0f766e;background:#effbf8;border-color:#0f766e2e}.ai-feedback.error{color:#b42318;background:#fff4f2;border-color:#b423182e}.ai-muted{color:#6b7888;margin:0;font-size:12px;line-height:1.6}.ai-field{color:#405066;gap:7px;margin:0;font-size:13px;font-weight:800;display:grid}.ai-field select,.ai-field textarea{border:1px solid var(--line);color:#172033;background:#fff;border-radius:7px;width:100%;min-height:38px;padding:9px 10px;font-size:13px}.ai-field textarea{resize:vertical;min-height:92px;line-height:1.55}.ai-field small{color:var(--muted);text-align:right;font-weight:600}.ai-web-switch{color:#405066;background:#fff;border:1px solid #edf1f5;border-radius:7px;justify-content:space-between;align-items:center;gap:10px;padding:9px 10px;font-size:13px;font-weight:800;display:flex}.ai-web-switch small{color:var(--muted);margin-top:3px;font-size:11px;font-weight:600;display:block}.ai-web-switch input{accent-color:#6a3de2;cursor:pointer;width:18px;height:18px;min-height:18px}.ai-primary,.ai-undo{border-radius:7px;min-height:38px;font-weight:900}.ai-primary{color:#fff;background:linear-gradient(135deg,#6a3de2,#8b5cf6)}.ai-undo{color:#6a3de2;background:#fff;border:1px solid #6a3de247}.ai-primary:disabled,.ai-undo:disabled,.ai-result-head button:disabled{opacity:.62;cursor:wait}.ai-result-head{justify-content:space-between;align-items:center;gap:8px;margin-top:2px;display:flex}.ai-result-head b{color:#172033;font-size:13px}.ai-result-head button{color:#6a3de2;background:#fff;border:1px solid #6a3de23d;border-radius:6px;min-height:30px;padding:0 10px;font-size:12px;font-weight:800}.ai-result{color:#526273;white-space:pre-wrap;background:#fff;border:1px solid #edf1f5;border-radius:7px;max-height:132px;padding:10px;font-size:13px;line-height:1.65;overflow:auto}.ai-sources{background:#fbfdff;border:1px solid #e6eef3;border-radius:7px;gap:7px;padding:10px;display:grid}.ai-sources b{color:#172033;font-size:13px}.ai-sources a{color:var(--teal-dark);text-overflow:ellipsis;white-space:nowrap;font-size:12px;line-height:1.45;overflow:hidden}.ai-result-modal{z-index:80;background:#0f172a61;place-items:center;padding:28px;display:grid;position:fixed;inset:0}.ai-result-modal-panel{background:#fff;border-radius:8px;grid-template-rows:auto minmax(0,1fr) auto;gap:14px;width:min(760px,94vw);max-height:min(760px,88vh);padding:18px;display:grid;box-shadow:0 28px 80px #0f172a3d}.ai-result-modal-panel header{border-bottom:1px solid #edf1f5;justify-content:space-between;align-items:center;gap:12px;padding-bottom:12px;display:flex}.ai-result-modal-panel header b{color:#172033;font-size:18px}.ai-result-modal-panel header button{border:1px solid var(--line);color:#536273;background:#fff;border-radius:7px;min-height:34px;padding:0 14px;font-weight:800}.ai-result-modal-panel pre{color:#24364a;white-space:pre-wrap;word-break:break-word;background:#fbfdff;border:1px solid #edf1f5;border-radius:8px;min-height:260px;margin:0;padding:16px;font-family:inherit;font-size:14px;line-height:1.75;overflow:auto}.ai-result-modal-sources{gap:8px;padding-top:2px;display:grid}.ai-result-modal-sources b{color:#172033;font-size:14px}.ai-result-modal-sources a{color:var(--teal-dark);word-break:break-all;line-height:1.5}.hint{color:#6c41d8;background:#f4eeff;border-radius:8px;padding:14px}.editor-actions{gap:8px;display:flex;position:absolute;top:22px;right:24px}.editor-actions button{border:1px solid var(--line);background:#fff;border-radius:7px;min-height:38px;padding:9px 16px}.editor-actions .draft{color:#fff;background:#ff9428;border:0}.editor-actions .primary{color:#fff;background:linear-gradient(135deg, var(--teal), #02a7a0);border:0}.search-mini button{width:28px;height:28px;color:var(--muted);border-radius:6px}.search-mini button:hover{color:var(--teal-dark);background:var(--teal-soft)}.category-grid button{color:#314359;text-align:left;grid-template-columns:28px minmax(70px,1fr) 34px;align-items:center;gap:10px;display:grid}.category-grid button b{text-align:right;color:#344b68}.category-grid button:hover,.mini-list button:hover,.archive-item:hover{color:var(--teal-dark)}.tag-button{border-radius:7px;padding:0}.filter .tag-cloud .tag-button{width:auto;padding:0;display:inline-flex}.tag-button.active .tag,.tag-button:hover .tag{color:var(--teal-dark);background:var(--teal-soft);box-shadow:inset 0 0 0 1px #079b952e}.archive-item{text-align:left;background:#fff;width:100%}.reply-box{grid-template-columns:1fr 96px;gap:8px;margin:10px 0;display:grid}.reply-box input{height:38px;padding:0 12px}.reply-box button{color:#fff;background:var(--teal);border-radius:7px}.admin-placeholder{grid-template-columns:1fr}.admin-table{flex-direction:column;gap:0;display:flex}.admin-table header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:16px;padding-bottom:12px;display:flex}.admin-table header>div{gap:4px;min-width:0;display:grid}.admin-table header span{color:var(--muted);font-size:13px}.table-batch-button{border:1px solid var(--line);color:var(--teal-dark);background:#fff;border-radius:999px;flex:none;padding:7px 12px;font-size:12px}.table-batch-button:hover{background:#e9fbf8;border-color:#00a69659}.batch-toolbar{border-bottom:1px solid var(--line);background:#fbfdfe;align-items:center;gap:14px;padding:12px 4px;display:flex}.batch-toolbar label{color:#314359;align-items:center;gap:8px;font-weight:700;display:inline-flex}.batch-toolbar input,.row-check input{width:16px;height:16px;accent-color:var(--teal);cursor:pointer}.batch-toolbar>span{color:var(--muted);font-size:13px}.batch-toolbar>div{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;margin-left:auto;display:inline-flex}.batch-toolbar button{border:1px solid var(--line);color:var(--teal-dark);background:#fff;border-radius:999px;padding:7px 12px;font-size:12px}.batch-toolbar button:hover:not(:disabled){background:#e9fbf8;border-color:#00a69659}.batch-toolbar button.danger{color:#d33f49}.batch-toolbar button.danger:hover:not(:disabled){background:#fff0f2;border-color:#d33f4947}.batch-toolbar button:disabled{color:#a8b2bd;cursor:not-allowed;background:#f4f7f8}.admin-pagination{justify-content:center;align-items:center;gap:12px;padding:16px 0 4px;display:flex}.admin-pagination button{border:1px solid var(--line);min-height:36px;color:var(--teal-dark);background:#fff;border-radius:7px;padding:0 14px;font-weight:800}.admin-pagination button:not(:disabled):hover{background:#e9fbf8;border-color:#079b9566}.admin-pagination span{color:#5d6d7e;font-size:13px;font-weight:700}.admin-row{border-bottom:1px solid var(--line);text-align:left;justify-content:space-between;align-items:center;gap:18px;padding:14px 4px;display:flex}.admin-row.selected{background:#f2fbf9}.admin-row>span{overflow-wrap:anywhere;flex:1;min-width:0}.row-check{cursor:pointer;flex:none;align-items:center;display:inline-flex}.admin-row.media-row{align-items:center}.media-text{flex-direction:column;gap:4px;display:flex}.media-text b{color:var(--ink);overflow-wrap:anywhere;font-size:14px;line-height:1.35}.media-text small{color:var(--muted);overflow-wrap:anywhere;font-size:12px;line-height:1.35}.media-thumb{border:1px solid var(--line);background-color:#f3f6f8;background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:7px;flex:none;width:72px;height:54px}.media-thumb.video-thumb{background:#111827;display:block;position:relative;overflow:hidden}.media-thumb.video-thumb video{object-fit:cover;opacity:.78;width:100%;height:100%}.media-thumb.video-thumb span{color:#fff;background:#0f172ac2;border-radius:5px;padding:2px 5px;font-size:11px;font-weight:800;position:absolute;bottom:5px;right:5px}.admin-row.clickable{cursor:pointer}.admin-row.clickable:hover>span{color:var(--teal-dark)}.admin-row-actions{flex-shrink:0;justify-content:flex-end;align-items:center;gap:8px;display:inline-flex}.admin-row-actions small{text-overflow:ellipsis;white-space:nowrap;max-width:360px;color:var(--muted);overflow:hidden}.admin-row-actions button{border:1px solid var(--line);color:var(--teal-dark);background:#fff;border-radius:999px;padding:6px 10px;font-size:12px}.admin-row-actions button:hover{background:#e9fbf8;border-color:#00a69659}.admin-table small{color:var(--muted)}.media-modal{z-index:80;background:#0f172a7a;place-items:center;padding:28px;display:grid;position:fixed;inset:0}.media-modal-panel{border:1px solid var(--line);background:#fff;border-radius:8px;flex-direction:column;gap:14px;width:min(920px,92vw);max-height:88vh;padding:18px;display:flex;box-shadow:0 24px 70px #0f172a38}.media-modal-panel header{justify-content:space-between;align-items:center;gap:16px;display:flex}.media-modal-panel header button{border:1px solid var(--line);color:var(--teal-dark);background:#fff;border-radius:7px;padding:8px 12px}.media-modal-panel>img{object-fit:contain;background:#f3f6f8;border-radius:7px;max-width:100%;max-height:64vh}.media-preview-video{background:#111827;border-radius:7px;width:100%;max-height:64vh}.media-modal-panel>p{color:var(--muted);overflow-wrap:anywhere;margin:0;font-size:13px}.article-image-modal-panel{width:min(1080px,94vw)}.article-image-modal-panel>img{max-height:76vh}.qr-modal-panel{width:min(360px,92vw)}.qr-modal-panel>img{aspect-ratio:1;object-fit:contain;width:100%;max-height:none}.media-picker-panel{width:min(760px,92vw)}.media-picker-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;padding-right:4px;display:grid;overflow:auto}.media-picker-grid button{border:1px solid var(--line);text-align:left;background:#fff;border-radius:7px;gap:8px;padding:8px;display:grid}.media-picker-grid button:hover{border-color:#079b9566;box-shadow:0 0 0 3px #079b951a}.media-picker-grid img,.media-picker-grid video{aspect-ratio:4/3;object-fit:cover;background:#f3f6f8;border-radius:6px;width:100%}.media-picker-grid span{color:#314359;text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.about-config,.home-config,.site-config{grid-template-columns:minmax(360px,.9fr) minmax(560px,1.1fr);align-items:start;gap:18px;display:grid}.settings-panel{background:#fbfdfe;border:1px solid #e7eef2;border-radius:8px;gap:14px;min-width:0;padding:16px;display:grid}.settings-panel.wide{grid-column:1/-1}.settings-panel>header{border-bottom:1px solid #edf3f6;justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:12px;display:flex}.settings-panel>header b{color:#102033;font-size:16px}.settings-panel>header span,.project-editor header span,.timeline-editor header span,.home-entry-editor header span{color:#6b7a8d;margin-top:4px;font-size:13px;font-weight:500;line-height:1.5;display:block}.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-content:start;gap:14px;display:grid}.settings-grid.single{grid-template-columns:1fr}.settings-grid.compact textarea{min-height:150px}.settings-grid label{color:#314359;gap:8px;font-weight:700;display:grid}.settings-grid .wide{grid-column:1/-1}.settings-grid input,.settings-grid textarea{border:1px solid var(--line);color:#172033;width:100%;min-height:40px;box-shadow:none;background:#fff;border-radius:7px;padding:10px 12px}.settings-grid textarea{resize:vertical;min-height:118px;line-height:1.6}.color-field{grid-template-columns:46px minmax(0,1fr);gap:8px;display:grid}.color-field input[type=color]{cursor:pointer;min-height:40px;padding:4px}.home-config{grid-template-columns:minmax(520px,1.1fr) minmax(360px,.9fr)}.home-cover-preview{border:1px solid var(--line);text-align:center;background-color:#0000;background-image:radial-gradient(circle at 16% 24%,#fffffff2 0 32px,#0000 33px),linear-gradient(#d8f5fb,#fff 78%);background-position:50%;background-repeat:repeat,repeat;background-size:cover;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;border-radius:8px;place-items:center;min-height:260px;display:grid;position:relative;overflow:hidden}.home-cover-preview.has-image{color:#fff;text-shadow:0 2px 12px #00000052}.home-cover-preview.has-video{background:#0f172a}.home-cover-preview-video{object-fit:cover;transform-origin:50%;width:100%;height:100%;position:absolute;inset:0}.home-cover-preview-overlay{z-index:1;pointer-events:none;background:#000;position:absolute;inset:0}.home-cover-preview.draggable{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.home-cover-preview.draggable:active{cursor:grabbing}.home-cover-preview div{z-index:2;gap:8px;padding:24px;display:grid;position:relative}.home-cover-preview b{font-size:26px}.home-cover-preview span{color:inherit;font-weight:700}.home-cover-preview small{color:inherit;opacity:.9;font-size:13px;font-weight:700}.home-cover-preview-actions{justify-content:center;gap:8px;margin:4px 0;display:flex}.home-cover-preview-actions i{border-radius:7px;justify-content:center;align-items:center;min-height:30px;padding:0 12px;font-size:12px;font-style:normal;font-weight:800;display:inline-flex;box-shadow:0 10px 18px #0f172a1f}.muted-preview-text{text-shadow:none;color:#8b9aab!important}.home-cover-type{justify-content:flex-start}.home-cover-position{background:#fff;border:1px solid #e8f0f3;border-radius:8px;gap:12px;padding:12px;display:grid}.home-cover-position label{color:#314359;grid-template-columns:auto 44px minmax(0,1fr);align-items:center;gap:10px;font-weight:700;display:grid}.home-cover-position b{color:var(--teal-dark);text-align:right;font-size:13px}.home-cover-position input{width:100%;accent-color:var(--teal)}.home-cover-actions{justify-content:flex-end;display:flex}.home-cover-actions button{border:1px solid var(--line);color:#314359;background:#fff;border-radius:7px;min-height:38px;padding:0 14px;font-weight:700}.inline-picker{grid-template-columns:minmax(0,1fr) repeat(3,auto);gap:8px;display:grid}.inline-picker button,.project-editor header button,.timeline-editor header button,.home-entry-editor header button,.entry-card-actions button,.project-media-column button,.project-remove{border:1px solid var(--line);color:var(--teal-dark);background:#fff;border-radius:7px;padding:0 12px;font-weight:700}.inline-picker button:hover,.project-editor header button:hover,.timeline-editor header button:hover,.home-entry-editor header button:hover,.entry-card-actions button:hover:not(:disabled),.project-media-column button:hover{background:#e9fbf8;border-color:#079b9559}.site-preview-grid{grid-template-columns:minmax(260px,.8fr) minmax(320px,1.2fr);gap:14px;display:grid}.site-preview-card{background:#fff;border:1px solid #e5edf1;border-radius:8px;align-content:start;gap:12px;min-width:0;padding:14px;display:grid}.site-preview-card>span{color:var(--muted);font-size:12px;font-weight:800}.site-preview-card .brand{cursor:default;justify-self:start}.site-browser-preview{color:#172033;background:#f8fbfd;border:1px solid #e9eff3;border-radius:7px;align-items:center;gap:10px;min-height:40px;padding:9px 10px;display:flex}.site-browser-preview i{background:var(--teal-soft) center / cover no-repeat;width:22px;height:22px;color:var(--teal-dark);border-radius:5px;flex:none;place-items:center;font-size:12px;font-style:normal;font-weight:900;display:grid}.site-browser-preview b{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:13px;overflow:hidden}.site-share-preview{background:#fbfdff;border:1px solid #e9eff3;border-radius:8px;grid-template-columns:132px minmax(0,1fr);gap:12px;padding:10px;display:grid}.site-share-preview img,.site-share-preview>div{aspect-ratio:1.9;object-fit:cover;background:#eef3f5;border-radius:7px;width:100%}.site-share-preview>div{color:var(--muted);place-items:center;font-size:12px;font-weight:800;display:grid}.site-share-preview section{align-content:start;gap:6px;min-width:0;display:grid}.site-share-preview b{text-overflow:ellipsis;white-space:nowrap;color:#172033;font-size:14px;overflow:hidden}.site-share-preview p{color:#536273;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:1.55;display:-webkit-box;overflow:hidden}.site-footer-preview{border-top:1px solid #edf3f6;justify-content:flex-start;margin:0;padding:10px 0 0}.import-config{grid-template-columns:minmax(320px,.72fr) minmax(520px,1.28fr);align-items:start;gap:18px;display:grid}.import-json{border:1px solid var(--line);color:#172033;resize:vertical;background:#fff;border-radius:8px;width:100%;min-height:520px;padding:14px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.6}.import-help{color:#536273;background:#fff;border:1px solid #e9eff3;border-radius:8px;gap:8px;padding:12px;font-size:13px;line-height:1.6;display:grid}.import-help b{color:#172033}.import-help p{margin:0}.import-preview-list{gap:10px;max-height:520px;padding-right:4px;display:grid;overflow:auto}.import-preview-list article{background:#fff;border:1px solid #e5edf1;border-radius:8px;gap:5px;padding:12px;display:grid}.import-preview-list article.has-warning{background:#fffaf0;border-color:#d9770647}.import-preview-list article.has-error{background:#fff5f5;border-color:#dc262647}.import-preview-list b{color:#172033;font-size:14px}.import-preview-list small{color:var(--muted);line-height:1.45}.import-preview-list p{color:#a34000;margin:0;font-size:13px;line-height:1.5}.security-config{grid-template-columns:minmax(360px,.8fr) minmax(360px,1fr);align-items:start;gap:18px;display:grid}.ai-settings-config{grid-template-columns:minmax(360px,.9fr) minmax(360px,1fr);align-items:start;gap:18px;display:grid}.ai-key-status{background:#fff;border:1px solid #e6eef3;border-radius:8px;gap:6px;padding:12px;display:grid}.ai-key-status span{border-radius:999px;width:fit-content;padding:3px 9px;font-size:12px;font-weight:900}.ai-key-status span.ok{color:#04756f;background:#dff8f4}.ai-key-status span.warn{color:#a35b00;background:#fff1d8}.ai-key-status b{color:#142235;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:15px}.ai-key-status small{color:#65758a;line-height:1.5}.ai-clear-key,.ai-settings-switch{color:#33475f;align-items:center;gap:8px;font-weight:800}.ai-clear-key input,.ai-settings-switch input{width:18px;height:18px;min-height:18px;accent-color:var(--teal)}.security-form label{color:#314359;gap:8px;font-weight:800;display:grid}.security-form input{border:1px solid var(--line);color:#172033;background:#fff;border-radius:7px;min-height:40px;padding:10px 12px}.security-form .primary{color:#fff;background:var(--teal);border-radius:7px;min-height:40px;font-weight:900}.entry-card-actions button:disabled{color:#a8b2bd;cursor:not-allowed;background:#f4f7f8}.project-editor{gap:14px;display:grid}.project-editor header,.timeline-editor header{border:0;justify-content:space-between;align-items:flex-start;gap:16px;padding:0 0 2px;display:flex}.project-editor header button,.timeline-editor header button{white-space:nowrap;min-height:36px}.project-editor article{background:#fff;border:1px solid #e5edf1;border-radius:8px;grid-template-columns:180px 1fr;gap:16px;padding:16px;display:grid}.timeline-editor{gap:14px;display:grid}.timeline-editor article{background:#fff;border:1px solid #e5edf1;border-radius:8px;grid-template-columns:minmax(180px,.42fr) minmax(240px,.58fr);gap:12px;padding:16px;display:grid}.timeline-editor label{color:#314359;gap:8px;font-weight:700;display:grid}.timeline-editor input,.timeline-editor textarea{border:1px solid var(--line);color:#172033;width:100%;min-height:40px;box-shadow:none;background:#fff;border-radius:7px;padding:10px 12px}.timeline-editor textarea{resize:vertical;min-height:92px;line-height:1.6}.timeline-editor .wide{grid-column:1/-1}.home-entry-editor{gap:14px;display:grid}.home-entry-editor header{border:0;justify-content:space-between;align-items:flex-start;gap:16px;padding:0 0 2px;display:flex}.entry-editor-actions,.entry-card-actions{flex-wrap:wrap;align-items:center;gap:8px;display:inline-flex}.home-entry-editor header button,.entry-card-actions button{white-space:nowrap;min-height:36px}.entry-card-actions button:disabled{opacity:.5;cursor:not-allowed}.home-entry-editor article{background:#fff;border:1px solid #e5edf1;border-radius:8px;grid-template-columns:minmax(150px,.34fr) minmax(180px,.66fr);gap:12px;padding:16px;display:grid}.home-entry-editor label{color:#314359;gap:8px;font-weight:700;display:grid}.home-entry-editor input,.home-entry-editor textarea,.home-entry-editor select{border:1px solid var(--line);color:#172033;width:100%;min-height:40px;box-shadow:none;background:#fff;border-radius:7px;padding:10px 12px}.home-entry-editor textarea{resize:vertical;min-height:82px;line-height:1.6}.home-entry-editor .wide{grid-column:1/-1}.project-media-column{align-content:start;gap:10px;display:grid}.project-media-column button{min-height:36px}.project-thumb{aspect-ratio:4/3;border:1px solid var(--line);background:#eef3f5 50%/cover no-repeat;border-radius:7px;width:100%}.project-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.project-form-grid label{color:#314359;gap:8px;font-weight:700;display:grid}.project-form-grid input,.project-form-grid textarea{border:1px solid var(--line);color:#172033;width:100%;min-height:40px;box-shadow:none;background:#fff;border-radius:7px;padding:10px 12px}.project-form-grid .wide{grid-column:1/-1}.project-form-grid textarea{resize:vertical;min-height:82px;line-height:1.6}.project-card-head{grid-column:1/-1;justify-content:space-between;align-items:center;gap:12px;display:flex}.project-card-head b{color:#102033}.project-remove{color:#d33f49;min-height:30px}.project-remove:hover{background:#fff0f2;border-color:#d33f4947}.project-grid article.clickable{cursor:pointer;transition:transform .16s,box-shadow .16s}.project-grid article.clickable:hover{transform:translateY(-2px);box-shadow:0 14px 28px #0f172a14}.toolbar button{color:#2f3d4d;border-radius:6px;min-width:30px;height:32px}.toolbar button:hover,.editor-actions button.active{color:var(--teal-dark);background:var(--teal-soft)}.preview-mobile .preview-pane{border-left:1px solid var(--line);border-right:1px solid var(--line);background:#fff;max-width:360px;margin:0 auto}.preview-mobile .preview-doc{padding:22px 20px}[data-theme=dark]{--bg:#111827;--paper:#172033;--ink:#eef5f7;--muted:#9aa8b5;--line:#293548;--teal-soft:#123b3d}[data-theme=dark] body{background:#111827}[data-theme=dark] .card,[data-theme=dark] .hero-card,[data-theme=dark] .featured-card,[data-theme=dark] .article-row,[data-theme=dark] .paper,[data-theme=dark] .message-form,[data-theme=dark] .public-header,[data-theme=dark] .admin-side,[data-theme=dark] .admin-top,[data-theme=dark] .month-card,[data-theme=dark] .login-card,[data-theme=dark] .preview-pane,[data-theme=dark] .markdown-pane,[data-theme=dark] .editor-split{background:#172033}[data-theme=dark] input,[data-theme=dark] textarea,[data-theme=dark] select,[data-theme=dark] .search-mini,[data-theme=dark] .pager button,[data-theme=dark] .editor-actions button,[data-theme=dark] .archive-item{color:var(--ink);background:#111827}[data-theme=dark] .admin-mobile-bar{border-color:var(--line);background:#172033f0}[data-theme=dark] .admin-mobile-bar strong,[data-theme=dark] .admin-mobile-menu-button{color:var(--ink)}[data-theme=dark] .admin-mobile-menu-button{background:#111827;border-color:#293548}[data-theme=dark] .admin-mobile-new-button{color:#fff;background:var(--teal)}[data-theme=dark] .admin-entry-button{color:#9be7df;background:#123b3d;border-color:#23484c}@media (width>=1680px){.public-header{grid-template-columns:minmax(340px,.95fr) minmax(380px,1.1fr) minmax(340px,.95fr);padding-inline:clamp(70px,6vw,112px)}.public-header.article-header{grid-template-columns:minmax(320px,.95fr) minmax(360px,1.1fr) minmax(320px,.95fr)}.page,.home-landing,.public-footer{width:min(100% - 72px,1640px)}.home-entry-grid{max-width:1380px}.home-quiet-panel{grid-template-columns:minmax(0,1fr) minmax(420px,.36fr);max-width:1380px}.two-col{grid-template-columns:minmax(0,1fr) clamp(400px,25vw,460px);gap:26px}.home.two-col{grid-template-columns:minmax(0,1fr) clamp(412px,25vw,480px);gap:26px}.article-layout{grid-template-columns:minmax(230px,.24fr) minmax(0,960px) minmax(310px,.34fr);gap:26px;width:min(100% - 72px,1660px)}.archive-layout{grid-template-columns:minmax(286px,320px) minmax(0,1fr);gap:32px}.about-layout{grid-template-columns:minmax(0,1fr) minmax(420px,460px);gap:24px}}@media (width>=1920px){.page,.home-landing,.public-footer{width:min(100% - 96px,1760px)}.article-layout{grid-template-columns:minmax(250px,.24fr) minmax(0,1040px) minmax(330px,.34fr);gap:30px;width:min(100% - 96px,1780px)}.toc{max-height:calc(100vh - 130px);top:104px}.archive-featured-grid,.project-grid{gap:22px}}@media (width<=900px){body{min-width:0}.page,.home-landing,.public-footer{width:min(100% - 28px,100%)}.public-header{grid-template-columns:1fr;gap:12px;height:auto;padding:14px 16px}.public-header.article-header{grid-template-columns:1fr}.public-header nav{order:3;justify-content:start;gap:22px;overflow-x:auto}.public-header.article-header nav{gap:22px}.header-tools{order:2;grid-template-columns:minmax(0,1fr) 42px auto;gap:10px;width:100%;display:grid}.header-tools .search-mini{width:100%}.admin-entry-button{min-width:64px;height:42px;padding:0 12px}.page,.article-layout,.archive-layout,.about-layout,.two-col,.login-page,.admin-app,.editor{display:block}.login-page{padding:28px}.login-copy{max-width:none}.feature-row{grid-template-columns:1fr;gap:14px;margin:28px 0}.feature-row span{white-space:normal;min-height:52px}.dashboard-preview{background-position:0 0;height:230px}.login-card{min-height:0;margin-top:28px}.side-stack,.toc,.article-side{display:none}.mobile-toc{margin:0 0 12px;padding:0;display:block;overflow:hidden}.mobile-toc summary{min-height:42px;color:var(--teal-dark);cursor:pointer;justify-content:space-between;align-items:center;gap:10px;padding:0 12px;font-weight:800;list-style:none;display:flex}.mobile-toc summary:focus{outline:none}.mobile-toc summary:focus-visible{box-shadow:inset 0 0 0 2px #079b9559}.mobile-toc summary::-webkit-details-marker{display:none}.mobile-toc summary:after{content:"展开";color:#6b7a8d;flex:none;font-size:12px;font-weight:800}.mobile-toc[open] summary:after{content:"收起"}.mobile-toc summary small{color:var(--muted);font-size:12px;font-weight:600}.mobile-toc-list{gap:8px;padding:0 10px 10px;display:flex;overflow-x:auto}.mobile-toc-list button{color:#526273;text-overflow:ellipsis;white-space:nowrap;background:#fff;border:1px solid #dce8ec;border-radius:7px;flex:none;max-width:188px;min-height:34px;padding:0 12px;overflow:hidden}.mobile-toc button.active{color:var(--teal-dark);background:var(--teal-soft);border-color:#079b9559}.paper{padding:18px 16px}.paper h1{overflow-wrap:anywhere;font-size:30px;line-height:1.28}.paper blockquote{margin:12px 0;padding:12px 14px}.article-actions{grid-template-columns:1fr;display:grid}.article-actions button{justify-content:center}.pager,.comment-input{grid-template-columns:1fr}.comment-input>.avatar{display:none}.comment-input>button{width:100%}.float-actions{display:none}.hero-card,.featured-card,.article-row,.profile,.form-grid,.project-grid{grid-template-columns:1fr;height:auto}.profile{grid-template-areas:"portrait""text";gap:18px}.profile-text{border-left:0;min-width:0;padding-left:0}.profile-text h1{overflow-wrap:anywhere;font-size:30px;line-height:1.25}.contact span{overflow-wrap:anywhere;word-break:break-word;min-width:0}.cooperate{text-align:center;grid-template-columns:1fr}.cooperate span{height:64px}.cooperate button{width:100%}.laptop-scene{display:none}.home-landing{margin:12px auto 34px;padding:0 14px}.home-hero-shell{min-height:560px}.home-hero-content{padding:72px 20px 124px}.home-hero-content h1{font-size:38px}.home-hero-subtitle{font-size:19px}.home-hero-copy{font-size:15px}.home-hero-actions{flex-direction:column;align-items:center}.home-primary-action,.home-secondary-action{width:min(260px,100%)}.home-entry-grid{grid-template-columns:1fr;gap:14px;margin-top:-56px;padding:0 10px}.home-entry-card{min-height:auto;padding:22px}.home-quiet-panel{grid-template-columns:1fr;margin-top:18px;padding:22px}.home-mini-stats{grid-template-columns:repeat(2,1fr)}.archive-layout{flex-direction:column;gap:16px;display:flex}.archive-category-panel{order:2;margin-bottom:0;position:static}.archive-main{order:1;gap:16px;display:grid}.archive-search-form{grid-template-columns:1fr;align-items:stretch}.archive-search-form div{grid-template-columns:1fr}.archive-search-form button{width:100%}.archive-active-filter{margin-left:0}.archive-hero{grid-template-columns:1fr;padding:24px 22px}.archive-hero h1{font-size:30px}.archive-hero button,.archive-result-head button{width:100%}.archive-featured-grid,.archive-featured-card{grid-template-columns:1fr}.archive-result-head{flex-direction:column;align-items:stretch}.message-title{flex-direction:column;align-items:flex-start;gap:10px}.message-form{padding:18px}.message-form footer{flex-direction:column;align-items:stretch}.message-form footer small{margin-left:0}.message-form footer>button{width:100%}.message-tabs{gap:16px;overflow-x:auto}.message-item{grid-template-columns:44px 1fr}.media-modal{padding:14px}.media-modal-panel{width:100%;max-height:92vh}.admin-app{background:#f5f8fb;min-height:100dvh}.admin-mobile-bar{z-index:80;min-height:64px;padding:max(10px, env(safe-area-inset-top)) 14px 10px;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff0;grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;gap:10px;display:grid;position:sticky;top:0}.admin-mobile-bar div{text-align:center;gap:2px;min-width:0;display:grid}.admin-mobile-bar strong{color:#172033;text-overflow:ellipsis;white-space:nowrap;font-size:16px;line-height:22px;overflow:hidden}.admin-mobile-bar small{color:var(--muted);font-size:12px;line-height:16px}.admin-mobile-menu-button,.admin-mobile-new-button{color:#213244;background:#fff;border:1px solid #dfe9ed;border-radius:10px;place-items:center;width:44px;height:44px;font-size:21px;font-weight:900;display:inline-grid;box-shadow:0 8px 18px #1f304414}.admin-mobile-new-button{color:#fff;background:var(--teal);border-color:#0000}.admin-side{z-index:100;width:min(84vw,318px);height:100dvh;padding-bottom:max(18px, env(safe-area-inset-bottom));border-right:1px solid var(--line);transition:transform .22s;position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-105%);box-shadow:24px 0 44px #0f172a2e}.admin-side nav{margin-top:20px}.admin-side nav button{min-height:46px}.admin-user{margin-top:18px}.admin-mobile-menu-open .admin-side{transform:translate(0)}.admin-mobile-backdrop{z-index:90;background:#0f172a61;border:0;border-radius:0;width:100%;height:100%;padding:0;display:block;position:fixed;inset:0}.admin-main{min-height:calc(100dvh - 64px)}.admin-top{display:none}.admin-content{background:#f5f8fb;padding:16px 14px 24px;display:block}.admin-content>*+*{margin-top:14px}.admin-stats{grid-template-columns:1fr;gap:12px;display:grid}.title-row{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:10px}.title-row h1{overflow-wrap:anywhere;font-size:22px;line-height:1.35}.title-row button,.title-actions button{justify-content:center;width:100%}.title-actions{grid-template-columns:1fr;gap:8px;width:100%;display:grid}.admin-row{flex-wrap:wrap;align-items:flex-start;gap:10px 12px;padding:14px 0}.admin-row>span{flex:min(100%,220px);line-height:1.55}.admin-row-actions{flex-wrap:wrap;flex:1 0 100%;justify-content:flex-start;gap:8px;width:100%}.admin-row-actions small{text-overflow:clip;white-space:normal;flex:1 0 100%;max-width:none;overflow:visible}.admin-row-actions button{min-height:34px}.admin-pagination{flex-wrap:wrap;gap:8px}.admin-pagination button{flex:96px}.editor{padding:16px 14px 24px}.editor-title{gap:6px;min-height:0;padding-right:0;display:grid}.editor-title h1{overflow-wrap:anywhere;font-size:24px;line-height:1.25}.editor-title span{overflow-wrap:anywhere;line-height:1.45}.title-input{margin-top:12px}.toolbar{flex-wrap:wrap;max-width:100%;height:auto;min-height:50px;overflow:visible}.toolbar button{flex:none}.editor-split{grid-template-columns:1fr}.markdown-pane{border-right:0}.markdown-editor-shell{grid-template-columns:38px minmax(0,1fr);height:520px}.markdown-pane textarea{padding:16px 14px}.preview-pane{border-top:1px solid var(--line)}.editor-actions{margin:12px 0;position:static}.publish-panel{margin-top:14px}.publish-panel .card:has(.cover-thumb){grid-template-columns:1fr}.about-config,.home-config,.site-config,.import-config,.security-config,.ai-settings-config,.settings-grid,.project-editor article,.timeline-editor article,.home-entry-editor article,.project-form-grid,.site-preview-grid,.site-share-preview,.inline-picker{grid-template-columns:1fr}.inline-picker button{min-height:38px}.media-filter-bar,.moderation-filter-bar{grid-template-columns:1fr}.media-type-tabs{width:100%}.media-type-tabs button{flex:1}.settings-panel.wide,.settings-grid .wide,.timeline-editor .wide,.home-entry-editor .wide,.project-form-grid .wide,.project-card-head{grid-column:auto}.project-editor header,.timeline-editor header,.home-entry-editor header,.settings-panel>header,.project-card-head{flex-direction:column;align-items:stretch}body{background:linear-gradient(#eef8f6 0,#f8fbfa 320px,#f6f8fb 100%)}.page,.article-layout,.archive-layout,.about-layout,.two-col{width:min(100% - 20px,100%);margin:10px auto 26px}.public-header{background:#ffffffe6;border:1px solid #cadae0c7;border-radius:18px;gap:10px;width:calc(100% - 20px);margin:10px auto 12px;padding:10px 12px 12px;position:relative;top:auto;box-shadow:0 12px 34px #1a2c3b1f}.public-header.floating-header{border-radius:18px;margin:10px auto 12px;top:auto;box-shadow:0 12px 34px #1a2c3b1f}.public-header .desktop-nav{display:none}.brand{gap:10px;min-width:0}.brand-mark{border-radius:13px;width:42px;height:42px;font-size:18px}.brand span{min-width:0}.brand strong{text-overflow:ellipsis;white-space:nowrap;max-width:calc(100vw - 120px);font-size:18px;line-height:1.25;overflow:hidden}.brand small{text-overflow:ellipsis;white-space:nowrap;max-width:calc(100vw - 120px);font-size:12px;line-height:1.35;overflow:hidden}.header-tools{grid-template-columns:minmax(0,1fr) 42px 64px;gap:8px}.search-mini{background:#f8fbfb;border-radius:14px;height:42px}.round{border-radius:14px;width:42px;height:42px}.admin-entry-button{color:#fff;background:#102033;border-color:#102033;border-radius:14px;min-width:64px;height:42px;box-shadow:0 10px 22px #1020332e}.admin-entry-button:hover{color:#fff;background:#172b42;border-color:#102033}.mobile-bottom-nav{left:10px;right:10px;bottom:max(10px, env(safe-area-inset-bottom));z-index:90;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff0;border:1px solid #cddae0db;border-radius:20px;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;padding:6px;display:grid;position:fixed;box-shadow:0 18px 42px #0f172a2e}.mobile-bottom-nav button{color:#657386;border-radius:15px;align-content:center;justify-items:center;gap:4px;min-width:0;min-height:54px;padding:6px 4px;font-size:11px;font-weight:800;display:grid}.mobile-bottom-nav button.active{color:#fff;background:#102033;box-shadow:0 10px 22px #10203333}.mobile-bottom-nav b{font-size:11px;line-height:1}.mobile-nav-icon{color:currentColor;width:22px;height:22px;position:relative}.mobile-nav-icon:before,.mobile-nav-icon:after{content:"";display:block;position:absolute}.mobile-nav-home:before{border:2px solid;border-top:0;border-radius:2px 2px 5px 5px;width:14px;height:11px;top:8px;left:4px}.mobile-nav-home:after{border-top:2px solid;border-left:2px solid;border-radius:3px 0 0;width:14px;height:14px;top:3px;left:4px;transform:rotate(45deg)}.mobile-nav-posts:before{border:2px solid;border-radius:5px;width:12px;height:16px;top:3px;left:5px}.mobile-nav-posts:after{background:currentColor;border-radius:2px;width:7px;height:2px;top:8px;left:8px;box-shadow:0 5px}.mobile-nav-about:before{border:2px solid;border-radius:50%;width:8px;height:8px;top:4px;left:7px}.mobile-nav-about:after{border:2px solid;border-radius:10px 10px 4px 4px;width:14px;height:8px;bottom:2px;left:4px}.mobile-nav-messages:before{border:2px solid;border-radius:7px;width:16px;height:12px;top:4px;left:3px}.mobile-nav-messages:after{border-bottom:2px solid;border-left:2px solid;width:7px;height:7px;bottom:3px;left:8px;transform:skew(-18deg)}.public-footer{padding-bottom:max(92px, env(safe-area-inset-bottom));margin-bottom:0;line-height:1.7}.card,.message-form,.paper{border-radius:18px}.home-landing{width:100%;margin:0 auto 26px;padding:0 0 18px}.home-hero-shell{min-height:488px;box-shadow:none;border:0;border-bottom:1px solid #cddae0cc;border-radius:0 0 28px 28px}.home-hero-blank{background:linear-gradient(#d8f3ee 0%,#f6fffb 62%,#fff8ed 100%)}.home-hero-blank:before,.home-hero-blank:after,.home-hero-orbit{display:none}.home-hero-horizon{background:linear-gradient(#f4cb8b9e,#fffffff5);height:164px;bottom:-74px;left:-18%;right:-18%}.home-hero-content{text-align:left;place-self:end stretch;max-width:none;padding:48px 24px 108px}.home-hero-content h1{max-width:9em;font-size:34px;line-height:1.18}.home-hero-subtitle{margin-top:14px;font-size:18px}.home-hero-copy{max-width:none;margin-top:14px;font-size:15px;line-height:1.8}.home-hero-actions{flex-flow:wrap;justify-content:flex-start;gap:10px;margin-top:24px}.home-primary-action,.home-secondary-action{border-radius:14px;flex:128px;width:auto;min-width:0;min-height:46px;padding:0 16px}.home-entry-grid{gap:10px;margin:-58px 10px 0;padding:0}.home-entry-card{border-radius:18px;grid-template-columns:46px minmax(0,1fr);gap:14px;padding:16px;box-shadow:0 12px 30px #0f172a17}.home-entry-icon{border-radius:14px;width:46px;height:46px}.home-entry-icon:before{width:20px;height:20px}.home-entry-icon.doc:after{width:14px;top:20px;left:16px}.home-entry-card b{font-size:18px}.home-entry-card small{margin-top:6px;line-height:1.65}.home-entry-card em{margin-top:12px}.home-quiet-panel{border-radius:18px;margin:14px 10px 0;padding:18px}.home-quiet-panel h2{font-size:21px;line-height:1.35}.home-mini-stats span{border-radius:14px;min-height:74px}.article-layout{margin-top:8px}.mobile-toc{z-index:18;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffeb;border-radius:16px;margin:0 0 10px;position:sticky;top:10px;box-shadow:0 10px 28px #0f172a14}.mobile-toc summary{color:#102033;min-height:48px;padding:0 14px}.mobile-toc summary:after{color:#a45f0a}.mobile-toc-list{scrollbar-width:none;gap:8px;padding:0 12px 12px}.mobile-toc-list::-webkit-scrollbar{display:none}.mobile-toc-list button{background:#f7fbfb;border-radius:999px;max-width:220px;min-height:36px}.paper{padding:0;overflow:hidden;box-shadow:0 16px 42px #0f172a1a}.cover{height:148px}.paper-body{padding:18px 16px 24px}.paper h1{margin-bottom:10px;font-size:28px;line-height:1.25}.paper .chip-row{align-items:flex-start;gap:8px}.paper .meta{flex-basis:100%;gap:8px;margin-top:3px;font-size:12px;line-height:1.5}.article-actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:14px 0 12px}.article-actions button{text-align:center;border-radius:14px;flex-direction:column;justify-content:center;gap:4px;min-width:0;min-height:50px;padding:8px 6px;font-size:12px;line-height:1.15;overflow:hidden}.article-actions span{width:24px;min-width:24px;height:24px}.paper blockquote{background:#f4f9f8;border-left:0;border-radius:16px;margin:14px 0 18px;padding:14px 16px;line-height:1.75}.article-section{scroll-margin-top:142px}.article-section>h2{margin:28px 0 10px;font-size:23px;line-height:1.35}.article-section>h3{margin:24px 0 8px;font-size:19px;line-height:1.4}.article-markdown{gap:14px}.preview-doc p,.article-markdown p,.article-markdown .markdown-list li{color:#34495e;font-size:16px;line-height:1.95}.markdown-image-button,.article-markdown .preview-inline-image{border-radius:16px;width:100%}.article-markdown .preview-inline-image{box-shadow:0 12px 30px #0f172a14}.markdown-table-scroll,.code-block{border-radius:14px}.pager{gap:10px}.pager button,.article-related-bottom button,.comment-compose{border-radius:14px}.comment-meta{grid-template-columns:1fr}.comment-meta input+input{border-left:0;border-top:1px solid var(--line)}.comment-input>button{border-radius:14px;height:44px}.article-related-bottom{border-radius:18px;margin:26px 0 4px;padding:16px}.article-related-bottom>div{grid-template-columns:1fr}.archive-layout,.archive-main{gap:14px}.archive-hero{color:#fff;background:linear-gradient(135deg,#102033 0%,#1f6b66 68%,#f4b466 100%);border:0;border-radius:22px;order:-1;padding:22px;box-shadow:0 16px 38px #1020332e}.archive-hero h1{color:#fff;font-size:30px;line-height:1.18}.archive-hero p{color:#ffffffd6;line-height:1.75}.archive-hero button{color:#102033;background:#fff;border:0;border-radius:14px;box-shadow:0 10px 20px #10203329}.archive-search-panel{border-radius:18px;padding:12px;box-shadow:0 12px 28px #0f172a14}.archive-search-form label{font-size:13px}.archive-search-form div{grid-template-columns:minmax(0,1fr) 76px;gap:8px}.archive-search-form input{border-radius:14px;height:44px}.archive-search-form button{border-radius:14px;width:auto;min-height:44px;padding:0 14px}.archive-search-form button.ghost{grid-column:1/-1;width:100%}.archive-active-filter{gap:6px 10px;font-size:12px}.archive-sort-toolbar{justify-content:flex-start;min-height:38px;padding:0;overflow-x:auto}.archive-sort-toolbar button{border-radius:999px;min-width:58px;min-height:34px}.archive-featured-card{border-radius:20px;grid-template-columns:1fr;gap:0;min-height:0;padding:0;overflow:hidden;box-shadow:0 14px 32px #0f172a17}.archive-featured-card .art{border-radius:0;height:168px}.archive-featured-card span{gap:9px;padding:16px}.archive-featured-card b{-webkit-line-clamp:3;font-size:21px;line-height:1.35}.archive-featured-card small{-webkit-line-clamp:3;line-height:1.72}.archive-pagination{border-radius:18px;flex-wrap:wrap;align-items:stretch;gap:8px;margin-top:4px;padding:12px}.archive-pagination span{text-align:center;order:-1;width:100%;font-size:13px}.archive-pagination button{border-radius:14px;flex:1}.archive-category-panel{border-radius:20px;padding:16px}.archive-category-panel p{margin-bottom:12px;font-size:13px}.filter button{border-radius:12px;min-height:42px}.about-main{border-radius:22px;padding:18px}.profile{justify-items:center;gap:16px}.portrait{border-radius:24px;max-width:178px;min-height:214px;box-shadow:0 16px 32px #1020331f}.profile-text h1{text-align:center}.profile-text p{line-height:1.85}.contact{gap:8px;margin-top:18px;display:grid}.contact span{background:#f8fbfb;border:1px solid #e4edf1;border-radius:14px;min-height:40px;padding:8px 12px}.skill-row{gap:8px}.skill-chip{border-radius:999px;min-height:30px;padding:4px 10px}.project-grid{gap:12px}.project-grid article{background:#fff;border-radius:18px;box-shadow:0 12px 28px #0f172a12}.project-grid article .art{height:178px}.cooperate{border-radius:20px;padding:18px}.about-layout>.side-stack{gap:12px;margin-top:14px;display:flex}.about-layout>.side-stack .card{border-radius:20px}.message-page{gap:14px}.message-title{color:#fff;background:#102033;border-radius:22px;margin:4px 0 12px;padding:18px}.message-title h1{color:#fff;font-size:30px;line-height:1.15}.message-title p{color:#ffffffc2;margin:10px 0 0;line-height:1.7}.message-title>span{color:#f4c77a}.message-title-icon{border-color:#fff}.message-title-icon:before{background:#102033;border-color:#fff}.message-title-icon:after{background:#ffffffb3;box-shadow:0 7px #ffffffb3}.message-form{border-radius:20px;padding:16px}.message-form input,.message-form textarea{border-radius:14px}.message-form textarea{min-height:160px;line-height:1.75}.message-form footer{gap:10px}.message-form footer>button{border-radius:14px;min-height:44px}.message-tabs{scrollbar-width:none;background:#eaf1f0;border:0;border-radius:16px;gap:6px;margin:14px 0 12px;padding:5px}.message-tabs::-webkit-scrollbar{display:none}.message-tabs button{white-space:nowrap;border-radius:12px;flex:none;min-height:38px;padding:0 12px}.message-tabs button.active{color:#fff;background:#102033;border-bottom:0}.message-tabs select{border-radius:12px;flex:none;height:38px;margin-left:0}.message-list{gap:10px;display:grid}.message-item{border-radius:18px;grid-template-columns:40px minmax(0,1fr);gap:10px;padding:14px}.message-list>.message-item:before{top:70px;bottom:18px;left:34px}.message-item>.avatar{width:40px;height:40px}.message-item h3{flex-wrap:wrap;align-items:center;gap:5px;line-height:1.45;display:flex}.message-item p{line-height:1.75}.message-item button{color:#91520b;background:#fff5e6;border-radius:12px;min-height:34px;padding:0 12px}.message-item .approved{grid-column:2;justify-self:start;margin-top:2px;font-size:12px;position:static}.message-item .message-item{margin-top:12px}.message-item .message-item:before{width:22px;left:-30px}.list-count{margin-top:12px}.load-more{border-radius:14px;width:100%;min-height:42px}}
