*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f13;--bg-card:#1a1a24;--bg-sidebar:#14141c;--bg-hover:#22222e;--text:#a0a0b0;--text-bright:#e4e4ef;--accent:#6366f1;--accent-hover:#818cf8;--border:#2a2a3a;--success:#22c55e;--danger:#ef4444;--warning:#f59e0b;--radius:10px;--sidebar-width:220px;--font:"Inter", system-ui, -apple-system, sans-serif}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}.layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border);z-index:100;flex-direction:column;height:100vh;padding:20px 12px;transition:transform .25s;display:flex;position:fixed;top:0;left:0}.sidebar-brand{color:var(--text-bright);letter-spacing:-.5px;padding:8px 12px 24px;font-size:20px;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:4px;display:flex;overflow-y:auto}.sidebar-divider{background:var(--border);height:1px;margin:8px 12px}.sidebar-footer{border-top:1px solid var(--border);padding-top:8px}.sidebar-auth-btn{width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 12px;font-size:13px;transition:all .15s;display:flex}.sidebar-auth-btn:hover{background:var(--bg-hover);color:var(--text-bright)}.sidebar-link{color:var(--text);border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;transition:all .15s;display:flex}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-bright)}.sidebar-link.active{background:var(--accent);color:#fff}.sidebar-icon{text-align:center;width:24px;font-size:18px}.sidebar-overlay{display:none}.sidebar-toggle{z-index:200;background:var(--bg-sidebar);border:1px solid var(--border);border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:36px;height:36px;transition:left .25s;display:none;position:fixed;top:12px;left:12px;box-shadow:0 2px 8px #0006}.sidebar-toggle span{background:var(--text-bright);border-radius:2px;width:18px;height:2px;display:block}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;padding:32px 40px}.home-header{margin-bottom:40px}.home-header h1{color:var(--text-bright);letter-spacing:-.5px;margin-bottom:8px;font-size:32px;font-weight:700}.home-header p{color:var(--text);font-size:15px}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:12px;padding:24px;transition:all .2s;display:flex}.project-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.project-card-icon{font-size:32px}.project-card-name{color:var(--text-bright);font-size:18px;font-weight:600}.project-card-desc{color:var(--text);font-size:14px;line-height:1.5}.project-card-arrow{color:var(--accent);margin-top:auto;font-size:13px}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:99;background:#00000080;display:block;position:fixed;inset:0}.sidebar-toggle{display:flex}.sidebar-toggle.shifted{left:calc(var(--sidebar-width) + 8px)}.main-content{margin-left:0;padding:60px 16px 20px}.projects-grid{grid-template-columns:1fr}}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:10px 18px;font-family:inherit;font-size:.875rem;font-weight:500;transition:background .15s,opacity .15s,border-color .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{color:var(--text);background:0 0;padding:4px 8px}.btn-ghost:hover{color:var(--accent)}.btn-outline{border:1px solid var(--border);color:var(--text);background:0 0}.btn-outline:hover:not(:disabled){border-color:var(--text)}.btn-sm{padding:6px 12px;font-size:.8rem}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.8}}.skeleton{background:var(--bg-hover);border-radius:6px;animation:1.5s ease-in-out infinite skeleton-pulse}.skeleton-line{height:14px;margin-bottom:10px}.skeleton-thumb{aspect-ratio:16/9;border-radius:var(--radius);width:100%}.skeleton-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.skeleton-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:10px;padding:12px;display:flex}.skeleton-text{flex-direction:column;gap:8px;display:flex}.error-boundary{justify-content:center;align-items:center;min-height:40vh;padding:40px 20px;display:flex}.error-boundary-content{text-align:center;max-width:400px}.error-boundary-content h2{color:var(--text-bright);margin-bottom:12px;font-size:1.5rem;font-weight:700}.error-boundary-content p{color:var(--text);margin-bottom:24px;font-size:.9rem;line-height:1.6}:focus-visible,button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.sr-only,.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.app-loading{min-height:200px;color:var(--text);justify-content:center;align-items:center;font-size:.9rem;display:flex}.bookmarks-app{--bm-accent:#6366f1;--bm-accent-hover:#818cf8;--bm-surface:#1a1a24;--bm-surface-hover:#22222e;--bm-border:#2a2a3a;--bm-text:#a0a0b0;--bm-text-bright:#e4e4ef;--bm-danger:#ef4444;--bm-radius:10px}.bm-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.bm-header h2{color:var(--bm-text-bright);margin:0;font-size:1.3rem}.bm-header-actions{align-items:center;gap:.5rem;display:flex}.bm-data-manager{align-items:center;gap:.3rem;display:flex}.bm-btn-sm{min-width:auto;padding:.3rem}.bookmarks-app .tab-bar{margin-bottom:24px}.bookmarks-app .tab-list{border-bottom:1px solid var(--bm-border);gap:4px;padding-bottom:4px;display:flex;overflow-x:auto}.bookmarks-app .tab-item{color:var(--bm-text);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:6px 6px 0 0;align-items:center;gap:4px;padding:8px 16px;font-size:.875rem;transition:all .15s;display:flex}.bookmarks-app .tab-item:hover{color:var(--bm-text-bright);background:var(--bm-surface)}.bookmarks-app .tab-item.active{color:var(--bm-accent);border-bottom-color:var(--bm-accent);background:var(--bm-surface)}.bookmarks-app .tab-name{-webkit-user-select:none;user-select:none}.bookmarks-app .tab-delete{color:var(--bm-text);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;padding:1px 4px;font-size:.7rem;line-height:1;transition:opacity .15s}.bookmarks-app .tab-item:hover .tab-delete{opacity:1}.bookmarks-app .tab-delete:hover{color:var(--bm-danger);background:#ef44441a}.bookmarks-app .tab-edit-form,.bookmarks-app .tab-add-form{display:inline}.bookmarks-app .tab-edit-input,.bookmarks-app .tab-add-input{background:var(--bm-surface-hover);border:1px solid var(--bm-accent);width:100px;color:var(--bm-text-bright);border-radius:4px;outline:none;padding:4px 8px;font-size:.8rem}.bookmarks-app .tab-add-btn{color:var(--bm-text);border:1px dashed var(--bm-border);cursor:pointer;background:0 0;border-radius:6px 6px 0 0;padding:6px 14px;font-size:1rem;transition:all .15s}.bookmarks-app .tab-add-btn:hover{color:var(--bm-accent);border-color:var(--bm-accent)}.bm-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.bm-card{background:var(--bm-surface);border:1px solid var(--bm-border);border-radius:var(--bm-radius);transition:transform .15s,box-shadow .15s,border-color .15s;overflow:hidden}.bm-card:hover{border-color:var(--bm-accent);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.bm-card-link{color:inherit;align-items:flex-start;gap:12px;padding:20px;text-decoration:none;display:flex}.bm-card-icon{flex-shrink:0;font-size:28px;line-height:1}.bm-card-favicon{object-fit:contain;border-radius:4px;width:28px;height:28px}.bm-card-body{flex:1;min-width:0}.bm-card-title{color:var(--bm-text-bright);word-break:break-word;margin-bottom:4px;font-size:.95rem;font-weight:600}.bm-card-desc{color:var(--bm-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.8rem;line-height:1.4;display:-webkit-box;overflow:hidden}.bm-card-actions{gap:4px;padding:0 20px 12px;display:flex}.bm-card-actions .bm-btn-danger:hover{color:var(--bm-danger)}.bm-form{background:var(--bm-surface);border:1px solid var(--bm-border);border-radius:var(--bm-radius);margin-bottom:1.25rem;padding:1.25rem}.bm-form-title{color:var(--bm-text-bright);margin:0 0 1rem;font-size:1rem}.bm-form-field{margin-bottom:.85rem}.bm-form-field label{color:var(--bm-text);margin-bottom:.3rem;font-size:.8rem;display:block}.bm-form-field input,.bm-form-field textarea{background:var(--bm-surface-hover);border:1px solid var(--bm-border);width:100%;color:var(--bm-text-bright);box-sizing:border-box;border-radius:6px;outline:none;padding:.55rem .7rem;font-family:inherit;font-size:.9rem;transition:border-color .15s}.bm-form-field input:focus,.bm-form-field textarea:focus{border-color:var(--bm-accent)}.bm-form-field textarea{resize:vertical}.bm-form-hint{color:var(--bm-text);margin-top:.2rem;font-size:.75rem}.bm-form-actions{gap:.5rem;margin-top:.25rem;display:flex}.bm-empty{text-align:center;color:var(--bm-text);padding:60px 20px}.bm-empty p{margin-bottom:8px}.bm-error{border:1px solid var(--bm-danger);border-radius:var(--bm-radius);color:var(--bm-danger);background:#ef44441a;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.65rem 1rem;font-size:.85rem;display:flex}.bm-error button{color:var(--bm-danger);cursor:pointer;background:0 0;border:none;padding:.2rem;font-size:1rem;line-height:1}@media (width<=640px){.bm-grid{grid-template-columns:1fr}.bm-header{flex-direction:column;align-items:flex-start;gap:.75rem}}.color-app{--cl-accent:#6366f1;--cl-accent-hover:#818cf8;--cl-surface:#1a1a24;--cl-surface-hover:#22222e;--cl-border:#2a2a3a;--cl-text:#a0a0b0;--cl-text-bright:#e4e4ef;--cl-success:#22c55e;--cl-danger:#ef4444;--cl-radius:10px;max-width:860px;margin:0 auto;padding:0 1rem}.color-app .cl-header{align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.color-app .cl-header h2{color:var(--cl-text-bright);margin:0;font-size:1.35rem}.color-app .cl-header__name{color:var(--cl-text);font-size:.85rem;font-style:italic}.color-app .cl-history{flex-wrap:wrap;gap:4px;margin-bottom:1rem;display:flex}.color-app .cl-history__item{cursor:pointer;border:1px solid var(--cl-border);border-radius:4px;width:24px;height:24px;transition:transform .12s}.color-app .cl-history__item:hover{transform:scale(1.2)}.color-app .cl-tabs{border-bottom:1px solid var(--cl-border);-webkit-overflow-scrolling:touch;gap:0;margin-bottom:1.5rem;display:flex;overflow-x:auto}.color-app .cl-tabs__btn{color:var(--cl-text);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:.6rem .75rem;font-size:.8rem;transition:color .15s,border-color .15s}.color-app .cl-tabs__btn:hover{color:var(--cl-text-bright)}.color-app .cl-tabs__btn--active{color:var(--cl-accent);border-bottom-color:var(--cl-accent)}.color-app .cl-input__split{align-items:flex-start;gap:1.5rem;display:flex}.color-app .cl-input__preview{border-radius:var(--cl-radius);cursor:pointer;justify-content:center;align-items:center;width:200px;min-width:200px;height:100%;min-height:220px;display:flex;position:relative;overflow:hidden}.color-app .cl-input__native-picker{opacity:0;cursor:pointer;border:none;width:100%;height:100%;position:absolute;inset:0}.color-app .cl-input__preview-label{opacity:.7;pointer-events:none;font-size:.85rem}.color-app .cl-input__formats{flex-direction:column;flex:1;gap:.6rem;min-width:0;display:flex}.color-app .cl-input__row{grid-template-columns:52px 1fr auto;align-items:center;gap:.6rem;display:grid}.color-app .cl-input__label{color:var(--cl-text);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600}.color-app .cl-input__fields{gap:.35rem;display:flex}.color-app .cl-input__field{background:var(--bg,#0f0f13);border:1px solid var(--cl-border);color:var(--cl-text-bright);border-radius:6px;outline:none;padding:.4rem .5rem;font-family:inherit;font-size:.85rem;transition:border-color .15s}.color-app .cl-input__field:focus{border-color:var(--cl-accent)}.color-app .cl-input__field--hex{width:100%;max-width:120px;font-family:monospace}.color-app .cl-input__field--num{text-align:center;width:56px}.color-app .cl-input__field--num::-webkit-inner-spin-button{opacity:.3}.color-app .cl-swatch{cursor:pointer;border-radius:8px;flex-shrink:0;transition:transform .12s;position:relative;overflow:hidden}.color-app .cl-swatch:hover{transform:scale(1.06)}.color-app .cl-swatch--sm{width:48px;height:48px}.color-app .cl-swatch--md{width:64px;height:64px}.color-app .cl-swatch__overlay{opacity:0;background:#00000040;flex-direction:column;justify-content:center;align-items:center;gap:2px;transition:opacity .15s;display:flex;position:absolute;inset:0}.color-app .cl-swatch:hover .cl-swatch__overlay{opacity:1}.color-app .cl-swatch__label{font-family:monospace;font-size:.6rem;font-weight:600}.color-app .cl-swatch__copy{cursor:pointer;background:0 0;border:none;padding:0;font-size:.55rem;text-decoration:underline}.color-app .cl-swatch__bottom-label{text-align:center;font-family:monospace;font-size:.55rem;position:absolute;bottom:3px;left:0;right:0}.color-app .cl-palette__section{margin-bottom:1.25rem}.color-app .cl-palette__title{color:var(--cl-text);margin:0 0 .5rem;font-size:.85rem;font-weight:500}.color-app .cl-palette__row{flex-wrap:wrap;gap:.5rem;display:flex}.color-app .cl-contrast__inputs{align-items:flex-end;gap:1rem;margin-bottom:1.25rem;display:flex}.color-app .cl-contrast__color-group{flex:1}.color-app .cl-contrast__label{color:var(--cl-text);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.4rem;font-size:.75rem;font-weight:600;display:block}.color-app .cl-contrast__picker-row{align-items:center;gap:.5rem;display:flex}.color-app .cl-contrast__mini-swatch{border:1px solid var(--cl-border);border-radius:6px;flex-shrink:0;width:36px;height:36px;position:relative;overflow:hidden}.color-app .cl-contrast__swap{flex-shrink:0;align-self:flex-end;padding:.35rem .5rem;font-size:1.2rem}.color-app .cl-contrast__ratio{text-align:center;margin-bottom:1rem}.color-app .cl-contrast__ratio-value{color:var(--cl-text-bright);font-size:2.5rem;font-weight:700}.color-app .cl-contrast__results{grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1.25rem;display:grid}.color-app .cl-contrast__result{background:var(--cl-surface);border-left:3px solid;border-radius:8px;justify-content:space-between;align-items:center;padding:.6rem .8rem;display:flex}.color-app .cl-contrast__pass{border-left-color:var(--cl-success)}.color-app .cl-contrast__pass .cl-contrast__result-value{color:var(--cl-success);font-weight:600}.color-app .cl-contrast__fail{border-left-color:var(--cl-danger)}.color-app .cl-contrast__fail .cl-contrast__result-value{color:var(--cl-danger);font-weight:600}.color-app .cl-contrast__result-label{color:var(--cl-text);font-size:.8rem}.color-app .cl-contrast__preview{border-radius:var(--cl-radius);border:1px solid var(--cl-border);padding:1.25rem}.color-app .cl-contrast__preview p{margin:0 0 .5rem}.color-app .cl-contrast__preview p:last-child{margin-bottom:0}.color-app .cl-shades__section{margin-bottom:1.5rem}.color-app .cl-shades__title{color:var(--cl-text);margin:0 0 .5rem;font-size:.85rem;font-weight:500}.color-app .cl-shades__strip{gap:2px;display:flex}.color-app .cl-shades__cell{cursor:pointer;flex:1;justify-content:center;align-items:center;height:56px;transition:transform .12s;display:flex;position:relative}.color-app .cl-shades__cell:first-child{border-radius:8px 0 0 8px}.color-app .cl-shades__cell:last-child{border-radius:0 8px 8px 0}.color-app .cl-shades__cell:hover{z-index:1;transform:scaleY(1.15)}.color-app .cl-shades__cell-label{opacity:0;pointer-events:none;font-family:monospace;font-size:.5rem;transition:opacity .15s}.color-app .cl-shades__cell:hover .cl-shades__cell-label{opacity:1}.color-app .cl-gradient__preview{border-radius:var(--cl-radius);width:100%;height:120px;margin-bottom:1.25rem}.color-app .cl-gradient__controls{flex-direction:column;gap:1rem;margin-bottom:1.25rem;display:flex}.color-app .cl-gradient__type-row{gap:.5rem;display:flex}.color-app .cl-gradient__angle-row{align-items:center;gap:.75rem;display:flex}.color-app .cl-gradient__slider{accent-color:var(--cl-accent);flex:1}.color-app .cl-gradient__angle-val{color:var(--cl-text-bright);min-width:40px;font-size:.85rem}.color-app .cl-gradient__stops{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.color-app .cl-gradient__stop{align-items:center;gap:.4rem;display:flex}.color-app .cl-gradient__stop-hex{color:var(--cl-text);font-family:monospace;font-size:.75rem}.color-app .cl-gradient__code{background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:8px;align-items:center;gap:.75rem;padding:.6rem .8rem;display:flex}.color-app .cl-gradient__code code{color:var(--cl-text-bright);word-break:break-all;flex:1;font-size:.78rem}.color-app .cl-extractor__drop{border:2px dashed var(--cl-border);border-radius:var(--cl-radius);cursor:pointer;width:100%;min-height:160px;color:var(--cl-text);justify-content:center;align-items:center;margin-bottom:1.25rem;font-size:.85rem;transition:border-color .15s;display:flex;overflow:hidden}.color-app .cl-extractor__drop:hover{border-color:var(--cl-accent)}.color-app .cl-extractor__img{object-fit:contain;max-width:100%;max-height:300px}.color-app .cl-extractor__results{margin-top:1rem}.color-app .cl-blindness__grid{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem;display:grid}.color-app .cl-blindness__card{border:1px solid var(--cl-border);border-radius:8px;overflow:hidden}.color-app .cl-blindness__swatch{justify-content:center;align-items:center;height:72px;font-family:monospace;font-size:.8rem;font-weight:600;display:flex}.color-app .cl-blindness__info{background:var(--cl-surface);flex-direction:column;gap:2px;padding:.5rem .75rem;display:flex}.color-app .cl-blindness__info strong{color:var(--cl-text-bright);font-size:.8rem}.color-app .cl-blindness__info span{color:var(--cl-text);font-size:.7rem}.color-app .cl-blindness__strips{flex-direction:column;gap:.35rem;display:flex}.color-app .cl-blindness__strip-row{align-items:center;gap:.75rem;display:flex}.color-app .cl-blindness__strip-label{color:var(--cl-text);min-width:90px;font-size:.7rem}.color-app .cl-blindness__strip{border-radius:4px;flex:1;height:28px}.color-app .cl-toast{background:var(--cl-surface);color:var(--cl-text-bright);border:1px solid var(--cl-border);z-index:1000;border-radius:8px;padding:.6rem 1rem;font-size:.85rem;animation:.2s cl-toast-in;position:fixed;bottom:24px;right:24px}@keyframes cl-toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (width<=640px){.color-app .cl-input__split{flex-direction:column}.color-app .cl-input__preview{width:100%;min-width:unset;min-height:100px}.color-app .cl-input__row{grid-template-columns:1fr;gap:.35rem}.color-app .cl-input__label{margin-bottom:0}.color-app .cl-swatch--md{width:48px;height:48px}.color-app .cl-contrast__inputs{flex-direction:column;align-items:stretch}.color-app .cl-contrast__swap{align-self:center}.color-app .cl-contrast__results{grid-template-columns:1fr}.color-app .cl-shades__cell-label{display:none}.color-app .cl-shades__cell{height:40px}.color-app .cl-blindness__grid{grid-template-columns:1fr}.color-app .cl-gradient__stops{flex-direction:column;align-items:flex-start}}.facebook-app{--fb-bg:#0f0f0f;--fb-surface:#1a1a1a;--fb-surface-hover:#252525;--fb-border:#2a2a2a;--fb-text:#f1f1f1;--fb-text-secondary:#aaa;--fb-accent:#1877f2;--fb-accent-hover:#4293f5;--fb-green:#2ea043;--fb-green-hover:#3fb950;--fb-radius:12px;color:var(--fb-text);line-height:1.5}.facebook-header{border-bottom:1px solid var(--fb-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:32px;padding:20px 0;display:flex}.facebook-header h2{color:var(--fb-accent);font-size:1.5rem;font-weight:700}.facebook-app .header-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.facebook-app .range-toggle{background:var(--fb-surface);border:1px solid var(--fb-border);border-radius:8px;display:flex;overflow:hidden}.facebook-app .range-btn{color:var(--fb-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:0;padding:6px 12px;font-size:.8rem;transition:all .15s}.facebook-app .range-btn.active{background:var(--fb-accent);color:#fff}.facebook-app .range-btn:hover:not(.active){color:var(--fb-text)}.facebook-app .tab-bar{margin-bottom:24px}.facebook-app .tab-list{border-bottom:1px solid var(--fb-border);gap:4px;padding-bottom:4px;display:flex;overflow-x:auto}.facebook-app .tab-item{color:var(--fb-text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:6px 6px 0 0;align-items:center;gap:4px;padding:8px 16px;font-size:.875rem;transition:all .15s;display:flex}.facebook-app .tab-item:hover{color:var(--fb-text);background:var(--fb-surface)}.facebook-app .tab-item.active{color:var(--fb-accent);border-bottom-color:var(--fb-accent);background:var(--fb-surface)}.facebook-app .tab-name{-webkit-user-select:none;user-select:none}.facebook-app .tab-delete{color:var(--fb-text-secondary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;padding:1px 4px;font-size:.7rem;line-height:1;transition:opacity .15s}.facebook-app .tab-item:hover .tab-delete{opacity:1}.facebook-app .tab-delete:hover{color:var(--fb-accent);background:#1877f21a}.facebook-app .tab-edit-form,.facebook-app .tab-add-form{display:inline}.facebook-app .tab-edit-input,.facebook-app .tab-add-input{background:var(--fb-bg);border:1px solid var(--fb-accent);width:100px;color:var(--fb-text);border-radius:4px;outline:none;padding:4px 8px;font-size:.8rem}.facebook-app .tab-add-btn{color:var(--fb-text-secondary);border:1px dashed var(--fb-border);cursor:pointer;background:0 0;border-radius:6px 6px 0 0;padding:6px 14px;font-size:1rem;transition:all .15s}.facebook-app .tab-add-btn:hover{color:var(--fb-accent);border-color:var(--fb-accent)}.facebook-app button{cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:background .15s,opacity .15s}.facebook-app button:disabled{opacity:.5;cursor:not-allowed}.facebook-app .btn-accent{background:var(--fb-accent);color:#fff}.facebook-app .btn-accent:hover:not(:disabled){background:var(--fb-accent-hover)}.facebook-app .btn-green{background:var(--fb-green);color:#fff}.facebook-app .btn-green:hover:not(:disabled){background:var(--fb-green-hover)}.facebook-app .btn-ghost{color:var(--fb-text-secondary);background:0 0;padding:4px 8px}.facebook-app .btn-ghost:hover{color:var(--fb-accent)}.facebook-app .btn-outline{border:1px solid var(--fb-border);color:var(--fb-text);background:0 0}.facebook-app .btn-outline:hover:not(:disabled){border-color:var(--fb-text-secondary)}.facebook-app .btn-sm{padding:4px 10px;font-size:.75rem}.facebook-app .data-manager{align-items:center;gap:4px;display:flex;position:relative}.facebook-app .fb-form{background:var(--fb-surface);border:1px solid var(--fb-border);border-radius:var(--fb-radius);margin-bottom:1.25rem;padding:1.25rem}.facebook-app .fb-form-title{color:var(--fb-text);margin:0 0 1rem;font-size:1rem}.facebook-app .fb-form-field{margin-bottom:.85rem}.facebook-app .fb-form-field label{color:var(--fb-text-secondary);margin-bottom:.3rem;font-size:.8rem;display:block}.facebook-app .fb-form-field input{background:var(--fb-surface-hover);border:1px solid var(--fb-border);width:100%;color:var(--fb-text);box-sizing:border-box;border-radius:6px;outline:none;padding:.55rem .7rem;font-family:inherit;font-size:.9rem;transition:border-color .15s}.facebook-app .fb-form-field input:focus{border-color:var(--fb-accent)}.facebook-app .fb-form-actions{gap:.5rem;margin-top:.25rem;display:flex}.facebook-app .fb-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:2rem;display:grid}.facebook-app .fb-card{background:var(--fb-surface);border:1px solid var(--fb-border);border-radius:var(--fb-radius);transition:transform .15s,box-shadow .15s,border-color .15s;overflow:hidden}.facebook-app .fb-card:hover{border-color:var(--fb-accent);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.facebook-app .fb-card-link{color:inherit;align-items:center;gap:12px;padding:16px 20px;text-decoration:none;display:flex}.facebook-app .fb-card-icon{flex-shrink:0;font-size:28px;line-height:1}.facebook-app .fb-card-avatar{object-fit:cover;border-radius:50%;width:40px;height:40px}.facebook-app .fb-card-emoji{font-size:28px}.facebook-app .fb-card-body{flex:1;min-width:0}.facebook-app .fb-card-title{color:var(--fb-text);word-break:break-word;margin-bottom:2px;font-size:.95rem;font-weight:600}.facebook-app .fb-card-desc{color:var(--fb-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.facebook-app .fb-card-actions{gap:4px;padding:0 20px 12px;display:flex}.facebook-app .fb-card-actions .fb-btn-danger:hover{color:#ef4444}.facebook-app .fb-empty{text-align:center;color:var(--fb-text-secondary);margin-bottom:2rem;padding:40px 20px}.facebook-app .fb-empty p{margin-bottom:8px}.facebook-app .section-title{color:var(--fb-text-secondary);margin-bottom:16px;font-size:1.125rem;font-weight:600}.facebook-app .post-list{flex-direction:column;gap:1px;padding-bottom:60px;display:flex}.facebook-app .post-item{border-bottom:1px solid var(--fb-border);padding:16px 0}.facebook-app .post-item:first-child{padding-top:0}.facebook-app .post-content{color:var(--fb-text);-webkit-line-clamp:4;-webkit-box-orient:vertical;margin-bottom:8px;font-size:.9rem;line-height:1.6;display:-webkit-box;overflow:hidden}.facebook-app .post-meta{color:var(--fb-text-secondary);align-items:center;gap:16px;font-size:.75rem;display:flex}.facebook-app .post-source{color:var(--fb-accent);font-weight:600}.facebook-app .post-link{color:var(--fb-accent);margin-left:auto;font-weight:500;text-decoration:none}.facebook-app .post-link:hover{text-decoration:underline}.facebook-app .error-banner{color:#f88;background:#3b1010;border:1px solid #5c2020;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:10px 14px;font-size:.85rem;display:flex}@media (width<=640px){.facebook-app .fb-grid{grid-template-columns:1fr}.facebook-header{flex-direction:column;align-items:flex-start}}.spritesheetslicer-app{--ss-accent:var(--accent,#6366f1);--ss-border:var(--border,#23233a);--ss-surface:var(--bg-card,#1a1a24);--ss-text:var(--text,#a0a0b0);--ss-text-bright:var(--text-bright,#e4e4ef);--ss-radius:var(--radius,10px);flex-direction:column;gap:1.25rem;max-width:960px;margin:0 auto;padding:0 1rem;display:flex}.spritesheetslicer-app .ss-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.spritesheetslicer-app .ss-header h2{color:var(--ss-text-bright);margin:0;font-size:1.25rem;font-weight:600}.spritesheetslicer-app .ss-dropzone{border:2px dashed var(--ss-border);border-radius:var(--ss-radius);background:var(--ss-surface);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;min-height:280px;transition:border-color .2s,background .2s;display:flex}.spritesheetslicer-app .ss-dropzone:hover,.spritesheetslicer-app .ss-dropzone.dragging{border-color:var(--ss-accent);background:#6366f10f}.spritesheetslicer-app .ss-dropzone-icon{opacity:.5;font-size:3rem}.spritesheetslicer-app .ss-dropzone-text{color:var(--ss-text);text-align:center;font-size:.95rem}.spritesheetslicer-app .ss-dropzone-text span{color:var(--ss-accent);text-decoration:underline}.spritesheetslicer-app .ss-controls{background:var(--ss-surface);border:1px solid var(--ss-border);border-radius:var(--ss-radius);flex-wrap:wrap;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.spritesheetslicer-app .ss-control-group{align-items:center;gap:.4rem;display:flex}.spritesheetslicer-app .ss-separator{color:var(--ss-border);-webkit-user-select:none;user-select:none;font-size:1.1rem}.spritesheetslicer-app .ss-control-group label{color:var(--ss-text);white-space:nowrap;font-size:.85rem}.spritesheetslicer-app .ss-control-group input[type=number]{background:var(--bg,#0f0f13);border:1px solid var(--ss-border);width:60px;color:var(--ss-text-bright);text-align:center;border-radius:6px;outline:none;padding:.35rem .5rem;font-size:.9rem;transition:border-color .2s}.spritesheetslicer-app .ss-control-group input[type=number]:focus{border-color:var(--ss-accent)}.spritesheetslicer-app .ss-info{color:var(--ss-text);flex-wrap:wrap;gap:1rem;margin-left:auto;font-size:.8rem;display:flex}.spritesheetslicer-app .ss-info span{white-space:nowrap}.spritesheetslicer-app .ss-preview{justify-content:center;display:flex;overflow:auto}.spritesheetslicer-app .ss-preview-container{border-radius:var(--ss-radius);border:1px solid var(--ss-border);max-width:100%;display:inline-block;position:relative;overflow:hidden}.spritesheetslicer-app .ss-preview-container img{max-width:100%;height:auto;display:block}.spritesheetslicer-app .ss-grid-overlay{pointer-events:none;display:grid;position:absolute;inset:0}.spritesheetslicer-app .ss-grid-cell{box-sizing:border-box;border:1px solid #ff323280}.spritesheetslicer-app .ss-toast{color:#fff;z-index:1000;pointer-events:none;border-radius:8px;padding:.6rem 1.1rem;font-size:.9rem;animation:.25s ss-toast-in;position:fixed;bottom:24px;right:24px}.spritesheetslicer-app .ss-toast.success{background:var(--success,#22c55e)}.spritesheetslicer-app .ss-toast.error{background:var(--danger,#ef4444)}@keyframes ss-toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (width<=640px){.spritesheetslicer-app{padding:0 .5rem}.spritesheetslicer-app .ss-controls{flex-direction:column;align-items:flex-start;gap:.75rem}.spritesheetslicer-app .ss-info{margin-left:0}.spritesheetslicer-app .ss-dropzone{min-height:200px}}.tasks-app{--tk-accent:#6366f1;--tk-accent-hover:#818cf8;--tk-surface:#1a1a24;--tk-surface-hover:#22222e;--tk-border:#2a2a3a;--tk-text:#a0a0b0;--tk-text-bright:#e4e4ef;--tk-success:#22c55e;--tk-danger:#ef4444;--tk-warning:#f59e0b;--tk-radius:10px;max-width:720px;margin:0 auto;padding:0 1rem}.tk-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.tk-header h2{color:var(--tk-text-bright);margin:0;font-size:1.3rem}.tk-header-actions{align-items:center;gap:.5rem;display:flex}.tk-data-manager{align-items:center;gap:.3rem;display:flex}.tk-tabs{border-bottom:1px solid var(--tk-border);gap:0;margin-bottom:1.25rem;display:flex}.tk-tab{color:var(--tk-text);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:.4rem;padding:.6rem 1.2rem;font-size:.9rem;transition:color .15s,border-color .15s;display:flex}.tk-tab:hover{color:var(--tk-text-bright)}.tk-tab--active{color:var(--tk-accent);border-bottom-color:var(--tk-accent)}.tk-tab-badge{background:var(--tk-surface-hover);color:var(--tk-text);text-align:center;border-radius:99px;min-width:1.2rem;padding:.1rem .45rem;font-size:.75rem}.tk-tab--active .tk-tab-badge{background:var(--tk-accent);color:#fff}.tk-form{background:var(--tk-surface);border:1px solid var(--tk-border);border-radius:var(--tk-radius);margin-bottom:1.25rem;padding:1.25rem}.tk-form-title{color:var(--tk-text-bright);margin:0 0 1rem;font-size:1rem}.tk-form-field{flex:1;margin-bottom:.85rem}.tk-form-field label{color:var(--tk-text);margin-bottom:.3rem;font-size:.8rem;display:block}.tk-form-field input,.tk-form-field textarea,.tk-form-field select{background:var(--tk-surface-hover);border:1px solid var(--tk-border);width:100%;color:var(--tk-text-bright);box-sizing:border-box;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;border-radius:6px;outline:none;padding:.55rem .7rem;font-family:inherit;font-size:.9rem;transition:border-color .15s}.tk-form-field input:focus,.tk-form-field textarea:focus,.tk-form-field select:focus{border-color:var(--tk-accent)}.tk-form-field select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}.tk-form-field select option{background:var(--tk-surface-hover);color:var(--tk-text-bright)}.tk-form-field textarea{resize:vertical}.tk-form-row{gap:.85rem;display:flex}.tk-form-actions{gap:.5rem;margin-top:.25rem;display:flex}.tk-list{flex-direction:column;gap:.6rem;display:flex}.tk-empty{text-align:center;color:var(--tk-text);padding:2.5rem 1rem;font-size:.9rem}.tk-item{background:var(--tk-surface);border:1px solid var(--tk-border);border-radius:var(--tk-radius);align-items:flex-start;gap:.75rem;padding:.85rem 1rem;transition:border-color .15s;display:flex}.tk-item:hover{border-color:var(--tk-accent)}.tk-item--overdue{border-left:3px solid var(--tk-danger)}.tk-item--done{opacity:.6}.tk-item--done .tk-item-title{text-decoration:line-through}.tk-checkbox{border:2px solid var(--tk-border);cursor:pointer;color:#fff;background:0 0;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:2px;padding:0;transition:background-color .15s,border-color .15s;display:flex}.tk-checkbox:hover{border-color:var(--tk-accent)}.tk-checkbox--checked{background:var(--tk-success);border-color:var(--tk-success)}.tk-item-body{flex:1;min-width:0}.tk-item-title{color:var(--tk-text-bright);word-break:break-word;margin-bottom:.2rem;font-size:.95rem}.tk-item-desc{color:var(--tk-text);word-break:break-word;margin-bottom:.35rem;font-size:.8rem}.tk-item-meta{color:var(--tk-text);flex-wrap:wrap;gap:.5rem;font-size:.75rem;display:flex}.tk-item-due--overdue{color:var(--tk-danger)}.tk-item-reminder{color:var(--tk-warning)}.tk-repeat-badge{color:var(--tk-accent);font-weight:600}.tk-item-sent{color:var(--tk-success)}.tk-item-actions{flex-shrink:0;gap:.2rem;display:flex}.tk-btn-sm{min-width:auto;padding:.3rem}.tk-btn-danger:hover{color:var(--tk-danger)}.tk-error{border:1px solid var(--tk-danger);border-radius:var(--tk-radius);color:var(--tk-danger);background:#ef44441a;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.65rem 1rem;font-size:.85rem;display:flex}.tk-error button{color:var(--tk-danger);cursor:pointer;background:0 0;border:none;padding:.2rem;font-size:1rem;line-height:1}.tk-loading{text-align:center;color:var(--tk-text);padding:3rem 1rem}.tk-reminder-chips{flex-wrap:wrap;gap:.4rem;display:flex}.tk-chip{border:1px solid var(--tk-border);background:var(--tk-surface-hover);color:var(--tk-text);cursor:pointer;border-radius:99px;padding:.35rem .7rem;font-size:.8rem;transition:background-color .15s,border-color .15s,color .15s}.tk-chip:hover{border-color:var(--tk-accent);color:var(--tk-text-bright)}.tk-chip--active{background:var(--tk-accent);border-color:var(--tk-accent);color:#fff}.tk-chip--active:hover{background:var(--tk-accent-hover);border-color:var(--tk-accent-hover);color:#fff}@media (width<=640px){.tk-form-row{flex-direction:column;gap:0}.tk-item-meta{flex-direction:column;gap:.2rem}.tk-header h2{font-size:1.1rem}}.telegram-app{justify-content:center;align-items:center;min-height:60vh;padding:20px;display:flex}.tg-container{flex-direction:column;gap:20px;width:100%;max-width:480px;display:flex}.tg-title{color:var(--text-bright);text-align:center;font-size:1.5rem;font-weight:700}.tg-link{color:var(--accent-hover);justify-content:center;align-items:center;gap:8px;font-size:.875rem;transition:color .15s;display:flex}.tg-link:hover{color:#93bbfd}.tg-form{flex-direction:column;gap:16px;display:flex}.tg-textarea{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-bright);resize:none;border-radius:10px;outline:none;padding:12px;font-family:inherit;font-size:.9rem;line-height:1.5;transition:border-color .15s}.tg-textarea::placeholder{color:#555}.tg-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px #6366f126}.tg-char-count{text-align:right;color:var(--text);margin-top:-10px;font-size:.75rem}.tg-submit{border-radius:10px;width:100%;padding:12px;font-size:.95rem}.tg-status{text-align:center;font-size:.875rem}.tg-status.success{color:var(--success)}.tg-status.error{color:var(--danger)}.texttools-app{--tt-accent:#6366f1;--tt-accent-hover:#818cf8;--tt-surface:#1a1a24;--tt-surface-hover:#22222e;--tt-border:#2a2a3a;--tt-text:#a0a0b0;--tt-text-bright:#e4e4ef;--tt-radius:8px;flex-direction:column;max-width:860px;height:calc(100vh - 60px);margin:0 auto;padding:0 1rem;display:flex}.texttools-app .tt-header{justify-content:space-between;align-items:center;padding:1rem 0 .75rem;display:flex}.texttools-app .tt-header h2{color:var(--tt-text-bright);margin:0;font-size:1.3rem}.texttools-app .tt-header-actions{gap:.5rem;display:flex}.texttools-app .tt-toolbar{border-bottom:1px solid var(--tt-border);flex-wrap:wrap;gap:.5rem;padding-bottom:.75rem;display:flex}.texttools-app .tt-dropdown{position:relative}.texttools-app .tt-dropdown .btn.active{background:var(--tt-accent);color:#fff;border-color:var(--tt-accent)}.texttools-app .tt-dropdown-menu{z-index:50;background:var(--tt-surface);border:1px solid var(--tt-border);border-radius:var(--tt-radius);min-width:120px;padding:4px;position:absolute;top:calc(100% + 4px);left:0;box-shadow:0 8px 24px #0006}.texttools-app .tt-dropdown-item{width:100%;color:var(--tt-text);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.4rem .75rem;font-size:.85rem;transition:background .15s,color .15s;display:block}.texttools-app .tt-dropdown-item:hover{background:var(--tt-surface-hover);color:var(--tt-text-bright)}.texttools-app .tt-textarea{background:var(--tt-surface);border:1px solid var(--tt-border);border-radius:var(--tt-radius);color:var(--tt-text-bright);resize:none;outline:none;flex:1;margin-top:.75rem;padding:.75rem;font-family:Fira Code,Cascadia Code,Consolas,monospace;font-size:.875rem;line-height:1.6;transition:border-color .2s}.texttools-app .tt-textarea:focus{border-color:var(--tt-accent)}.texttools-app .tt-textarea::placeholder{color:var(--tt-text);opacity:.5}.texttools-app .tt-footer{color:var(--tt-text);gap:1.25rem;padding:.4rem 0;font-size:.75rem;display:flex}.texttools-app .tt-toast{border-radius:var(--tt-radius);color:#fff;z-index:100;padding:.5rem 1rem;font-size:.85rem;font-weight:500;animation:.2s tt-fadeIn;position:fixed;bottom:1.5rem;right:1.5rem}.texttools-app .tt-toast--success{background:#22c55e}.texttools-app .tt-toast--error{background:#ef4444}@keyframes tt-fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (width<=640px){.texttools-app{padding:0 .5rem}.texttools-app .tt-header h2{font-size:1.1rem}.texttools-app .tt-toolbar{gap:.35rem}}.ptimeline-app{--pt-bg-card:#1e293b;--pt-bg-card-h:#253347;--pt-border:#94a3b81f;--pt-border-h:#94a3b847;--pt-text-pri:#f1f5f9;--pt-text-sec:#94a3b8;--pt-text-mute:#475569;--pt-accent:#38bdf8;--pt-accent-glow:#38bdf82e;--pt-gold:#fbbf24;--pt-gold-glow:#fbbf242e;--pt-danger:#f87171;--pt-success:#34d399;--pt-lunar-badge:#a78bfa;--pt-solar-badge:#38bdf8;--pt-timeline-line:#94a3b826;--pt-font-display:"Playfair Display", Georgia, serif;--pt-font-body:"DM Sans", sans-serif;--pt-radius:14px;--pt-transition:.28s cubic-bezier(.4, 0, .2, 1);font-family:var(--pt-font-body);color:var(--pt-text-pri);min-height:100%;line-height:1.6}.ptimeline-app .pt-header{border-bottom:1px solid var(--pt-border);margin-bottom:24px}.ptimeline-app .pt-header-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:18px 0 12px;display:flex}.ptimeline-app .pt-header-brand{align-items:baseline;gap:10px;display:flex}.ptimeline-app .pt-brand-icon{font-size:1.5rem;line-height:1;position:relative;top:2px}.ptimeline-app .pt-brand-title{font-family:var(--pt-font-display);letter-spacing:-.02em;color:var(--pt-text-pri);font-size:1.5rem;font-weight:700}.ptimeline-app .pt-today-bar{flex-direction:column;gap:4px;padding:8px 0 16px;display:flex}.ptimeline-app .pt-today-row{align-items:center;gap:10px;display:flex}.ptimeline-app .pt-today-label{letter-spacing:.14em;text-transform:uppercase;color:var(--pt-text-mute);min-width:52px;font-size:.72rem;font-weight:600}.ptimeline-app .pt-today-date{font-family:var(--pt-font-display);color:var(--pt-accent);font-size:.95rem}.ptimeline-app .pt-today-lunar{font-family:var(--pt-font-display);color:var(--pt-lunar-badge);font-size:.95rem}.ptimeline-app .pt-form{background:var(--pt-bg-card);border:1px solid var(--pt-border);border-radius:var(--pt-radius);margin-bottom:24px;padding:20px}.ptimeline-app .pt-form-header h3{color:var(--pt-text-pri);margin:0 0 16px;font-size:1.1rem}.ptimeline-app .pt-form-grid{flex-direction:column;gap:14px;display:flex}.ptimeline-app .pt-field label{color:var(--pt-text-sec);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.78rem;font-weight:600;display:block}.ptimeline-app .pt-field input,.ptimeline-app .pt-field select{border:1px solid var(--pt-border);width:100%;color:var(--pt-text-pri);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:#0003;border-radius:8px;outline:none;padding:8px 12px;font-size:.9rem;transition:border-color .2s}.ptimeline-app .pt-field input:focus,.ptimeline-app .pt-field select:focus{border-color:var(--pt-accent)}.ptimeline-app .pt-field select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.ptimeline-app .pt-field select option{color:#f1f5f9;background:#1e293b}.ptimeline-app .pt-icon-grid{flex-wrap:wrap;gap:6px;display:flex}.ptimeline-app .pt-icon-btn{border:1px solid var(--pt-border);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:all .15s;display:flex}.ptimeline-app .pt-icon-btn:hover{background:#ffffff0d}.ptimeline-app .pt-icon-btn.active{border-color:var(--pt-accent);background:var(--pt-accent-glow);box-shadow:0 0 0 1px var(--pt-accent)}.ptimeline-app .pt-form-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.ptimeline-app .pt-empty{text-align:center;color:var(--pt-text-mute);padding:60px 20px;font-size:.95rem}.ptimeline-app .pt-main-container{padding:8px 0 40px}.ptimeline-app .pt-timeline{padding-left:100px;position:relative}.ptimeline-app .pt-timeline:before{content:"";background:var(--pt-timeline-line);width:1px;position:absolute;top:0;bottom:0;left:74px}.ptimeline-app .pt-item{opacity:0;margin-bottom:28px;animation:.55s forwards pt-fadeUp;position:relative}.ptimeline-app .pt-date{flex-direction:column;justify-content:center;align-items:center;width:68px;line-height:1.2;display:flex;position:absolute;top:0;bottom:0;left:-100px}.ptimeline-app .pt-date .day{font-family:var(--pt-font-display);color:var(--pt-text-pri);transition:color var(--pt-transition);font-size:1.6rem;font-weight:700;display:block}.ptimeline-app .pt-date .month{letter-spacing:.1em;text-transform:uppercase;color:var(--pt-text-mute);white-space:nowrap;margin-top:2px;font-size:.68rem;font-weight:600;display:block}.ptimeline-app .pt-dot{background:var(--pt-text-mute);border:2px solid var(--bg,#0f0f13);width:12px;height:12px;transition:background var(--pt-transition), transform var(--pt-transition), box-shadow var(--pt-transition);z-index:1;border-radius:50%;position:absolute;top:50%;left:-32px;transform:translateY(-50%)}.ptimeline-app .pt-card{background:var(--pt-bg-card);border:1px solid var(--pt-border);border-radius:var(--pt-radius);cursor:default;transition:background var(--pt-transition), border-color var(--pt-transition), transform var(--pt-transition), box-shadow var(--pt-transition);align-items:center;gap:18px;padding:20px 22px;display:flex;position:relative;overflow:hidden}.ptimeline-app .pt-card:hover{background:var(--pt-bg-card-h);border-color:var(--pt-border-h);box-shadow:-4px 0 0 var(--pt-accent), 0 8px 32px #0000002e;transform:translate(4px)}.ptimeline-app .pt-card-icon{text-align:center;flex-shrink:0;width:48px;font-size:2rem;line-height:1}.ptimeline-app .pt-card-body{flex:1;min-width:0}.ptimeline-app .pt-card-name{font-family:var(--pt-font-display);color:var(--pt-text-pri);white-space:nowrap;text-overflow:ellipsis;margin-bottom:5px;font-size:1.08rem;font-weight:700;overflow:hidden}.ptimeline-app .pt-card-dates{color:var(--pt-text-sec);flex-wrap:wrap;gap:8px;font-size:.78rem;display:flex}.ptimeline-app .pt-badge{letter-spacing:.05em;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.ptimeline-app .pt-badge-solar{background:var(--pt-accent-glow);color:var(--pt-solar-badge);border:1px solid #38bdf833}.ptimeline-app .pt-badge-lunar{color:var(--pt-lunar-badge);background:#a78bfa1f;border:1px solid #a78bfa33}.ptimeline-app .pt-card-count{text-align:right;flex-shrink:0}.ptimeline-app .pt-count-num{font-family:var(--pt-font-display);color:var(--pt-text-sec);transition:color var(--pt-transition);font-size:1.6rem;font-weight:900;line-height:1}.ptimeline-app .pt-count-label{color:var(--pt-text-mute);letter-spacing:.08em;text-transform:uppercase;margin-top:2px;font-size:.7rem;display:block}.ptimeline-app .pt-card-actions{opacity:0;flex-direction:column;flex-shrink:0;gap:4px;transition:opacity .2s;display:flex}.ptimeline-app .pt-card:hover .pt-card-actions{opacity:1}.ptimeline-app .pt-action-btn{border:1px solid var(--pt-border);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;transition:all .15s;display:flex}.ptimeline-app .pt-action-btn:hover{border-color:var(--pt-border-h);background:#ffffff14}.ptimeline-app .pt-action-del:hover{border-color:var(--pt-danger);background:#f8717126}.ptimeline-app .pt-item.is-today .pt-dot{background:var(--pt-gold);box-shadow:0 0 0 4px var(--pt-gold-glow);transform:translateY(-50%)scale(1.3)}.ptimeline-app .pt-item.is-today .pt-card{border-color:#fbbf244d;box-shadow:0 0 0 1px #fbbf2426,inset 0 0 40px #fbbf240a}.ptimeline-app .pt-item.is-today .pt-card:hover{box-shadow:-4px 0 0 var(--pt-gold), 0 8px 32px #0000002e}.ptimeline-app .pt-item.is-today .pt-count-num,.ptimeline-app .pt-item.is-today .pt-card-name{color:var(--pt-gold)}.ptimeline-app .pt-item.is-soon .pt-dot{background:var(--pt-danger);box-shadow:0 0 0 3px #f871712e}.ptimeline-app .pt-item.is-soon .pt-card{border-color:#f8717138}.ptimeline-app .pt-item.is-soon .pt-card:hover{box-shadow:-4px 0 0 var(--pt-danger), 0 8px 32px #0000002e}.ptimeline-app .pt-item.is-soon .pt-count-num{color:var(--pt-danger)}.ptimeline-app .pt-item:not(.is-today):not(.is-soon) .pt-card:hover .pt-count-num{color:var(--pt-accent)}.ptimeline-app .pt-item.is-soon .pt-card:after{content:"";border-radius:var(--pt-radius);pointer-events:none;background:radial-gradient(circle at 0%,#f871710f 0%,#0000 70%);position:absolute;inset:0}.ptimeline-app .pt-today-tag{font-size:.9rem;animation:.8s infinite alternate pt-bounce}@keyframes pt-bounce{0%{transform:scale(1)}to{transform:scale(1.25)}}@keyframes pt-fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width<=600px){.ptimeline-app .pt-timeline{padding-left:76px}.ptimeline-app .pt-timeline:before{left:48px}.ptimeline-app .pt-date{width:36px;left:-70px}.ptimeline-app .pt-date .day{font-size:1rem}.ptimeline-app .pt-dot{left:-28px}.ptimeline-app .pt-card{flex-wrap:wrap;gap:12px;padding:16px}.ptimeline-app .pt-card-count{text-align:left;align-items:baseline;gap:6px;width:100%;display:flex}.ptimeline-app .pt-count-label{margin-top:0}.ptimeline-app .pt-card-actions{opacity:1;flex-direction:row}}@media (width<=380px){.ptimeline-app .pt-card-icon{display:none}.ptimeline-app .pt-timeline{padding-left:66px}.ptimeline-app .pt-timeline:before{left:44px}.ptimeline-app .pt-date{width:32px;left:-60px}.ptimeline-app .pt-date .day{font-size:.9rem}.ptimeline-app .pt-date .month{letter-spacing:.05em;font-size:.58rem}.ptimeline-app .pt-dot{width:10px;height:10px;left:-22px}}.timeline-app{--tl-bg:#0f172a;--tl-bg-card:#1e293b;--tl-bg-card-h:#253347;--tl-border:#94a3b81f;--tl-border-h:#94a3b847;--tl-text-pri:#f1f5f9;--tl-text-sec:#94a3b8;--tl-text-mute:#475569;--tl-accent:#38bdf8;--tl-accent-glow:#38bdf82e;--tl-gold:#fbbf24;--tl-gold-glow:#fbbf242e;--tl-danger:#f87171;--tl-success:#34d399;--tl-lunar-badge:#a78bfa;--tl-solar-badge:#38bdf8;--tl-timeline-line:#94a3b826;--tl-font-display:"Playfair Display", Georgia, serif;--tl-font-body:"DM Sans", sans-serif;--tl-radius:14px;--tl-transition:.28s cubic-bezier(.4, 0, .2, 1);font-family:var(--tl-font-body);color:var(--tl-text-pri);min-height:100%;line-height:1.6}.tl-header{border-bottom:1px solid var(--tl-border);margin-bottom:24px}.tl-header-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:18px 0 12px;display:flex}.tl-header-brand{align-items:baseline;gap:10px;display:flex}.tl-brand-icon{color:var(--tl-accent);font-size:1.5rem;line-height:1;animation:12s linear infinite tl-spin-slow;position:relative;top:2px}@keyframes tl-spin-slow{to{transform:rotate(360deg)}}.tl-brand-title{font-family:var(--tl-font-display);letter-spacing:-.02em;color:var(--tl-text-pri);font-size:1.5rem;font-weight:700}.tl-today-bar{flex-direction:column;gap:4px;padding:8px 0 16px;display:flex}.tl-today-row{align-items:center;gap:10px;display:flex}.tl-today-label{letter-spacing:.14em;text-transform:uppercase;color:var(--tl-text-mute);min-width:52px;font-size:.72rem;font-weight:600}.tl-today-date{font-family:var(--tl-font-display);color:var(--tl-accent);font-size:.95rem;font-weight:400}.tl-today-lunar{font-family:var(--tl-font-display);color:var(--tl-lunar-badge);font-size:.95rem;font-weight:400}.tl-main-container{padding:8px 0 40px}.timeline-app .timeline{padding-left:100px;position:relative}.timeline-app .timeline:before{content:"";background:var(--tl-timeline-line);width:1px;position:absolute;top:0;bottom:0;left:74px}.timeline-app .tl-item{opacity:0;margin-bottom:28px;animation:.55s forwards tl-fadeUp;position:relative}.timeline-app .tl-date{flex-direction:column;justify-content:center;align-items:center;width:68px;line-height:1.2;display:flex;position:absolute;top:0;bottom:0;left:-100px}.timeline-app .tl-date .day{font-family:var(--tl-font-display);color:var(--tl-text-pri);transition:color var(--tl-transition);font-size:1.6rem;font-weight:700;display:block}.timeline-app .tl-date .month{letter-spacing:.1em;text-transform:uppercase;color:var(--tl-text-mute);white-space:nowrap;margin-top:2px;font-size:.68rem;font-weight:600;display:block}.timeline-app .tl-dot{background:var(--tl-text-mute);border:2px solid var(--bg,#0f0f13);width:12px;height:12px;transition:background var(--tl-transition), transform var(--tl-transition), box-shadow var(--tl-transition);z-index:1;border-radius:50%;position:absolute;top:50%;left:-32px;transform:translateY(-50%)}.timeline-app .ev-card{background:var(--tl-bg-card);border:1px solid var(--tl-border);border-radius:var(--tl-radius);cursor:default;transition:background var(--tl-transition), border-color var(--tl-transition), transform var(--tl-transition), box-shadow var(--tl-transition);align-items:center;gap:18px;padding:20px 22px;display:flex;position:relative;overflow:hidden}.timeline-app .ev-card:hover{background:var(--tl-bg-card-h);border-color:var(--tl-border-h);box-shadow:-4px 0 0 var(--tl-accent), 0 8px 32px #0000002e;transform:translate(4px)}.timeline-app .card-icon{text-align:center;flex-shrink:0;width:48px;font-size:2rem;line-height:1}.timeline-app .card-body{flex:1;min-width:0}.timeline-app .card-name{font-family:var(--tl-font-display);color:var(--tl-text-pri);white-space:nowrap;text-overflow:ellipsis;margin-bottom:5px;font-size:1.08rem;font-weight:700;overflow:hidden}.timeline-app .card-dates{color:var(--tl-text-sec);flex-wrap:wrap;gap:8px;font-size:.78rem;display:flex}.timeline-app .badge{letter-spacing:.05em;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.timeline-app .badge-solar{background:var(--tl-accent-glow);color:var(--tl-solar-badge);border:1px solid #38bdf833}.timeline-app .badge-lunar{color:var(--tl-lunar-badge);background:#a78bfa1f;border:1px solid #a78bfa33}.timeline-app .card-count{text-align:right;flex-shrink:0}.timeline-app .count-num{font-family:var(--tl-font-display);color:var(--tl-text-sec);transition:color var(--tl-transition);font-size:1.6rem;font-weight:900;line-height:1}.timeline-app .count-label{color:var(--tl-text-mute);letter-spacing:.08em;text-transform:uppercase;margin-top:2px;font-size:.7rem;display:block}.timeline-app .tl-item.is-today .tl-dot{background:var(--tl-gold);box-shadow:0 0 0 4px var(--tl-gold-glow);transform:translateY(-50%)scale(1.3)}.timeline-app .tl-item.is-today .ev-card{border-color:#fbbf244d;box-shadow:0 0 0 1px #fbbf2426,inset 0 0 40px #fbbf240a}.timeline-app .tl-item.is-today .ev-card:hover{box-shadow:-4px 0 0 var(--tl-gold), 0 8px 32px #0000002e}.timeline-app .tl-item.is-today .count-num,.timeline-app .tl-item.is-today .card-name{color:var(--tl-gold)}.timeline-app .tl-item.is-soon .tl-dot{background:var(--tl-danger);box-shadow:0 0 0 3px #f871712e}.timeline-app .tl-item.is-soon .ev-card{border-color:#f8717138}.timeline-app .tl-item.is-soon .ev-card:hover{box-shadow:-4px 0 0 var(--tl-danger), 0 8px 32px #0000002e}.timeline-app .tl-item.is-soon .count-num{color:var(--tl-danger)}.timeline-app .tl-item:not(.is-today):not(.is-soon) .ev-card:hover .count-num{color:var(--tl-accent)}.timeline-app .tl-item.is-soon .ev-card:after{content:"";border-radius:var(--tl-radius);pointer-events:none;background:radial-gradient(circle at 0%,#f871710f 0%,#0000 70%);position:absolute;inset:0}.timeline-app .today-tag{font-size:.9rem;animation:.8s infinite alternate tl-bounce}@keyframes tl-bounce{0%{transform:scale(1)}to{transform:scale(1.25)}}@keyframes tl-fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width<=600px){.timeline-app .timeline{padding-left:76px}.timeline-app .timeline:before{left:48px}.timeline-app .tl-date{width:36px;left:-70px}.timeline-app .tl-date .day{font-size:1rem}.timeline-app .tl-dot{left:-28px}.timeline-app .ev-card{flex-wrap:wrap;gap:12px;padding:16px}.timeline-app .card-count{text-align:left;align-items:baseline;gap:6px;width:100%;display:flex}.timeline-app .count-label{margin-top:0}}@media (width<=380px){.timeline-app .card-icon{display:none}.timeline-app .timeline{padding-left:66px}.timeline-app .timeline:before{left:44px}.timeline-app .tl-date{width:32px;left:-60px}.timeline-app .tl-date .day{font-size:.9rem}.timeline-app .tl-date .month{letter-spacing:.05em;font-size:.58rem}.timeline-app .tl-dot{width:10px;height:10px;left:-22px}}.youtube-app{--yt-bg:#0f0f0f;--yt-surface:#1a1a1a;--yt-surface-hover:#252525;--yt-border:#2a2a2a;--yt-text:#f1f1f1;--yt-text-secondary:#aaa;--yt-accent:#f44;--yt-accent-hover:#f66;--yt-green:#2ea043;--yt-green-hover:#3fb950;--yt-radius:12px;color:var(--yt-text);line-height:1.5}.youtube-header{border-bottom:1px solid var(--yt-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:32px;padding:20px 0;display:flex}.youtube-header h2{color:var(--yt-accent);font-size:1.5rem;font-weight:700}.youtube-app .header-actions{align-items:center;gap:8px;display:flex}.youtube-app .range-toggle{background:var(--yt-surface);border:1px solid var(--yt-border);border-radius:8px;display:flex;overflow:hidden}.youtube-app .range-btn{color:var(--yt-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:0;padding:6px 14px;font-size:.8rem;transition:all .15s}.youtube-app .range-btn.active{background:var(--yt-accent);color:#fff}.youtube-app .range-btn:hover:not(.active){color:var(--yt-text)}.youtube-app .tab-bar{margin-bottom:24px}.youtube-app .tab-list{border-bottom:1px solid var(--yt-border);gap:4px;padding-bottom:4px;display:flex;overflow-x:auto}.youtube-app .tab-item{color:var(--yt-text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:6px 6px 0 0;align-items:center;gap:4px;padding:8px 16px;font-size:.875rem;transition:all .15s;display:flex}.youtube-app .tab-item:hover{color:var(--yt-text);background:var(--yt-surface)}.youtube-app .tab-item.active{color:var(--yt-accent);border-bottom-color:var(--yt-accent);background:var(--yt-surface)}.youtube-app .tab-name{-webkit-user-select:none;user-select:none}.youtube-app .tab-delete{color:var(--yt-text-secondary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;padding:1px 4px;font-size:.7rem;line-height:1;transition:opacity .15s}.youtube-app .tab-item:hover .tab-delete{opacity:1}.youtube-app .tab-delete:hover{color:var(--yt-accent);background:#ff44441a}.youtube-app .tab-edit-form,.youtube-app .tab-add-form{display:inline}.youtube-app .tab-edit-input,.youtube-app .tab-add-input{background:var(--yt-bg);border:1px solid var(--yt-accent);width:100px;color:var(--yt-text);border-radius:4px;outline:none;padding:4px 8px;font-size:.8rem}.youtube-app .tab-add-btn{color:var(--yt-text-secondary);border:1px dashed var(--yt-border);cursor:pointer;background:0 0;border-radius:6px 6px 0 0;padding:6px 14px;font-size:1rem;transition:all .15s}.youtube-app .tab-add-btn:hover{color:var(--yt-accent);border-color:var(--yt-accent)}.youtube-app button{cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:background .15s,opacity .15s}.youtube-app button:disabled{opacity:.5;cursor:not-allowed}.youtube-app .btn-accent{background:var(--yt-accent);color:#fff}.youtube-app .btn-accent:hover:not(:disabled){background:var(--yt-accent-hover)}.youtube-app .btn-green{background:var(--yt-green);color:#fff}.youtube-app .btn-green:hover:not(:disabled){background:var(--yt-green-hover)}.youtube-app .btn-ghost{color:var(--yt-text-secondary);background:0 0;padding:4px 8px}.youtube-app .btn-ghost:hover{color:var(--yt-accent)}.youtube-app .btn-outline{border:1px solid var(--yt-border);color:var(--yt-text);background:0 0}.youtube-app .btn-outline:hover:not(:disabled){border-color:var(--yt-text-secondary)}.youtube-app .btn-sm{padding:4px 10px;font-size:.75rem}.youtube-app .data-manager{align-items:center;gap:4px;display:flex;position:relative}.youtube-app .yt-form{background:var(--yt-surface);border:1px solid var(--yt-border);border-radius:var(--yt-radius);margin-bottom:1.25rem;padding:1.25rem}.youtube-app .yt-form-title{color:var(--yt-text);margin:0 0 1rem;font-size:1rem}.youtube-app .yt-form-field{margin-bottom:.85rem}.youtube-app .yt-form-field label{color:var(--yt-text-secondary);margin-bottom:.3rem;font-size:.8rem;display:block}.youtube-app .yt-form-field input{background:var(--yt-surface-hover);border:1px solid var(--yt-border);width:100%;color:var(--yt-text);box-sizing:border-box;border-radius:6px;outline:none;padding:.55rem .7rem;font-family:inherit;font-size:.9rem;transition:border-color .15s}.youtube-app .yt-form-field input:focus{border-color:var(--yt-accent)}.youtube-app .yt-form-field input:disabled{opacity:.5;cursor:not-allowed}.youtube-app .yt-form-hint{color:var(--yt-text-secondary);margin-top:.2rem;font-size:.75rem}.youtube-app .yt-form-error{color:#f88;background:#3b1010;border:1px solid #5c2020;border-radius:6px;margin-bottom:.75rem;padding:.5rem .75rem;font-size:.8rem}.youtube-app .yt-form-actions{gap:.5rem;margin-top:.25rem;display:flex}.youtube-app .yt-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:2rem;display:grid}.youtube-app .yt-card{background:var(--yt-surface);border:1px solid var(--yt-border);border-radius:var(--yt-radius);transition:transform .15s,box-shadow .15s,border-color .15s;overflow:hidden}.youtube-app .yt-card:hover{border-color:var(--yt-accent);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.youtube-app .yt-card-link{color:inherit;align-items:center;gap:12px;padding:16px 20px;text-decoration:none;display:flex}.youtube-app .yt-card-icon{flex-shrink:0;font-size:28px;line-height:1}.youtube-app .yt-card-avatar{object-fit:cover;border-radius:50%;width:40px;height:40px}.youtube-app .yt-card-emoji{font-size:28px}.youtube-app .yt-card-body{flex:1;min-width:0}.youtube-app .yt-card-title{color:var(--yt-text);word-break:break-word;font-size:.95rem;font-weight:600}.youtube-app .yt-card-actions{gap:4px;padding:0 20px 12px;display:flex}.youtube-app .yt-card-actions .yt-btn-danger:hover{color:var(--yt-accent)}.youtube-app .yt-empty{text-align:center;color:var(--yt-text-secondary);margin-bottom:2rem;padding:40px 20px}.youtube-app .yt-empty p{margin-bottom:8px}.youtube-app .section-title{color:var(--yt-text-secondary);margin-bottom:16px;font-size:1.125rem;font-weight:600}.youtube-app .videos-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;padding-bottom:60px;display:grid}.youtube-app .video-card{background:var(--yt-surface);border-radius:var(--yt-radius);border:1px solid var(--yt-border);transition:transform .15s,box-shadow .15s;overflow:hidden}.youtube-app .video-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0006}.youtube-app .video-card a{color:inherit;text-decoration:none}.youtube-app .video-thumb{background:#000;padding-top:56.25%;position:relative}.youtube-app .video-thumb img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.youtube-app .video-info{padding:12px}.youtube-app .video-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:6px;font-size:.9rem;font-weight:500;line-height:1.4;display:-webkit-box;overflow:hidden}.youtube-app .video-meta{color:var(--yt-text-secondary);justify-content:space-between;font-size:.75rem;display:flex}.youtube-app .error-banner{color:#f88;background:#3b1010;border:1px solid #5c2020;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:10px 14px;font-size:.85rem;display:flex}@media (width<=640px){.youtube-app .videos-grid,.youtube-app .yt-grid{grid-template-columns:1fr}.youtube-header{flex-direction:column;align-items:flex-start}}
