:root{font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei UI,Microsoft YaHei,Noto Sans CJK SC,Source Han Sans SC,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{min-width:320px;color:#586e75;background:radial-gradient(circle at 10% 8%,rgba(38,139,210,.11) 0%,transparent 42%),radial-gradient(circle at 92% 2%,rgba(181,137,0,.12) 0%,transparent 38%),linear-gradient(150deg,#fdf6e3,#f7f0db 58%,#eee8d5);cursor:default}#root{cursor:default}button,a,[role=button],[draggable=true]{cursor:pointer}input,textarea,select{cursor:text}.app-shell{width:min(1140px,92vw);margin:30px auto}.hero{background:linear-gradient(150deg,#fdf6e3f2,#f6eed4eb);border:1px solid rgba(147,161,161,.35);border-radius:18px;padding:22px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.hero.compact{padding:18px 20px}.eyebrow{margin:0 0 8px;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:#b58900;font-weight:700}h1{margin:0;font-size:clamp(1.4rem,2.8vw,2.1rem);color:#073642}.login-title-trigger{cursor:pointer}.title-authenticated{color:#4da635}.subtitle{margin:6px 0 0;color:#657b83}.panel{border:1px solid rgba(147,161,161,.35);background:#fdf6e3db;border-radius:15px;padding:16px}.toolbar{display:grid;grid-template-columns:1fr 220px;gap:10px}.toolbar.single{grid-template-columns:1fr}.search-shell{display:grid;grid-template-columns:40px 1fr 40px;gap:8px;align-items:center;padding:2px;border:1px solid rgba(131,148,150,.45);border-radius:14px;background:#fdf6e3;box-shadow:inset 0 1px #ffffffb8}.news-card{padding:0;border:none;background:transparent;box-shadow:none}.news-inline{margin-top:10px}.news-inline-row{margin-top:10px;display:flex;align-items:baseline;gap:12px}.news-inline-row .news-inline{flex:1;margin-top:0;display:flex;align-items:center;min-height:24px}.news-inline-count{margin:0;white-space:nowrap;line-height:24px}.news-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:9px}.news-head strong{color:#073642;font-size:.92rem;letter-spacing:.02em}.news-refresh-btn{padding:0;border-radius:999px;font-size:.72rem;line-height:1.2;border:none;background:transparent;color:#268bd2;text-decoration:underline;text-underline-offset:2px}.news-list{display:grid;gap:8px;max-height:276px;overflow:auto;padding-right:2px}.news-ticker-window{height:24px;overflow:hidden;position:relative}.news-ticker-track{display:grid;grid-auto-rows:24px;transform:translateY(0)}.news-ticker-track.animating{transform:translateY(-24px);transition:transform .34s ease}.ticker-line{height:24px;display:flex;align-items:center}.news-item{display:grid;gap:2px;padding:0;text-decoration:none;background:transparent;transition:color .12s ease}.news-item:hover{transform:none}.news-title{color:#073642;font-size:.82rem;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.news-meta{color:#657b83;font-size:.72rem}.engine-picker{position:relative;display:inline-flex;align-items:center;justify-content:center}.engine-trigger{width:36px;height:36px;border:1px solid transparent;border-radius:9px;background:transparent;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.engine-trigger img{width:20px;height:20px;display:block}.engine-trigger:hover{border-color:#b9c3c0}.engine-menu{position:absolute;top:46px;left:0;display:grid;gap:6px;padding:8px;border:1px solid #93a1a1;background:#fdf6e3;border-radius:10px;box-shadow:0 8px 20px #586e752e;z-index:10}.search-input{border:none;background:transparent;color:#073642;padding:8px 4px}.search-input:focus{outline:none;box-shadow:none}.search-submit{width:36px;height:36px;border:1px solid transparent;background:transparent;border-radius:9px;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.search-submit:hover{border-color:#b9c3c0}.engine-option{width:34px;height:34px;border:1px solid #c7d0cd;background:#fdf6e3;border-radius:8px;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.engine-option img{width:18px;height:18px}.engine-option.active,.engine-option:hover{border-color:#268bd2;box-shadow:0 0 0 2px #268bd226}label{display:flex;flex-direction:column;gap:6px;color:#586e75;font-size:.9rem}input,select,textarea,button{font:inherit}input,select,textarea{border:1px solid #93a1a1;background:#fdf6e3;color:#073642;border-radius:10px;padding:9px 10px}input:focus,select:focus,textarea:focus{outline:none;border-color:#268bd2;box-shadow:0 0 0 3px #268bd233}.hint{margin:12px 0 0;color:#2aa198;font-size:.9rem}.hint.subtle{margin:0;color:#6c7d83;font-size:.84rem}.group-list{display:grid;gap:14px;margin-top:16px}.group-drop-ghost{height:14px;border-radius:999px;border:2px dashed rgba(38,139,210,.72);background:#268bd214;color:#268bd2;font-size:.72rem;display:grid;place-items:center;animation:ghostPulse .9s ease-in-out infinite}.group-drop-ghost.tail{margin-top:-2px}.group h2{margin:0 0 12px}.group h2 span{font-size:.9rem;color:#657b83;font-weight:400}.group h2{display:flex;align-items:center;gap:10px}.group-name{border:none;background:transparent;padding:0;color:#073642;font-weight:700;font-size:1rem;cursor:default}.group-drag-handle{border:1px dashed #93a1a1;background:#fdf6e3;color:#657b83;border-radius:8px;width:24px;height:24px;padding:0;font-size:.75rem;line-height:1;cursor:grab;display:inline-flex;align-items:center;justify-content:center}.group-drag-source{opacity:.45}.group-name.editable{cursor:pointer;text-decoration:underline dotted;text-underline-offset:3px}.group-remove-btn{margin-left:auto;width:18px;height:18px;border:1px solid rgba(220,50,47,.35);background:#fff;color:#dc322f;border-radius:999px;padding:0;font-size:.69rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.group-remove-btn:hover{background:#dc322f;color:#fff}.add-group-btn{border:1px dashed #93a1a1;background:#fdf6e3;color:#657b83;border-radius:999px;width:24px;height:24px;line-height:1;font-size:1rem;cursor:pointer}.add-group-card h2{margin:0;justify-content:center}.add-group-entry{border:1px dashed #93a1a1;background:#fdf6e3;color:#586e75;border-radius:10px;width:40px;height:40px;padding:0;font-weight:600;font-size:1.4rem;line-height:1;cursor:pointer}.add-group-entry:hover{border-color:#268bd2;color:#268bd2}.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,88px));gap:16px;align-content:start;min-height:104px}.site-cell{display:contents}.site-icon-wrap{width:88px;min-height:108px;position:relative;display:grid;grid-template-rows:68px auto;justify-items:center;gap:8px;transition:transform .18s ease,opacity .18s ease,filter .18s ease}.site-icon-wrap.dragging{opacity:.35;transform:scale(.92);filter:saturate(.8)}.site-icon-wrap.just-moved{animation:siteSnapIn .22s ease-out}.site-icon-wrap.site-shifted{animation:sitePushed .17s ease-out}.site-ghost-wrap{pointer-events:none}.site-icon-btn{border:1px solid #c9d4d1;background:#fdf6e3;border-radius:999px;width:68px;height:68px;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative;overflow:hidden}.site-icon-btn:hover{border-color:#268bd2;box-shadow:0 4px 10px #268bd226}.site-icon-btn img,.site-favicon{width:36px;height:36px;display:block}.site-favicon.placeholder{position:absolute;opacity:1;transition:opacity .12s ease}.site-favicon.real{position:absolute;width:56px;height:56px;opacity:0;transition:opacity .18s ease}.site-favicon.real.loaded{opacity:1}.site-icon-btn.has-real-favicon .site-favicon.placeholder{opacity:0}.site-drop-ghost{width:68px;height:68px;border-radius:999px;border:2px dashed rgba(38,139,210,.75);background:#268bd214;box-shadow:inset 0 0 0 2px #fdf6e399;animation:ghostPulse .9s ease-in-out infinite}.site-drag-float{position:fixed;width:72px;height:72px;border-radius:999px;border:2px solid rgba(38,139,210,.45);background:#fdf6e3;box-shadow:0 8px 20px #0736423d;display:inline-flex;align-items:center;justify-content:center;pointer-events:none;transform:translate(-50%,-50%);z-index:9999}.site-drag-float img{width:40px;height:40px;display:block}.group-drag-float{position:fixed;max-width:240px;border-radius:10px;border:1px solid rgba(38,139,210,.55);background:#fdf6e3;box-shadow:0 8px 20px #07364238;padding:8px 10px;color:#073642;font-size:.86rem;font-weight:700;pointer-events:none;transform:translate(-12px,-16px);z-index:9999}.ghost-label{color:#268bd2}.site-add-btn{font-size:2rem;line-height:1;color:#657b83}.site-add-btn:hover{color:#268bd2}.site-label{margin:0;max-width:88px;font-size:.78rem;line-height:1.25;text-align:center;color:#586e75;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-remove-btn{position:absolute;top:-4px;right:2px;width:16px;height:16px;border:1px solid rgba(220,50,47,.35);background:#fff;color:#dc322f;border-radius:999px;padding:0;font-size:.65rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.site-remove-btn:hover{background:#dc322f;color:#fff}.chips{display:flex;gap:6px;flex-wrap:wrap}.chip{border:1px solid rgba(147,161,161,.45);border-radius:999px;padding:2px 8px;font-size:.72rem;color:#586e75;background:#fdf6e3;cursor:pointer}.chip.active{border-color:#268bd2;box-shadow:0 0 0 2px #268bd21f;color:#073642}.chip:disabled{opacity:.45;cursor:not-allowed}.editor-favicon-preview{width:40px;height:40px;border-radius:10px;border:1px solid #c9d4d1;background:#fdf6e3;display:inline-flex;align-items:center;justify-content:center;margin-left:2px}.editor-favicon-preview img{width:28px;height:28px;display:block}.ghost-btn,.primary-btn{border-radius:10px;border:1px solid #93a1a1;padding:8px 13px;background:#fdf6e3;color:#073642;cursor:pointer}.primary-btn{border-color:#268bd2b8;background:linear-gradient(135deg,#268bd2,#2aa198);color:#fff}.actions{display:flex;gap:8px;align-items:center}.icon-action{position:relative;min-width:40px;width:40px;height:40px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:1rem}.icon-action:after{content:attr(data-tip);position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);background:#073642;color:#fdf6e3;font-size:.72rem;line-height:1;padding:6px 8px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .12s ease}.icon-action:hover:after{opacity:1}.icon-action.active{border-color:#268bd2;box-shadow:0 0 0 2px #268bd226}.error{color:#dc322f}.ok{color:#2aa198}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#07364247;display:flex;align-items:center;justify-content:center;padding:20px;z-index:20}.modal{width:min(460px,92vw);background:#fdf6e3;border:1px solid #93a1a1;border-radius:14px;padding:16px}.modal h3{margin:0 0 12px;color:#073642}.modal form{display:grid;gap:10px}@keyframes ghostPulse{0%{transform:scale(.96);opacity:.75}50%{transform:scale(1.02);opacity:1}to{transform:scale(.96);opacity:.75}}@keyframes siteSnapIn{0%{transform:scale(.88)}60%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes sitePushed{0%{transform:translate(-20px) scale(.97)}to{transform:translate(0) scale(1)}}@media(max-width:920px){.hero{flex-direction:column;align-items:flex-start}.toolbar{grid-template-columns:1fr}.search-shell{grid-template-columns:40px 1fr 40px}.news-inline-row{flex-direction:column;align-items:flex-start;gap:6px}.news-inline-count{white-space:normal}}
