:root{--fn-bg-0: #0d0b08;--fn-bg-1: #14110d;--fn-bg-2: #1c1810;--fn-bg-3: #251f15;--fn-gold: #e6c570;--fn-gold-soft: #f4d98a;--fn-gold-deep: #c89b3c;--fn-gold-grad: linear-gradient(135deg, #f4d98a 0%, #c89b3c 100%);--fn-ink: #f5efe2;--fn-ink-dim: rgba(245, 239, 226, .62);--fn-ink-faint: rgba(245, 239, 226, .4);--fn-line: rgba(230, 197, 112, .22);--fn-line-strong: rgba(230, 197, 112, .45);--fn-surface: rgba(230, 197, 112, .08);--fn-surface-hover: rgba(230, 197, 112, .16);--fn-success: #4ade80;--fn-danger: #ff9b9b;--fn-page-bg: radial-gradient(1200px 700px at 75% 10%, #211b11 0%, var(--fn-bg-1) 45%, var(--fn-bg-0) 100%);--fn-radius-sm: 8px;--fn-radius: 12px;--fn-radius-lg: 22px;--fn-font: "Segoe UI", -apple-system, BlinkMacSystemFont, sans-serif;--fn-shadow: 0 20px 40px rgba(0, 0, 0, .5)}.fn-theme,body.fn-theme{background:var(--fn-page-bg);color:var(--fn-ink);font-family:var(--fn-font)}.fn-gold-text{background:var(--fn-gold-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.fn-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--fn-radius);background:var(--fn-gold-grad);color:#14110d;font-weight:700;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease}.fn-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #e6c5704d}.fn-btn-ghost{background:var(--fn-surface);border:1px solid var(--fn-line);color:var(--fn-ink)}.fn-btn-ghost:hover{background:var(--fn-surface-hover);border-color:var(--fn-line-strong);box-shadow:none}.fn-btn-primary{background:var(--fn-gold-grad);color:#14110d;font-weight:700}.fn-btn-outline{background:var(--fn-surface);border:1px solid var(--fn-line-strong);color:var(--fn-gold)}.fn-btn-outline:hover{background:var(--fn-surface-hover);border-color:var(--fn-gold);box-shadow:none}.fn-btn-secondary{background:var(--fn-surface);border:1px solid var(--fn-line);color:var(--fn-ink);font-weight:600}.fn-btn-secondary:hover{background:var(--fn-surface-hover);border-color:var(--fn-line-strong);box-shadow:none}.fn-btn-logout{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border:none;border-radius:var(--fn-radius);background:none;color:var(--fn-ink-faint);font:inherit;font-weight:600;cursor:pointer;transition:color .2s ease,background .2s ease}.fn-btn-logout:hover{color:var(--fn-danger);background:var(--fn-surface)}.fn-auth-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;border:1px solid var(--fn-line);border-radius:50px;background:var(--fn-surface);color:var(--fn-ink);font:inherit;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .25s ease,border-color .25s ease,transform .25s ease}.fn-auth-btn:hover{background:var(--fn-surface-hover);border-color:var(--fn-line-strong);transform:translateY(-2px)}.fn-auth-btn--block{width:100%;border-radius:var(--fn-radius);padding:14px 20px;border-color:var(--fn-line-strong);font-size:1rem}.fn-auth-btn--block:hover{border-color:var(--fn-gold)}.fn-auth-btn .fn-g-icon{flex-shrink:0;background:#fff;border-radius:3px;padding:1px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:1px solid transparent;border-radius:var(--fn-radius);font:inherit;font-weight:600;text-decoration:none;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease,background .2s ease,border-color .2s ease}.btn-primary{background:var(--fn-gold-grad);color:#14110d;font-weight:700}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px #e6c5704d}.btn-secondary,.btn-outline{background:var(--fn-surface);border-color:var(--fn-line);color:var(--fn-ink)}.btn-secondary:hover,.btn-outline:hover{background:var(--fn-surface-hover);border-color:var(--fn-line-strong)}.btn-logout{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border:none;border-radius:var(--fn-radius);background:none;color:var(--fn-ink-faint);font:inherit;font-weight:600;cursor:pointer;transition:color .2s ease,background .2s ease}.btn-logout:hover{color:var(--fn-danger);background:var(--fn-surface)}.fn-input,.fn-field{width:100%;padding:12px 16px;border:1px solid var(--fn-line);border-radius:var(--fn-radius);background:var(--fn-surface);color:var(--fn-ink);font:inherit;transition:border-color .2s ease,background .2s ease}.fn-input::placeholder,.fn-field::placeholder{color:var(--fn-ink-faint)}.fn-input:focus,.fn-field:focus{outline:none;border-color:var(--fn-gold);background:var(--fn-surface-hover)}.fn-card{background:var(--fn-bg-2);border:1px solid var(--fn-line);border-radius:var(--fn-radius-lg);box-shadow:var(--fn-shadow)}:root{--fn-gutter: clamp(16px, 3vw, 48px);--fn-header-h: 64px;--fn-measure: 72ch}.fn-page{width:100%;max-width:100%;margin:0;padding-inline:var(--fn-gutter);padding-block:clamp(20px,2.5vw,36px)}.fn-prose{max-width:var(--fn-measure)}.fn-header{position:sticky;top:0;z-index:100;background:var(--fn-bg-2);border-bottom:1px solid var(--fn-line);box-shadow:0 2px 10px #0006}.fn-header-inner{width:100%;min-height:var(--fn-header-h);margin:0;padding-inline:var(--fn-gutter);padding-block:10px;display:flex;align-items:center;gap:clamp(16px,2.5vw,40px)}.fn-brand{display:inline-flex;align-items:center;gap:10px;font-size:1.4rem;font-weight:700;text-decoration:none;color:var(--fn-gold);white-space:nowrap}.fn-brand .fn-brand-mark{background:var(--fn-gold-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.fn-nav{display:flex;align-items:center;gap:clamp(12px,1.6vw,26px);flex:1;flex-wrap:wrap}.fn-nav a{color:var(--fn-ink-dim);text-decoration:none;font-weight:500;padding:6px 4px;transition:color .2s ease}.fn-nav a:hover,.fn-nav a.router-link-active{color:var(--fn-gold)}.fn-header-right{display:flex;align-items:center;gap:14px;margin-left:auto}.fn-account{position:relative}.fn-account-trigger{display:inline-flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;border:1px solid var(--fn-line);border-radius:50px;background:var(--fn-surface);color:var(--fn-ink);font:inherit;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .25s ease,border-color .25s ease}.fn-account-trigger:hover{background:var(--fn-surface-hover);border-color:var(--fn-line-strong)}.fn-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;flex-shrink:0}.fn-avatar-fallback{display:inline-flex;align-items:center;justify-content:center;background:var(--fn-gold-grad);color:#14110d;font-weight:700;font-size:.95rem}.fn-account-name{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fn-account-caret{font-size:.7rem;opacity:.7}.fn-account-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:220px;background:var(--fn-bg-2);border:1px solid var(--fn-line);border-radius:14px;padding:8px;box-shadow:var(--fn-shadow)}.fn-account-head{padding:10px 12px 12px;border-bottom:1px solid var(--fn-line);margin-bottom:6px}.fn-account-head .fn-account-fullname{font-weight:600;font-size:.95rem}.fn-account-head .fn-account-email{font-size:.8rem;color:var(--fn-ink-faint);margin-top:2px;overflow:hidden;text-overflow:ellipsis}.fn-account-item{display:block;width:100%;text-align:left;padding:10px 12px;border:none;border-radius:8px;background:none;color:var(--fn-ink);font:inherit;font-size:.9rem;text-decoration:none;cursor:pointer;transition:background .2s ease}.fn-account-item:hover{background:var(--fn-surface-hover)}.fn-account-item.fn-account-logout{color:var(--fn-danger);margin-top:4px;border-top:1px solid var(--fn-line)}.role-badge{display:inline-block;margin-top:8px;padding:3px 10px;border-radius:50px;font-size:.72rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;background:#e6c57026;color:var(--fn-gold)}.role-badge.admin{background:linear-gradient(135deg,var(--fn-gold-soft) 0%,var(--fn-gold-deep) 100%);color:#14110d}.fn-fade-enter-active,.fn-fade-leave-active{transition:opacity .18s ease,transform .18s ease}.fn-fade-enter-from,.fn-fade-leave-to{opacity:0;transform:translateY(-4px)}@media (max-width: 768px){.fn-header-inner{gap:12px;flex-wrap:wrap}.fn-brand{font-size:1.15rem}.fn-nav{gap:14px;order:3;flex-basis:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.fn-nav a{white-space:nowrap}.fn-account-name{display:none}.fn-account-trigger{padding:6px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--fn-font);background:var(--fn-page-bg);color:var(--fn-ink);line-height:1.6}#app{min-height:100vh;display:flex;flex-direction:column}main{flex:1}footer{background:var(--fn-bg-0);border-top:1px solid var(--fn-line);padding:20px;text-align:center;color:var(--fn-ink-faint);font-size:.9em;margin-top:auto}
