:root{--font-family-sans: "Inter", "Source Han Sans SC", "Noto Sans SC", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Arial, sans-serif;font-family:var(--font-family-sans);line-height:1.5;font-weight:400;color-scheme:light;--theme-transition-duration: .28s;--theme-transition-ease: cubic-bezier(.2, .8, .2, 1);--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: .75rem;--spacing-lg: 1rem;--spacing-xl: 1.5rem;--spacing-2xl: 2rem;--spacing-3xl: 3rem;--bg-color: #f4f7f9;--bg-pattern-opacity: 1;--text-color: #1e293b;--text-sub-color: #506276;--text-muted-color: #6f8196;--card-bg: #f1f6fa;--text-inverse-color: #ffffff;--link-color: #3b82f6;--link-hover-color: #2563eb;--accent-warm: #f97316;--accent-warm-text: #2b1a12;--accent-warm-shadow: rgba(249, 115, 22, .18);--primary-color: #3b82f6;--primary-hover-color: #2563eb;--primary-light: rgba(59, 130, 246, .1);--primary-disabled: #93c5fd;--danger-color: #ef4444;--error-color: #ef4444;--success-color: #10b981;--warning-color: #f59e0b;--overlay-bg-soft: rgba(15, 23, 42, .24);--overlay-bg: rgba(15, 23, 42, .6);--modal-shadow: 0 28px 56px -18px rgba(15, 23, 42, .22), 0 18px 26px -22px rgba(15, 23, 42, .2);--tooltip-bg: rgba(15, 23, 42, .9);--tooltip-text: #ffffff;--focus-ring: 0 0 0 3px rgba(59, 130, 246, .2);--border-color: #c7d3df;--border-hover-color: #afbfcd;--shadow-color: rgba(15, 23, 42, .09);--shadow-hover-color: rgba(15, 23, 42, .16);--card-shadow: 0 1px 2px rgba(15, 23, 42, .04), 0 24px 60px -46px rgba(15, 23, 42, .18);--card-hover-shadow: 0 2px 3px rgba(15, 23, 42, .05), 0 38px 85px -56px rgba(15, 23, 42, .22);--glass-blur: 20px;--glass-bg: rgba(255, 255, 255, .72);--glass-bg-hover: rgba(255, 255, 255, .78);--glass-border: color-mix(in srgb, var(--border-color) 55%, transparent);--glass-border-hover: color-mix(in srgb, var(--border-color) 72%, transparent);--glass-highlight: rgba(255, 255, 255, 0);--menu-bg: #f2f7fb;--menu-hover: rgba(100, 116, 139, .12);--input-bg: #f2f7fb;--input-border: #c1ceda;--block-bg: #d8e3ec;--panel-bg: #f2f7fb;--panel-border: #cbd8e4;--panel-hover: #e7eef5;--surface-muted: #dbe6ef;--surface-muted-hover: #d2dee8;--action-bg: #dce6ef;--action-bg-hover: #d3dee8;--action-text: #334155;--like-hover-bg: #fee2e2;--dislike-hover-bg: #dbe5ee;--dislike-hover-text: #1f2937;--dislike-active-bg: #64748b;--collect-hover-bg: #ffedd5;--collect-color: #f97316;--timeline-accent: #0ea5e9;--shuoshuo-accent: #10b981;--shuoshuo-accent-hover: #059669;--shuoshuo-accent-disabled: #a7f3d0;--overlay-panel-bg: rgba(242, 247, 251, .97);--overlay-sidebar-bg: #e2ebf3;--overlay-border: rgba(100, 116, 139, .24);--sidebar-active-bg: rgba(59, 130, 246, .14);--highlight-color: #dc2626;--highlight-bg: rgba(254, 240, 138, .22);--nav-bg: rgba(255, 255, 255, .66);--comment-username-color: var(--link-color);--comment-action-hover-color: var(--link-color);--nav-page-color: var(--text-color);--nav-page-scrolled-bg: var(--nav-bg);--nav-page-border: rgba(100, 116, 139, .18);color:var(--text-color);background-color:var(--bg-color);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=dark]{color-scheme:dark;--bg-color: #0f172a;--bg-pattern-opacity: 1;--text-color: #f1f5f9;--text-sub-color: #94a3b8;--text-muted-color: #64748b;--card-bg: #1e293b;--text-inverse-color: #ffffff;--link-color: #60a5fa;--link-hover-color: #93c5fd;--accent-warm: #fb923c;--accent-warm-text: #2b1a12;--accent-warm-shadow: rgba(251, 146, 60, .35);--primary-color: #60a5fa;--primary-hover-color: #93c5fd;--primary-light: rgba(96, 165, 250, .1);--primary-disabled: color-mix(in oklch, var(--primary-color) 40%, transparent);--danger-color: #f87171;--error-color: #fca5a5;--success-color: #34d399;--warning-color: #fbbf24;--overlay-bg-soft: rgba(0, 0, 0, .4);--overlay-bg: rgba(0, 0, 0, .7);--modal-shadow: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 10px 10px -5px rgba(0, 0, 0, .3);--tooltip-bg: rgba(15, 23, 42, .92);--tooltip-text: #ffffff;--focus-ring: 0 0 0 3px rgba(96, 165, 250, .35);--border-color: #334155;--border-hover-color: #475569;--shadow-color: rgba(0, 0, 0, .3);--shadow-hover-color: rgba(0, 0, 0, .5);--card-shadow: inset 0 1px 0 var(--glass-highlight), 0 2px 4px rgba(0, 0, 0, .18), 0 26px 70px -56px rgba(0, 0, 0, .55);--card-hover-shadow: inset 0 1px 0 var(--glass-highlight), 0 4px 6px rgba(0, 0, 0, .22), 0 40px 95px -70px rgba(0, 0, 0, .62);--glass-blur: 20px;--glass-bg: rgba(30, 41, 59, .62);--glass-bg-hover: rgba(30, 41, 59, .72);--glass-border: rgba(255, 255, 255, .08);--glass-border-hover: rgba(255, 255, 255, .14);--glass-highlight: rgba(255, 255, 255, .1);--menu-bg: #1e293b;--menu-hover: rgba(255, 255, 255, .1);--input-bg: #334155;--input-border: #475569;--block-bg: #334155;--panel-bg: #334155;--panel-border: #475569;--panel-hover: #3f4b5f;--surface-muted: #1a1a1a;--surface-muted-hover: #252525;--action-bg: #374151;--action-bg-hover: #4b5563;--action-text: #d1d5db;--like-hover-bg: color-mix(in oklch, var(--danger-color) 22%, transparent);--dislike-hover-bg: color-mix(in oklch, var(--text-color) 18%, transparent);--dislike-hover-text: var(--text-color);--dislike-active-bg: color-mix(in oklch, var(--text-color) 35%, transparent);--collect-hover-bg: color-mix(in oklch, var(--accent-warm) 20%, transparent);--collect-color: var(--accent-warm);--timeline-accent: color-mix(in oklch, var(--primary-color) 70%, #0f172a);--shuoshuo-accent: color-mix(in oklch, #10b981 70%, #1f2937);--shuoshuo-accent-hover: color-mix(in oklch, #059669 70%, #1f2937);--shuoshuo-accent-disabled: color-mix(in oklch, #a7f3d0 55%, #1f2937);--overlay-panel-bg: rgba(30, 41, 59, .9);--overlay-sidebar-bg: rgba(0, 0, 0, .2);--overlay-border: rgba(255, 255, 255, .1);--sidebar-active-bg: rgba(255, 255, 255, .05);--highlight-color: #fca5a5;--highlight-bg: rgba(254, 240, 138, .15);--nav-bg: rgba(30, 41, 59, .62);--comment-username-color: var(--text-color);--comment-action-hover-color: var(--text-color);--nav-page-color: var(--text-inverse-color);--nav-page-scrolled-bg: rgba(15, 23, 42, .85);--nav-page-border: rgba(255, 255, 255, .1)}:root[data-theme=light][data-page-theme=music]{--nav-page-color: var(--text-color);--nav-page-scrolled-bg: rgba(238, 244, 249, .9);--nav-page-border: rgba(100, 116, 139, .18)}:root[data-theme=dark][data-page-theme=music]{--nav-page-color: var(--text-inverse-color);--nav-page-scrolled-bg: rgba(0, 0, 0, .7);--nav-page-border: rgba(255, 255, 255, .1)}a{font-weight:500;color:var(--link-color);text-decoration:inherit;transition:color .2s}a:hover{color:var(--link-hover-color)}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg-color);color:var(--text-color);font-family:var(--font-family-sans);position:relative;z-index:0}:root body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;opacity:var(--bg-pattern-opacity);background-image:radial-gradient(circle at top,rgba(59,130,246,.08),transparent 34%),linear-gradient(180deg,#f1f6fac7 0,#e5edf400 260px)}:root[data-theme=dark] body:before{opacity:var(--bg-pattern-opacity);background-image:radial-gradient(900px 700px at 88% 82%,rgba(59,130,246,.14),transparent 62%)}input,textarea,select,option{font-family:inherit}h1{font-size:3.2em;line-height:1.1;color:var(--text-color)}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--card-bg);color:var(--text-color);cursor:pointer;transition:border-color .25s,background-color .3s,color .3s}button:hover{border-color:var(--link-color)}button:focus:not(:focus-visible){outline:none}button:focus-visible{outline:2px solid var(--link-color);outline-offset:2px}.btn-reset{background:none;border:none;padding:0;font:inherit;color:inherit;text-align:inherit;cursor:pointer}.btn-reset:focus-visible{outline:2px solid var(--link-color);outline-offset:2px}.card{background:var(--glass-bg);border-radius:16px;box-shadow:var(--card-shadow);padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--text-color);border:1px solid var(--glass-border);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur))}@media(hover:hover)and (pointer:fine){.card:hover{box-shadow:var(--card-hover-shadow);border-color:var(--glass-border-hover);background:var(--glass-bg-hover);transform:translateY(-5px)}}#app{text-align:left}.page-container{max-width:1200px;margin:0 auto;padding:100px 20px 40px;min-height:calc(100vh - 60px)}img{display:block;max-width:100%;image-rendering:auto;transform:translateZ(0)}.article-card,.category-card,.card-cover,.cover-wrap,.avatar,.profile-avatar{overflow:hidden;transform:none;outline:none}.profile-avatar,.avatar{border-radius:8px}html.theme-transition,html.theme-transition *,html.theme-transition *:before,html.theme-transition *:after{transition-property:background-color,color,border-color,outline-color,box-shadow,fill,stroke,opacity,filter,backdrop-filter!important;transition-duration:var(--theme-transition-duration)!important;transition-timing-function:var(--theme-transition-ease)!important;transition-delay:0ms!important}html.theme-transition .nav,html.theme-transition .music-station,html.theme-transition .bg-layer{will-change:background-color,color,border-color,box-shadow,opacity,filter,backdrop-filter}html.theme-transition .bg-layer{transform:translateZ(0)}.admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg);display:flex;justify-content:center;align-items:center;z-index:1000;padding:24px}.admin-dialog{background:var(--panel-bg);color:var(--text-color);width:100%;max-width:960px;height:min(85vh,820px);border-radius:18px;border:1px solid var(--panel-border);box-shadow:var(--modal-shadow);display:flex;flex-direction:column;overflow:hidden}.admin-dialog__header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 24px;border-bottom:1px solid var(--panel-border)}.admin-dialog__title{margin:0;font-size:18px;font-weight:600;letter-spacing:.01em}.admin-dialog__close{width:32px;height:32px;border-radius:10px;border:none;background:transparent;color:var(--text-sub-color);font-size:20px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}.admin-dialog__close:hover{background:color-mix(in srgb,var(--text-color) 8%,transparent);color:var(--text-color)}.admin-dialog__body{flex:1;overflow-y:auto;padding:22px 24px 26px}.admin-dialog__toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}.admin-dialog__form-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}.admin-dialog__form-title{margin:0;font-size:16px;font-weight:600;color:var(--text-color)}.admin-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:10px;border:1px solid var(--panel-border);background:var(--panel-bg);color:var(--text-color);font-size:14px;line-height:1.2;cursor:pointer;transition:background .18s ease,border-color .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}.admin-btn:hover:not(:disabled){border-color:color-mix(in oklch,var(--primary-color) 45%,var(--panel-border));background:color-mix(in srgb,var(--text-color) 4%,transparent)}@media(hover:hover)and (pointer:fine){.admin-btn:hover:not(:disabled){transform:translateY(-1px)}}.admin-btn:disabled{opacity:.55;cursor:not-allowed}.admin-btn--primary{background:color-mix(in oklch,var(--primary-light),transparent 32%);color:var(--primary-color);border-color:color-mix(in oklch,var(--primary-color) 35%,transparent)}.admin-btn--primary:hover:not(:disabled){background:color-mix(in oklch,var(--primary-light),transparent 12%);border-color:color-mix(in oklch,var(--primary-color) 55%,transparent);box-shadow:0 6px 16px -12px color-mix(in oklch,var(--primary-color) 55%,transparent)}.admin-btn--danger{color:var(--danger-color);border-color:color-mix(in oklch,var(--danger-color) 45%,var(--panel-border))}.admin-btn--danger:hover:not(:disabled){background:color-mix(in oklch,var(--danger-color) 10%,transparent);border-color:var(--danger-color)}.admin-btn--ghost{border-color:transparent;background:transparent}.admin-btn--ghost:hover:not(:disabled){background:color-mix(in srgb,var(--text-color) 6%,transparent);border-color:transparent}.admin-btn--sm{padding:5px 10px;font-size:12.5px;border-radius:8px}.admin-table-wrap{border:1px solid var(--panel-border);border-radius:14px;overflow:hidden;background:var(--panel-bg)}.admin-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.admin-table thead th{text-align:center;font-weight:600;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-sub-color);padding:12px 16px;background:color-mix(in srgb,var(--text-color) 4%,transparent);border-bottom:1px solid var(--panel-border);white-space:nowrap}.admin-table tbody td{padding:14px 16px;vertical-align:middle;text-align:center;border-bottom:1px solid color-mix(in srgb,var(--panel-border) 65%,transparent);color:var(--text-color)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover td{background:color-mix(in srgb,var(--text-color) 3%,transparent)}.admin-table__actions{display:inline-flex;gap:8px;flex-wrap:nowrap;white-space:nowrap}.admin-table__empty{text-align:center;color:var(--text-sub-color);padding:32px 0;font-size:13px}.admin-thumb{width:52px;height:52px;border-radius:10px;object-fit:cover;background:color-mix(in srgb,var(--text-color) 6%,transparent);display:inline-flex;align-items:center;justify-content:center;color:var(--text-sub-color);font-size:18px;border:1px solid var(--panel-border);overflow:hidden}.admin-thumb--sm{width:32px;height:32px;font-size:13px;border-radius:8px}.admin-form{border:1px solid var(--panel-border);border-radius:14px;padding:22px;background:color-mix(in srgb,var(--panel-bg) 96%,transparent);display:flex;flex-direction:column;gap:16px}.admin-form__row{display:flex;flex-direction:column;gap:6px}.admin-form__row--two{flex-direction:row;gap:18px}.admin-form__row--two>*{flex:1;min-width:0}.admin-form__label{font-size:12.5px;font-weight:500;color:var(--text-sub-color);letter-spacing:.02em}.admin-form__input,.admin-form__textarea,.admin-form__select{width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid var(--input-border);border-radius:10px;background-color:var(--input-bg);color:var(--text-color);font-size:14px;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.admin-form__select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:36px;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='1 1.5 6 6.5 11 1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:12px 8px}:root[data-theme=dark] .admin-form__select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='1 1.5 6 6.5 11 1.5'/%3E%3C/svg%3E")}.admin-form__textarea{resize:vertical;min-height:96px;line-height:1.5}.admin-form__input:focus,.admin-form__textarea:focus,.admin-form__select:focus{outline:none;border-color:color-mix(in oklch,var(--primary-color) 55%,transparent);box-shadow:0 0 0 3px color-mix(in oklch,var(--primary-color) 18%,transparent);background-color:color-mix(in srgb,var(--input-bg) 92%,transparent)}.admin-form__input[type=file]{padding:6px 10px;font-size:13px}.admin-form__section{margin-top:6px;padding-top:16px;border-top:1px dashed var(--panel-border);display:flex;flex-direction:column;gap:12px}.admin-form__section-title{font-size:13px;font-weight:600;margin:0;color:var(--text-color);letter-spacing:.02em}.admin-form__hint{font-size:12px;color:var(--text-sub-color);line-height:1.5}.admin-form__checkbox{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:var(--text-color);cursor:pointer;-webkit-user-select:none;user-select:none}.admin-form__actions{margin-top:4px;display:flex;justify-content:flex-end;gap:10px}.admin-pill{display:inline-flex;align-items:center;white-space:nowrap;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:500;letter-spacing:.02em;color:var(--primary-color);background:color-mix(in oklch,var(--primary-light),transparent 38%);border:1px solid color-mix(in oklch,var(--primary-color) 32%,transparent)}.admin-pill--muted{color:var(--text-sub-color);background:color-mix(in srgb,var(--text-color) 5%,transparent);border-color:color-mix(in srgb,var(--border-color) 55%,transparent)}.admin-pill--success{color:var(--success-color);background:color-mix(in oklch,var(--success-color),transparent 86%);border-color:color-mix(in oklch,var(--success-color),transparent 58%)}.admin-state{text-align:center;color:var(--text-sub-color);font-size:13px;padding:24px 0}.admin-state--error{color:var(--danger-color)}html,body{overflow-x:hidden;overflow-x:clip}@media(max-width:768px){.page-container{padding:76px 14px 24px}}@media(max-width:480px){.page-container{padding:72px 12px 20px}}@media(max-width:768px){.card{padding:16px;border-radius:14px}}@media(max-width:480px){.card{padding:14px;border-radius:12px}}@media(max-width:768px){input,textarea,select,.admin-form__input,.admin-form__textarea,.admin-form__select{font-size:16px}}@media(max-width:768px){.admin-overlay{padding:0}.admin-dialog{width:100%;max-width:100%;height:100vh;height:100dvh;border-radius:0;border-left:none;border-right:none}.admin-dialog__header{padding:14px 16px;padding-top:max(14px,env(safe-area-inset-top))}.admin-dialog__close{width:44px;height:44px}.admin-dialog__body{padding:16px 14px 20px;padding-bottom:max(20px,env(safe-area-inset-bottom))}.admin-form{padding:14px;border-radius:12px}.admin-btn{min-height:44px}.admin-form__row--two{flex-direction:column;gap:12px}.admin-form__actions{flex-direction:column-reverse;align-items:stretch}.admin-form__actions .admin-btn{width:100%}.admin-table-wrap{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}.admin-table{width:max-content;min-width:100%;table-layout:auto}.admin-table thead th,.admin-table tbody td{padding:12px;font-size:13px;white-space:nowrap}}html,a,button,[role=button],.btn-reset,.admin-btn{-webkit-tap-highlight-color:transparent}@media(max-width:768px){.mobile-hide{display:none!important}}@media(max-width:768px){:root{--font-size-3xl: 1.5rem;--font-size-2xl: 1.35rem}}@media(max-width:480px){:root{--font-size-3xl: 1.375rem;--font-size-2xl: 1.25rem}}.nav-icon[data-v-c60c3a37]{width:1em;height:1em;fill:currentColor;flex-shrink:0}button[data-v-16406ffb]:focus:not(:focus-visible){outline:none}button[data-v-16406ffb]:focus-visible{outline:2px solid var(--link-color);outline-offset:2px}.nav[data-v-16406ffb]{position:fixed;top:0;left:0;width:100%;z-index:1000;background:transparent;border-bottom:1px solid transparent;transition:all .3s ease;color:var(--text-color)}.nav.scrolled[data-v-16406ffb]{background:var(--nav-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--nav-page-border);box-shadow:0 10px 30px -24px var(--shadow-hover-color)}[data-page-theme=music]{color:var(--nav-page-color)}[data-page-theme=music]{background:var(--nav-page-scrolled-bg);border-bottom:1px solid var(--nav-page-border);color:var(--nav-page-color)}.nav-inner[data-v-16406ffb]{max-width:1440px;margin:0 auto;padding:var(--spacing-md) var(--spacing-xl);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:var(--spacing-xl)}.left-group[data-v-16406ffb]{display:flex;align-items:center;gap:var(--spacing-lg);justify-self:start}.navbar-weather-slot[data-v-16406ffb]{min-width:128px;min-height:36px;display:flex;align-items:center}.right-group[data-v-16406ffb]{display:flex;align-items:center;gap:var(--spacing-md);justify-self:end}.brand[data-v-16406ffb]{display:flex;align-items:center;gap:var(--spacing-md);cursor:pointer;transition:opacity .2s;color:inherit;text-decoration:none}.brand[data-v-16406ffb]:hover{opacity:.8}.logo[data-v-16406ffb]{width:28px;height:28px}.title[data-v-16406ffb]{font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.links[data-v-16406ffb]{display:flex;align-items:center;gap:var(--spacing-sm);justify-self:center}.link[data-v-16406ffb]{position:relative;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:8px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-color);text-decoration:none;transition:all .2s}.link[data-v-16406ffb]:hover{background:var(--menu-hover);color:var(--primary-color)}.link.router-link-active[data-v-16406ffb]{background:transparent;color:var(--primary-color);font-weight:var(--font-weight-semibold)}.link.router-link-active[data-v-16406ffb]:after{content:"";position:absolute;left:10px;right:10px;bottom:4px;height:2px;border-radius:999px;background:color-mix(in srgb,var(--primary-color) 88%,transparent);box-shadow:0 0 14px color-mix(in srgb,var(--primary-color) 55%,transparent)}.icon-btn[data-v-16406ffb]{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:transparent;border:none;color:inherit;cursor:pointer;transition:all .2s}.icon-btn[data-v-16406ffb]:hover{background:var(--menu-hover);color:var(--primary-color)}.hamburger-btn[data-v-16406ffb]{display:none}.profile[data-v-16406ffb],.auth[data-v-16406ffb]{align-items:center}.profile[data-v-16406ffb]{position:relative;display:flex;align-items:center;gap:var(--spacing-md)}.auth[data-v-16406ffb]{display:flex;align-items:center;gap:var(--spacing-md)}.greet[data-v-16406ffb]{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-sub-color)}.avatar-wrap[data-v-16406ffb]{width:40px;height:40px;border-radius:50%;overflow:hidden;border:2px solid var(--border-color);cursor:pointer;transition:all .2s}@media(hover:hover)and (pointer:fine){.avatar-wrap[data-v-16406ffb]:hover{border-color:var(--primary-color);transform:scale(1.05)}}.avatar[data-v-16406ffb]{width:100%;height:100%;object-fit:cover;display:block}.menu[data-v-16406ffb]{position:absolute;top:52px;right:0;background:var(--menu-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--card-hover-shadow);padding:var(--spacing-sm);min-width:180px;z-index:1010;color:var(--text-color);display:flex;flex-direction:column}.menu-handle[data-v-16406ffb],.menu-greet[data-v-16406ffb]{display:none}.menu-item[data-v-16406ffb]{width:100%;text-align:left;padding:var(--spacing-sm) var(--spacing-md);border-radius:8px;background:transparent;border:none;cursor:pointer;color:var(--text-color);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all .2s}.menu-item[data-v-16406ffb]:hover{background:var(--menu-hover);color:var(--primary-color)}.menu-item--danger[data-v-16406ffb]{color:var(--danger-color)}.menu-item--danger[data-v-16406ffb]:hover{color:var(--danger-color);background:color-mix(in srgb,var(--danger-color) 12%,transparent)}.btn[data-v-16406ffb]{border-radius:8px;border:1px solid var(--primary-color);background:var(--primary-color);color:var(--text-inverse-color);cursor:pointer;padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);transition:all .2s}.btn[data-v-16406ffb]:hover{background:var(--primary-hover-color);border-color:var(--primary-hover-color)}.btn.ghost[data-v-16406ffb]{background:transparent;color:var(--primary-color)}.btn.ghost[data-v-16406ffb]:hover{background:var(--primary-light)}.menu-fade-enter-active[data-v-16406ffb],.menu-fade-leave-active[data-v-16406ffb]{transition:opacity .18s ease,transform .2s ease}.menu-fade-enter-from[data-v-16406ffb],.menu-fade-leave-to[data-v-16406ffb]{opacity:0;transform:translateY(-4px)}.drawer-overlay[data-v-16406ffb]{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1100;display:flex}.drawer-panel[data-v-16406ffb]{width:min(86vw,340px);max-width:100%;height:100vh;height:100dvh;background:var(--menu-bg);border-right:1px solid var(--border-color);box-shadow:8px 0 30px -12px var(--shadow-hover-color);display:flex;flex-direction:column;gap:14px;padding:16px 16px max(20px,env(safe-area-inset-bottom));padding-top:max(16px,env(safe-area-inset-top));overflow-y:auto}.drawer-header[data-v-16406ffb]{display:flex;align-items:center;justify-content:space-between;gap:12px}.drawer-search[data-v-16406ffb]{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border-color);border-radius:12px;background:var(--input-bg);color:var(--text-sub-color);font-size:14px;text-align:left;cursor:pointer;transition:border-color .2s,color .2s}.drawer-search[data-v-16406ffb]:hover{border-color:var(--primary-color);color:var(--text-color)}.drawer-search .nav-icon[data-v-16406ffb]{color:var(--text-sub-color)}.drawer-links[data-v-16406ffb]{display:flex;flex-direction:column;gap:4px}.drawer-link[data-v-16406ffb]{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;font-size:15px;font-weight:500;color:var(--text-color);text-decoration:none;min-height:48px;transition:background .2s,color .2s}.drawer-link .nav-icon[data-v-16406ffb]{width:18px;text-align:center;color:var(--text-sub-color)}.drawer-link.router-link-active[data-v-16406ffb]{background:var(--primary-light);color:var(--primary-color)}.drawer-link.router-link-active .nav-icon[data-v-16406ffb]{color:var(--primary-color)}.drawer-section[data-v-16406ffb]{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid var(--border-color)}.drawer-secondary[data-v-16406ffb]{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:12px;background:transparent;border:1px solid var(--border-color);color:var(--text-color);font-size:14px;font-weight:500;cursor:pointer;min-height:48px;transition:border-color .2s,color .2s,background .2s}.drawer-secondary[data-v-16406ffb]:hover{border-color:var(--primary-color);color:var(--primary-color)}.drawer-secondary--primary[data-v-16406ffb]{background:var(--primary-color);border-color:var(--primary-color);color:var(--text-inverse-color)}.drawer-secondary--primary[data-v-16406ffb]:hover{background:var(--primary-hover-color);border-color:var(--primary-hover-color);color:var(--text-inverse-color)}.drawer-fade-enter-active[data-v-16406ffb],.drawer-fade-leave-active[data-v-16406ffb]{transition:opacity .22s ease}.drawer-fade-enter-from[data-v-16406ffb],.drawer-fade-leave-to[data-v-16406ffb]{opacity:0}.drawer-slide-enter-active[data-v-16406ffb],.drawer-slide-leave-active[data-v-16406ffb]{transition:transform .26s cubic-bezier(.4,0,.2,1)}.drawer-slide-enter-from[data-v-16406ffb],.drawer-slide-leave-to[data-v-16406ffb]{transform:translate(-100%)}@media(max-width:768px){.nav-inner[data-v-16406ffb]{grid-template-columns:auto 1fr auto;padding:10px 14px;gap:10px}.left-group[data-v-16406ffb]{gap:8px}.navbar-weather-slot[data-v-16406ffb]{min-width:44px;min-height:44px}.desktop-only[data-v-16406ffb]{display:none!important}.hamburger-btn[data-v-16406ffb]{display:flex;width:44px;height:44px}.icon-btn[data-v-16406ffb]{width:44px;height:44px}.title[data-v-16406ffb]{font-size:var(--font-size-base)}.right-group[data-v-16406ffb]{gap:4px}.profile[data-v-16406ffb]{gap:0}.avatar-wrap[data-v-16406ffb]{width:44px;height:44px}.menu[data-v-16406ffb]{position:fixed;top:auto;left:0;right:0;bottom:0;border-radius:18px 18px 0 0;border:1px solid var(--border-color);border-bottom:none;padding:8px 12px max(16px,env(safe-area-inset-bottom));min-width:0;width:100%;z-index:1200;box-shadow:0 -10px 30px -12px var(--shadow-hover-color)}.menu-handle[data-v-16406ffb]{display:block;width:40px;height:4px;border-radius:999px;background:var(--border-color);margin:6px auto 10px}.menu-greet[data-v-16406ffb]{display:block;padding:4px 12px 10px;font-size:13px;color:var(--text-sub-color);border-bottom:1px solid var(--border-color);margin-bottom:6px}.menu-item[data-v-16406ffb]{padding:14px 12px;font-size:15px;min-height:48px}.menu-fade-enter-from[data-v-16406ffb],.menu-fade-leave-to[data-v-16406ffb]{transform:translateY(20px)}.auth .icon-btn[data-v-16406ffb]{display:none}.auth .btn.ghost[data-v-16406ffb]{padding:8px 14px;font-size:13px}}@media(max-width:480px){.title[data-v-16406ffb]{display:none}}.main-content[data-v-d323f4d9]{padding-top:60px;min-height:100vh}.route-loading[data-v-d323f4d9]{position:fixed;top:60px;left:0;right:0;z-index:1200;height:2px;overflow:hidden;pointer-events:none}.route-loading__bar[data-v-d323f4d9]{display:block;width:40%;height:100%;background:var(--primary-color);box-shadow:0 0 10px color-mix(in oklch,var(--primary-color) 45%,transparent);animation:route-loading-slide-d323f4d9 .9s ease-in-out infinite}.route-loading--inline[data-v-d323f4d9]{position:static;height:auto;min-height:180px;display:grid;place-items:center;color:var(--text-sub-color);font-size:.92rem}.route-error[data-v-d323f4d9]{min-height:220px;display:grid;place-items:center;gap:12px;color:var(--text-sub-color)}.route-error p[data-v-d323f4d9]{margin:0;font-size:.95rem}.route-error__retry[data-v-d323f4d9]{border:1px solid color-mix(in oklch,var(--primary-color) 38%,transparent);border-radius:6px;padding:8px 14px;background:color-mix(in oklch,var(--primary-color) 10%,transparent);color:var(--primary-color);cursor:pointer}.route-error__retry[data-v-d323f4d9]:hover{background:color-mix(in oklch,var(--primary-color) 16%,transparent)}@keyframes route-loading-slide-d323f4d9{0%{transform:translate(-100%)}to{transform:translate(260%)}}
