.brand-page{min-height:100vh;background:#f9fafb;font-family:DM Sans,system-ui,-apple-system,sans-serif;color:#111827}.brand-page__header{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;border-bottom:1px solid #E5E7EB;background:#fff}.brand-page__back{background:none;border:none;color:#4f46e5;cursor:pointer;font-size:14px;padding:4px 0;margin-bottom:4px}.brand-page__back:hover{text-decoration:underline}.brand-page__title{font-family:Syne,sans-serif;font-weight:700;font-size:24px;margin:0}.brand-page__header-right{display:flex;gap:16px;align-items:center}.brand-page__hub-select,.brand-page__hub-label{padding:8px 12px;border:1px solid #E5E7EB;border-radius:6px;font-size:14px;background:#fff;min-width:200px}.brand-page__hub-select{cursor:pointer}.brand-page__user{color:#6b7280;font-size:14px}.brand-page__layout{display:grid;grid-template-columns:420px 1fr;height:calc(100vh - 72px)}.brand-page__sidebar{display:flex;flex-direction:column;border-right:1px solid #E5E7EB;background:#fff;overflow:hidden}.brand-page__sidebar-content{flex:1;overflow-y:auto;padding:24px}.brand-page__main{display:flex;flex-direction:column;overflow:hidden}.brand-page__preview-toolbar{display:flex;gap:8px;padding:16px 24px;border-bottom:1px solid #E5E7EB;background:#fff}.brand-preview-toggle{padding:6px 14px;border-radius:6px;border:1px solid #E5E7EB;background:#fff;font-size:13px;cursor:pointer}.brand-preview-toggle--active{background:#4f46e5;color:#fff;border-color:#4f46e5}.brand-tabs{display:flex;gap:2px;padding:16px 16px 0;border-bottom:1px solid #E5E7EB;overflow-x:auto}.brand-tabs__btn{padding:10px 14px;background:none;border:none;border-bottom:2px solid transparent;color:#6b7280;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap}.brand-tabs__btn:hover{color:#111827}.brand-tabs__btn--active{color:#4f46e5;border-bottom-color:#4f46e5}.brand-panel__title{font-family:Syne,sans-serif;font-size:18px;font-weight:700;margin:0 0 4px}.brand-panel__hint{color:#6b7280;font-size:13px;margin:0 0 20px;line-height:1.5}.brand-section{margin-bottom:24px}.brand-section__title{font-size:13px;font-weight:600;color:#4b5563;margin:0 0 12px;text-transform:uppercase;letter-spacing:.04em}.brand-color-grid{display:flex;flex-direction:column;gap:10px}.brand-color-field{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:8px;border-radius:6px}.brand-color-field:hover{background:#f9fafb}.brand-color-field__label{display:flex;flex-direction:column;gap:2px}.brand-color-field__name{font-size:13px;font-weight:500}.brand-color-field__hint{font-size:11px;color:#9ca3af}.brand-color-field__controls{display:flex;gap:6px;align-items:center}.brand-color-field__swatch{width:32px;height:32px;border-radius:6px;border:1px solid #E5E7EB;cursor:pointer;padding:0}.brand-color-field__hex{width:90px;padding:6px 8px;border:1px solid #E5E7EB;border-radius:4px;font-family:DM Mono,ui-monospace,monospace;font-size:12px;text-transform:uppercase}.brand-color-field__hex--invalid{border-color:#dc2626}.brand-color-field__reset{width:24px;height:24px;border-radius:4px;border:none;background:#f3f4f6;color:#6b7280;cursor:pointer;font-size:16px;line-height:1}.brand-color-field__reset:hover{background:#e5e7eb}.brand-typography-grid{display:flex;flex-direction:column;gap:20px}.brand-typography-field{display:flex;flex-direction:column;gap:8px}.brand-typography-field__label{display:flex;flex-direction:column}.brand-typography-field__name{font-size:13px;font-weight:500}.brand-typography-field__hint{font-size:11px;color:#9ca3af}.brand-typography-field__select{padding:8px 10px;border:1px solid #E5E7EB;border-radius:6px;background:#fff;font-size:14px}.brand-typography-field__preview{padding:12px;background:#f9fafb;border-radius:6px;font-size:18px;color:#374151}.brand-radius-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.brand-radius-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;border:2px solid #E5E7EB;background:#fff;cursor:pointer;border-radius:8px}.brand-radius-option:hover{border-color:#818cf8}.brand-radius-option--active{border-color:#4f46e5;background:#eef2ff}.brand-radius-option__demo{width:48px;height:48px;background:#4f46e5}.brand-radius-option__label{font-size:12px;font-weight:500}.brand-shadow-list{display:flex;flex-direction:column;gap:8px}.brand-shadow-option{display:flex;align-items:center;gap:16px;padding:12px 16px;border:2px solid #E5E7EB;background:#fff;cursor:pointer;border-radius:8px;text-align:left}.brand-shadow-option:hover{border-color:#818cf8}.brand-shadow-option--active{border-color:#4f46e5}.brand-shadow-option__demo{width:48px;height:48px;background:#fff;border-radius:6px;flex-shrink:0}.brand-shadow-option__demo--flat{box-shadow:none;border:1px solid #E5E7EB}.brand-shadow-option__demo--subtle{box-shadow:0 1px 2px #0000000a}.brand-shadow-option__demo--default{box-shadow:0 0 0 1px #0000000a,0 1px 3px #0000000f,0 2px 8px #0000000a}.brand-shadow-option__demo--pronounced{box-shadow:0 0 0 1px #0000000f,0 2px 6px #00000014,0 8px 20px #00000014}.brand-shadow-option__text{flex:1}.brand-shadow-option__label{font-size:13px;font-weight:600}.brand-shadow-option__hint{font-size:11px;color:#6b7280;margin-top:2px}.brand-logo-grid{display:flex;flex-direction:column;gap:16px}.brand-logo-slot{border:1px solid #E5E7EB;border-radius:8px;padding:16px;background:#fff}.brand-logo-slot__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.brand-logo-slot__label{font-size:14px;font-weight:600;margin:0}.brand-logo-slot__hint{font-size:11px;color:#6b7280;margin:2px 0 0}.brand-logo-slot__add{padding:6px 10px;background:#eef2ff;color:#4f46e5;border:1px solid #E0E7FF;border-radius:4px;font-size:12px;cursor:pointer;white-space:nowrap}.brand-logo-slot__add:hover:not(:disabled){background:#e0e7ff}.brand-logo-slot__add:disabled{opacity:.5;cursor:default}.brand-logo-slot__empty{padding:20px;text-align:center;color:#9ca3af;font-size:12px;font-style:italic;background:#f9fafb;border-radius:4px}.brand-logo-slot__variants{display:flex;flex-direction:column;gap:8px}.brand-logo-variant{display:grid;grid-template-columns:60px 1fr auto;gap:12px;align-items:center;padding:8px;background:#f9fafb;border-radius:4px}.brand-logo-variant__img{max-width:60px;max-height:40px;object-fit:contain}.brand-logo-variant__meta{font-size:12px}.brand-logo-variant__name{font-weight:500}.brand-logo-variant__version{color:#9ca3af;font-family:DM Mono,monospace;font-size:11px}.brand-logo-variant__actions{display:flex;gap:4px}.brand-logo-variant__btn{padding:4px 8px;font-size:11px;border:1px solid #E5E7EB;border-radius:4px;background:#fff;cursor:pointer}.brand-logo-variant__btn:hover:not(:disabled){background:#f3f4f6}.brand-logo-variant__btn--danger{color:#dc2626;border-color:#fecaca}.brand-logo-variant__btn--danger:hover:not(:disabled){background:#fef2f2}.brand-error{padding:10px 12px;background:#fef2f2;border:1px solid #FECACA;color:#991b1b;border-radius:4px;font-size:13px;margin-bottom:12px}.brand-darkmode-list{display:flex;flex-direction:column;gap:10px}.brand-darkmode-option{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;border:2px solid #E5E7EB;border-radius:8px;cursor:pointer}.brand-darkmode-option:hover{border-color:#818cf8}.brand-darkmode-option--active{border-color:#4f46e5;background:#eef2ff}.brand-darkmode-option__label{font-size:14px;font-weight:600}.brand-darkmode-option__hint{font-size:12px;color:#6b7280;margin-top:4px;line-height:1.4}.brand-page__actions{display:flex;gap:8px;align-items:center;padding:16px 24px;border-top:1px solid #E5E7EB;background:#fafbfc}.brand-btn{padding:8px 16px;font-size:13px;font-weight:500;border-radius:6px;border:1px solid #E5E7EB;cursor:pointer}.brand-btn:disabled{opacity:.5;cursor:default}.brand-btn--primary{background:#4f46e5;color:#fff;border-color:#4f46e5}.brand-btn--primary:hover:not(:disabled){background:#4338ca}.brand-btn--ghost{background:#fff;color:#374151}.brand-btn--ghost:hover:not(:disabled){background:#f3f4f6}.brand-page__ok{color:#059669;font-size:13px;margin-right:auto}.brand-page__error{color:#dc2626;font-size:12px;margin-right:auto}.brand-preview{flex:1;overflow-y:auto;padding:24px;--fb-primary: #4F46E5;--fb-primary-hover: #4338CA;--fb-primary-muted: #818CF8;--fb-primary-soft: #E0E7FF;--fb-primary-bg: #EEF2FF;--fb-surface: #FFFFFF;--fb-surface-muted: #F9FAFB;--fb-surface-border: #E5E7EB;--fb-text: #111827;--fb-text-muted: #6B7280;--fb-success: #059669;--fb-warning: #D97706;--fb-error: #DC2626;--fb-info: #2563EB;--fb-font-sans: "DM Sans", system-ui, sans-serif;--fb-font-heading: "Syne", "DM Sans", sans-serif;--fb-radius-sm: 4px;--fb-radius-md: 8px;--fb-radius-lg: 12px;--fb-shadow-widget: 0 0 0 1px rgba(0, 0, 0, .04), 0 1px 3px rgba(0, 0, 0, .06), 0 2px 8px rgba(0, 0, 0, .04);background:var(--fb-surface-muted);color:var(--fb-text);font-family:var(--fb-font-sans)}.brand-preview[data-theme=dark]{--fb-surface: #1F2937;--fb-surface-muted: #111827;--fb-surface-border: #374151;--fb-text: #F9FAFB;--fb-text-muted: #9CA3AF}.brand-preview__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-family:var(--fb-font-heading);font-size:14px;font-weight:600}.brand-preview__hint{color:var(--fb-text-muted);font-weight:400}.brand-preview__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.brand-preview__section{display:flex;flex-direction:column;gap:8px}.brand-preview__label{font-size:11px;font-weight:600;color:var(--fb-text-muted);text-transform:uppercase;letter-spacing:.04em}.pv-widget{background:var(--fb-surface);border-radius:var(--fb-radius-md);padding:16px;box-shadow:var(--fb-shadow-widget)}.pv-widget__header{display:flex;gap:8px;align-items:center;margin-bottom:8px}.pv-widget__logo{max-width:32px;max-height:20px;object-fit:contain}.pv-widget__title{font-family:var(--fb-font-heading);font-weight:600;font-size:14px}.pv-widget__metric{font-size:32px;font-weight:700;color:var(--fb-primary);line-height:1;margin:8px 0}.pv-widget__bars{display:flex;gap:2px;height:6px;border-radius:var(--fb-radius-sm);overflow:hidden;margin-bottom:12px}.pv-widget__bar{flex:1;border-radius:9999px}.pv-widget__bar--open{background:var(--fb-info);flex:2}.pv-widget__bar--pending{background:var(--fb-warning);flex:1}.pv-widget__bar--closed{background:var(--fb-success);flex:1.5}.pv-widget__btn{background:var(--fb-primary);color:#fff;border:none;border-radius:var(--fb-radius-sm);padding:6px 12px;font-size:12px;font-weight:500;cursor:pointer}.pv-kanban{padding:16px;background:var(--fb-surface-muted);border-radius:var(--fb-radius-md)}.pv-kanban__card{background:var(--fb-surface);border-radius:var(--fb-radius-sm);padding:10px 12px;box-shadow:var(--fb-shadow-widget)}.pv-kanban__head{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--fb-text-muted);margin-bottom:6px}.pv-kanban__logo{max-width:16px;max-height:16px}.pv-kanban__id{font-family:DM Mono,monospace;flex:1}.pv-kanban__priority{color:var(--fb-warning);font-weight:700}.pv-kanban__title{font-weight:500;font-size:13px;margin-bottom:6px}.pv-kanban__meta{display:flex;gap:8px;font-size:11px;color:var(--fb-text-muted)}.pv-kanban__assignee{background:var(--fb-primary-bg);color:var(--fb-primary);padding:1px 6px;border-radius:9999px;font-size:10px;font-weight:600}.pv-kanban__type{display:inline-block;margin-top:6px;font-size:10px;color:var(--fb-primary);font-weight:500}.pv-ph-header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--fb-surface);border:1px solid var(--fb-surface-border);border-radius:var(--fb-radius-md)}.pv-ph-header__logo{height:24px;width:auto;max-width:120px;object-fit:contain}.pv-ph-header__logo-fallback{display:inline-flex;align-items:center;justify-content:center;width:16px;height:24px;font-family:Syne,sans-serif;font-weight:700;font-size:14px;color:var(--fb-primary)}.pv-ph-header__subtitle{font-family:Syne,sans-serif;font-weight:600;font-size:13px;color:var(--fb-text)}.pv-pdf{background:var(--fb-surface);padding:20px;border-radius:var(--fb-radius-md);border:1px solid var(--fb-surface-border);display:flex;flex-direction:column;gap:8px}.pv-pdf__logo{max-width:80px;max-height:28px;object-fit:contain}.pv-pdf__title{font-family:var(--fb-font-heading);font-size:20px;font-weight:700;color:var(--fb-primary);margin:0}.pv-pdf__chip{display:inline-block;align-self:flex-start;padding:3px 10px;background:var(--fb-primary-bg);color:var(--fb-primary);border-radius:9999px;font-size:11px;font-weight:500}.pv-section{background:var(--fb-surface);padding:16px;border-radius:var(--fb-radius-md);border:1px solid var(--fb-surface-border)}.pv-section__heading{font-family:var(--fb-font-heading);font-size:16px;font-weight:700;margin:0 0 8px;color:var(--fb-primary)}.pv-section__body{font-size:13px;line-height:1.5;margin:0 0 12px;color:var(--fb-text)}.pv-section__meta{display:flex;gap:8px;font-size:11px}.pv-section__label{color:var(--fb-text-muted)}.pv-section__value{font-weight:500}.brand-page-empty{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;font-family:DM Sans,sans-serif}.brand-darkcolors-section{margin-top:24px;padding-top:20px;border-top:1px solid #E5E7EB}.brand-darkcolors-section__title{font-family:Syne,sans-serif;font-size:14px;font-weight:700;margin-bottom:4px;color:#4f46e5}:root{--fb-primary: #4F46E5;--fb-primary-muted: #818CF8;--fb-primary-light: #C7D2FE;--fb-primary-subtle: #EEF2FF;--fb-primary-dark: #4338CA;--fb-text: #111827;--fb-text-muted: #6B7280;--fb-bg: #FFFFFF;--fb-bg-page: #F9FAFB;--fb-bg-secondary: #F3F4F6;--fb-bg-hover: #EEF2FF;--fb-border: #E5E7EB;--fb-success: #059669;--fb-warning: #D97706;--fb-error: #DC2626;--fb-radius-sm: 4px;--fb-radius-md: 6px;--fb-radius-lg: 8px;--fb-radius-xl: 12px;--fb-shadow-sm: 0 1px 2px rgba(0,0,0,.05);--fb-shadow-md: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -2px rgba(0,0,0,.05);--fb-shadow-card: 0 1px 2px rgba(0,0,0,.04), 0 2px 8px rgba(0,0,0,.06), 0 8px 24px rgba(0,0,0,.04)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:DM Sans,-apple-system,system-ui,sans-serif;color:var(--fb-text);background:var(--fb-bg-page);line-height:1.5;-webkit-font-smoothing:antialiased}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh}.loading-spinner{width:32px;height:32px;border:3px solid var(--fb-border);border-top-color:var(--fb-primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-section{text-align:center;padding:64px 0;color:var(--fb-text-muted)}.loading-section .loading-spinner{margin:0 auto 12px}.error-section{text-align:center;padding:64px 0;color:var(--fb-error)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(var(--fb-border) 1px,transparent 1px),linear-gradient(90deg,var(--fb-border) 1px,transparent 1px);background-size:64px 64px;background-position:center center}.login-card{background:var(--fb-bg);border-radius:var(--fb-radius-xl);padding:48px 40px;text-align:center;box-shadow:var(--fb-shadow-card);max-width:400px;width:100%;margin:24px}.login-logo{display:block;margin:0 auto 20px}.login-wordmark,.header-wordmark{font-family:Syne,sans-serif;font-size:28px;letter-spacing:-.02em;line-height:1}.wm-forma{font-weight:400;color:var(--fb-text)}.wm-bility{font-weight:700;color:var(--fb-primary)}.login-subtitle{font-size:14px;color:var(--fb-text-muted);margin:8px 0 32px}.login-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 28px;background:var(--fb-primary);color:#fff;border:none;border-radius:var(--fb-radius-lg);font-family:inherit;font-size:15px;font-weight:600;text-decoration:none;cursor:pointer;transition:background .15s}.login-btn:hover{background:var(--fb-primary-dark)}.login-hint{margin-top:24px;font-size:13px;color:var(--fb-text-muted);line-height:1.6}@keyframes heartbeat{0%,to{opacity:.55}14%{opacity:1}28%{opacity:.55}42%{opacity:.85}56%{opacity:.55}}.heartbeat{animation:heartbeat 1.8s ease-in-out infinite}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:var(--fb-bg);border-bottom:1px solid var(--fb-border);position:sticky;top:0;z-index:10}.header-left{display:flex;align-items:center;gap:12px}.header-title{display:flex;flex-direction:column}.header-wordmark{font-size:20px}.header-subtitle{font-size:11px;color:var(--fb-text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.header-right{display:flex;align-items:center;gap:16px}.header-account{font-size:13px;color:var(--fb-text-muted);padding:4px 10px;background:var(--fb-bg-secondary);border-radius:var(--fb-radius-sm)}.header-user{display:flex;align-items:center;gap:8px}.header-avatar{width:28px;height:28px;border-radius:50%}.header-name{font-size:14px;font-weight:500}.header-logout{font-size:13px;color:var(--fb-text-muted);text-decoration:none;padding:6px 12px;border-radius:var(--fb-radius-sm);transition:background .15s}.header-logout:hover{background:var(--fb-bg-secondary);color:var(--fb-text)}.dashboard-main{max-width:960px;margin:0 auto;padding:32px 24px}.summary-bar{display:flex;gap:24px;align-items:center;margin-bottom:32px;padding:16px 20px;background:var(--fb-bg);border-radius:var(--fb-radius-lg);box-shadow:var(--fb-shadow-sm)}.summary-stat{display:flex;align-items:baseline;gap:6px}.summary-value{font-size:24px;font-weight:700;font-family:Syne,sans-serif;color:var(--fb-primary)}.summary-label{font-size:14px;color:var(--fb-text-muted)}.plan-badge{font-size:12px;font-weight:600;padding:3px 10px;border-radius:var(--fb-radius-sm)}.plan-badge--trial{background:var(--fb-primary-subtle);color:var(--fb-primary)}.plan-badge--active{background:#ecfdf5;color:var(--fb-success)}.hub-card{background:var(--fb-bg);border-radius:var(--fb-radius-lg);box-shadow:var(--fb-shadow-card);margin-bottom:24px;overflow:hidden}.hub-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--fb-border)}.hub-info{display:flex;align-items:center;gap:10px}.hub-icon{color:var(--fb-text-muted)}.hub-name{font-size:16px;font-weight:600;font-family:Syne,sans-serif}.hub-count{font-size:13px;color:var(--fb-text-muted)}.hub-projects{padding:4px 0}.project-row{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;transition:background .15s}.project-row:hover{background:var(--fb-bg-page)}.project-info{display:flex;flex-direction:column;gap:2px}.project-name{font-size:14px;font-weight:500}.project-badges{display:flex;gap:6px}.badge{font-size:11px;font-weight:600;padding:1px 8px;border-radius:var(--fb-radius-sm)}.badge--paid{background:#ecfdf5;color:var(--fb-success)}.badge--trial{background:var(--fb-primary-subtle);color:var(--fb-primary)}.badge--expired{background:#fef2f2;color:var(--fb-error)}.badge--inactive{background:var(--fb-bg-secondary);color:var(--fb-text-muted)}.toggle-btn{background:none;border:none;cursor:pointer;padding:4px;flex-shrink:0}.toggle-btn:disabled{opacity:.5;cursor:wait}.toggle-track{width:44px;height:24px;border-radius:12px;background:var(--fb-border);position:relative;transition:background .2s}.toggle-btn--on .toggle-track{background:var(--fb-primary)}.toggle-thumb{width:20px;height:20px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle-btn--on .toggle-thumb{transform:translate(20px)}.setup-guide{background:var(--fb-bg);border-radius:var(--fb-radius-lg);box-shadow:var(--fb-shadow-card);padding:32px;text-align:center;margin-bottom:24px}.setup-icon{color:var(--fb-primary-muted);margin-bottom:16px}.setup-guide h3{font-family:Syne,sans-serif;font-size:18px;margin-bottom:20px}.setup-steps{text-align:left;max-width:480px;margin:0 auto;padding-left:20px}.setup-steps li{margin-bottom:16px;font-size:14px}.setup-steps li strong{display:block;margin-bottom:2px}.setup-steps li p{color:var(--fb-text-muted);font-size:13px;margin:0}.setup-steps a{color:var(--fb-primary);text-decoration:none}.setup-steps a:hover{text-decoration:underline}.role-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--fb-radius-sm);margin-left:8px}.role-badge--account_admin{background:var(--fb-primary-subtle);color:var(--fb-primary)}.role-badge--project_admin{background:#fef3c7;color:#92400e}.role-badge--member{background:var(--fb-bg-secondary);color:var(--fb-text-muted)}.hub-member-notice{display:flex;align-items:center;gap:8px;padding:16px 20px;color:var(--fb-text-muted);font-size:13px}.hub-member-notice svg{flex-shrink:0;color:var(--fb-text-muted)}.register-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--fb-bg-page);padding:24px}.register-card{background:var(--fb-bg);border-radius:var(--fb-radius-xl);padding:40px;box-shadow:var(--fb-shadow-card);max-width:560px;width:100%}.register-title{font-family:Syne,sans-serif;font-size:24px;margin:16px 0 8px}.register-subtitle{font-size:14px;color:var(--fb-text-muted);line-height:1.6;margin-bottom:24px}.register-instructions{background:var(--fb-bg-page);border:1px solid var(--fb-border);border-radius:var(--fb-radius-lg);padding:16px 20px;margin-bottom:24px}.register-instructions h3{font-family:Syne,sans-serif;font-size:14px;margin-bottom:8px}.register-instructions p{font-size:13px;color:var(--fb-text-muted);margin-bottom:8px}.register-instructions ol{padding-left:18px;font-size:13px;color:var(--fb-text)}.register-instructions li{margin-bottom:4px}.register-client-id{display:inline-block;background:var(--fb-bg-secondary);border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);padding:2px 8px;font-family:SF Mono,Fira Code,monospace;font-size:11px;cursor:pointer;-webkit-user-select:all;user-select:all;transition:background .15s}.register-client-id:hover{background:var(--fb-primary-subtle);border-color:var(--fb-primary-light)}.register-hubs{margin-bottom:24px}.register-hubs h3{font-family:Syne,sans-serif;font-size:14px;margin-bottom:12px}.register-hub-list{display:flex;flex-direction:column;gap:8px}.register-hub-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border:1px solid var(--fb-border);border-radius:var(--fb-radius-md);cursor:pointer;transition:all .15s}.register-hub-item:hover{background:var(--fb-bg-page)}.register-hub-item--checked{border-color:var(--fb-primary);background:var(--fb-primary-subtle)}.register-hub-checkbox{accent-color:var(--fb-primary);width:18px;height:18px;flex-shrink:0}.register-hub-info{display:flex;flex-direction:column}.register-hub-name{font-size:14px;font-weight:500}.register-hub-meta{font-size:12px;color:var(--fb-text-muted)}.register-no-hubs{font-size:13px;color:var(--fb-text-muted);text-align:center;padding:20px}.register-btn{width:100%;justify-content:center}.register-btn:disabled{opacity:.5;cursor:not-allowed}.register-error{color:var(--fb-error);font-size:13px;margin-bottom:12px}.register-hint{margin-top:16px;font-size:12px;color:var(--fb-text-muted);text-align:center;line-height:1.6}.admin-login-form{display:flex;flex-direction:column;gap:12px}.admin-login-input{width:100%;padding:10px 14px;font-family:inherit;font-size:14px;border:1px solid var(--fb-border);border-radius:var(--fb-radius-md);outline:none;transition:border-color .15s}.admin-login-input:focus{border-color:var(--fb-primary);box-shadow:0 0 0 3px var(--fb-primary-subtle)}.admin{min-height:100vh;background:var(--fb-bg-page)}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:12px 32px;background:#1f2937;color:#fff}.admin-title{font-family:Syne,sans-serif;font-size:16px;font-weight:700}.admin-header .header-logout{color:#9ca3af}.admin-header .header-logout:hover{color:#fff;background:#374151}.admin-stats{display:flex;gap:16px;padding:20px 32px;flex-wrap:wrap}.admin-stat{background:var(--fb-bg);border-radius:var(--fb-radius-lg);padding:16px 20px;box-shadow:var(--fb-shadow-sm);min-width:100px;text-align:center}.admin-stat-value{display:block;font-size:28px;font-weight:700;font-family:Syne,sans-serif;color:var(--fb-primary)}.admin-stat-label{font-size:12px;color:var(--fb-text-muted);text-transform:uppercase;letter-spacing:.04em}.admin-tabs{display:flex;gap:2px;padding:0 32px;border-bottom:1px solid var(--fb-border)}.admin-tab{padding:10px 20px;font-size:13px;font-weight:500;font-family:inherit;border:none;background:none;color:var(--fb-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.admin-tab--active{color:var(--fb-primary);border-bottom-color:var(--fb-primary)}.admin-section{padding:20px 32px}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--fb-text-muted);padding:8px 12px;border-bottom:1px solid var(--fb-border)}.admin-table td{padding:10px 12px;border-bottom:1px solid var(--fb-border);vertical-align:middle}.admin-table--compact td{padding:6px 10px}.admin-row{cursor:pointer}.admin-row:hover{background:var(--fb-bg-hover)}.admin-cell-name{font-weight:500}.admin-cell-date{color:var(--fb-text-muted);font-size:12px}.admin-empty{text-align:center;color:var(--fb-text-muted);padding:20px;font-size:13px}.adm-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--fb-radius-sm);white-space:nowrap}.adm-badge--trial{background:var(--fb-primary-subtle);color:var(--fb-primary)}.adm-badge--active{background:#ecfdf5;color:var(--fb-success)}.adm-badge--inactive{background:var(--fb-bg-secondary);color:var(--fb-text-muted)}.adm-badge--paid{background:#ecfdf5;color:var(--fb-success)}.adm-badge--expired{background:#fef2f2;color:var(--fb-error)}.adm-badge--neutral{background:var(--fb-bg-secondary);color:var(--fb-text-muted)}.adm-badge--churned{background:#fef2f2;color:var(--fb-error)}.admin-actions{display:flex;gap:6px;flex-wrap:wrap}.adm-btn{font-size:11px;font-family:inherit;padding:4px 10px;border:1px solid var(--fb-border);border-radius:var(--fb-radius-sm);background:var(--fb-bg);cursor:pointer;white-space:nowrap;transition:all .15s}.adm-btn:hover{background:var(--fb-bg-secondary)}.adm-btn--primary{background:var(--fb-primary-subtle);color:var(--fb-primary);border-color:var(--fb-primary-light)}.adm-btn--primary:hover{background:var(--fb-primary-light)}.adm-btn--danger{background:#fef2f2;color:var(--fb-error);border-color:#fecaca}.adm-btn--danger:hover{background:#fee2e2}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.admin-modal{background:var(--fb-bg);border-radius:var(--fb-radius-xl);padding:24px;max-width:900px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:var(--fb-shadow-card)}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.admin-modal-header h2{font-family:Syne,sans-serif;font-size:20px}.admin-modal-close{font-size:24px;background:none;border:none;cursor:pointer;color:var(--fb-text-muted);padding:4px 8px;border-radius:var(--fb-radius-sm)}.admin-modal-close:hover{background:var(--fb-bg-secondary)}.admin-modal-meta{display:flex;gap:12px;align-items:center;margin-bottom:20px;font-size:13px;color:var(--fb-text-muted)}.admin-hub{margin-bottom:20px}.admin-hub h3{font-family:Syne,sans-serif;font-size:15px;margin-bottom:8px}.portfolio-link-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--fb-bg);border:1px solid var(--fb-border);border-radius:var(--fb-radius-md);color:var(--fb-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.portfolio-link-btn:hover{background:#eef2ff;border-color:var(--fb-primary)}.portfolio-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.portfolio-back-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:none;border:1px solid var(--fb-border);border-radius:var(--fb-radius-md);color:var(--fb-text);font-size:13px;cursor:pointer;transition:all .15s ease}.portfolio-back-btn:hover{background:var(--fb-bg-page)}.portfolio-title{font-family:Syne,sans-serif;font-size:20px;font-weight:700;color:var(--fb-text);margin:0}.portfolio-actions{margin-bottom:20px}.portfolio-empty{text-align:center;padding:48px 24px;color:#6b7280;font-size:14px}.portfolio-list{display:flex;flex-direction:column;gap:12px}.portfolio-card{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--fb-bg);border-radius:var(--fb-radius-md);box-shadow:var(--fb-shadow-card)}.portfolio-card-header{display:flex;align-items:baseline;gap:12px}.portfolio-card-name{font-family:Syne,sans-serif;font-size:16px;font-weight:600;color:var(--fb-text);margin:0}.portfolio-card-count{font-size:13px;color:#6b7280}.portfolio-card-actions{display:flex;gap:8px}.portfolio-form{background:var(--fb-bg);border-radius:var(--fb-radius-md);box-shadow:var(--fb-shadow-card);padding:24px}.portfolio-form h3{font-family:Syne,sans-serif;font-size:18px;font-weight:700;margin:0 0 20px}.portfolio-form-label{display:block;font-size:13px;font-weight:500;color:var(--fb-text);margin-bottom:16px}.portfolio-form-input{display:block;width:100%;margin-top:6px;padding:10px 12px;border:1px solid var(--fb-border);border-radius:var(--fb-radius-md);font-size:14px;font-family:DM Sans,sans-serif;color:var(--fb-text);background:var(--fb-bg);box-sizing:border-box}.portfolio-form-input:focus{outline:none;border-color:var(--fb-primary);box-shadow:0 0 0 3px #4f46e51a}.portfolio-form-hint{font-size:13px;color:#9ca3af}.portfolio-form-projects{margin-bottom:20px}.portfolio-project-list{display:flex;flex-direction:column;gap:4px;max-height:320px;overflow-y:auto;border:1px solid var(--fb-border);border-radius:var(--fb-radius-md);padding:8px}.portfolio-project-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:4px;cursor:pointer;font-size:14px;transition:background .1s}.portfolio-project-item:hover{background:var(--fb-bg-page)}.portfolio-project-item input[type=checkbox]{accent-color:var(--fb-primary);width:16px;height:16px;cursor:pointer}.portfolio-project-name{flex:1;color:var(--fb-text)}.portfolio-project-hub{font-size:12px;color:#9ca3af}.portfolio-form-actions{display:flex;gap:8px;justify-content:flex-end}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:var(--fb-radius-md);font-size:14px;font-weight:500;font-family:DM Sans,sans-serif;cursor:pointer;border:none;transition:all .15s ease}.btn--sm{padding:6px 12px;font-size:13px}.btn--primary{background:var(--fb-primary);color:#fff}.btn--primary:hover{background:#4338ca}.btn--primary:disabled{opacity:.5;cursor:not-allowed}.btn--secondary{background:var(--fb-bg);color:var(--fb-text);border:1px solid var(--fb-border)}.btn--secondary:hover{background:var(--fb-bg-page)}.btn--danger{background:var(--fb-bg);color:var(--fb-error);border:1px solid var(--fb-border)}.btn--danger:hover{background:#fef2f2;border-color:var(--fb-error)}@media (max-width: 640px){.header{padding:12px 16px}.header-account{display:none}.dashboard-main{padding:20px 16px}.summary-bar{flex-wrap:wrap;gap:12px}.login-card{padding:32px 24px}}.docs{min-height:100vh;background:var(--fb-bg-page);font-family:DM Sans,system-ui,sans-serif;color:var(--fb-text)}.docs-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 32px;background:var(--fb-bg);border-bottom:1px solid var(--fb-border)}.docs-header-left{display:flex;align-items:center;gap:16px}.docs-logo{flex-shrink:0}.docs-header-title{font-family:Syne,system-ui,sans-serif;font-size:22px;line-height:1;display:flex;align-items:baseline;gap:2px}.docs-header-title .wm-forma{font-weight:400;color:var(--fb-text)}.docs-header-title .wm-bility{font-weight:700;color:var(--fb-primary)}.docs-header-subtitle{margin-left:10px;padding:2px 8px;border-radius:var(--fb-radius-sm);background:var(--fb-primary-subtle);color:var(--fb-primary-dark);font-family:DM Sans,system-ui,sans-serif;font-weight:500;font-size:12px;letter-spacing:.02em}.docs-header-kicker{font-size:12px;color:var(--fb-text-muted);margin-top:4px}.docs-header-right{display:flex;gap:20px}.docs-header-link{color:var(--fb-text-muted);text-decoration:none;font-size:14px;transition:color .15s}.docs-header-link:hover{color:var(--fb-primary)}.docs-tabs{display:flex;gap:4px;padding:0 32px;background:var(--fb-bg);border-bottom:1px solid var(--fb-border)}.docs-tab{padding:14px 18px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--fb-text-muted);font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s}.docs-tab:hover{color:var(--fb-text)}.docs-tab--active{color:var(--fb-primary);border-bottom-color:var(--fb-primary)}.docs-main{max-width:1280px;margin:0 auto;padding:28px 32px 64px}.docs-overview{display:flex;flex-direction:column;gap:28px}.docs-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.docs-stat{background:var(--fb-bg);border-radius:var(--fb-radius-xl);padding:20px;box-shadow:var(--fb-shadow-card);display:flex;flex-direction:column;gap:4px}.docs-stat-value{font-family:Syne,system-ui,sans-serif;font-size:34px;font-weight:700;color:var(--fb-text);line-height:1}.docs-stat-value--sm{font-size:22px;margin-top:6px}.docs-stat-kicker{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--fb-primary);font-weight:600}.docs-stat-label{font-size:14px;color:var(--fb-text);font-weight:500}.docs-stat-sub{font-size:12px;color:var(--fb-text-muted);margin-top:4px}.docs-stat--highlight{background:var(--fb-primary-subtle);border:1px solid var(--fb-primary-light)}.docs-overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.docs-card{background:var(--fb-bg);border-radius:var(--fb-radius-xl);padding:20px;box-shadow:var(--fb-shadow-card);display:flex;flex-direction:column;gap:14px}.docs-card-header{display:flex;justify-content:space-between;align-items:center}.docs-card-header h2{font-family:Syne,system-ui,sans-serif;font-size:17px;font-weight:700}.docs-card-body{color:var(--fb-text-muted);font-size:14px;line-height:1.55}.docs-link-btn{background:transparent;border:none;color:var(--fb-primary);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;padding:2px 0}.docs-link-btn:hover{color:var(--fb-primary-dark)}.docs-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:2px}.docs-list-item{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:none;border-radius:var(--fb-radius-md);font-family:inherit;text-align:left;cursor:pointer;transition:background .12s}.docs-list-item:hover{background:var(--fb-bg-hover)}.docs-list-id{font-family:DM Mono,ui-monospace,monospace;font-size:12px;color:var(--fb-text-muted);min-width:56px;font-weight:500}.docs-list-title{flex:1;font-size:14px;color:var(--fb-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.docs-badge{display:inline-block;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.docs-badge--decided{background:#ecfdf5;color:#065f46}.docs-badge--proposed{background:#fef3c7;color:#92400e}.docs-badge--trial{background:var(--fb-primary-subtle);color:var(--fb-primary-dark)}.docs-badge--superseded{background:var(--fb-bg-secondary);color:var(--fb-text-muted)}.docs-badge--rejected{background:#fee2e2;color:#991b1b}.docs-filter-row{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:20px}.docs-search{position:relative;display:flex;align-items:center;gap:8px;background:var(--fb-bg);border:1px solid var(--fb-border);border-radius:var(--fb-radius-lg);padding:0 12px;min-width:280px;flex:1;max-width:440px}.docs-search:focus-within{border-color:var(--fb-primary);box-shadow:0 0 0 3px var(--fb-primary-subtle)}.docs-search-icon{color:var(--fb-text-muted);flex-shrink:0}.docs-search-input{flex:1;padding:10px 0;border:none;outline:none;background:transparent;font-family:inherit;font-size:14px;color:var(--fb-text)}.docs-search-clear{background:transparent;border:none;color:var(--fb-text-muted);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.docs-chips{display:flex;flex-wrap:wrap;gap:6px}.docs-chip{padding:6px 12px;background:var(--fb-bg);border:1px solid var(--fb-border);border-radius:999px;font-family:inherit;font-size:12px;color:var(--fb-text-muted);cursor:pointer;transition:all .15s}.docs-chip:hover{color:var(--fb-text);border-color:var(--fb-text-muted)}.docs-chip--active{background:var(--fb-primary);border-color:var(--fb-primary);color:#fff}.docs-empty{padding:48px 16px;text-align:center;color:var(--fb-text-muted);font-size:14px}.docs-adr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.docs-adr-card{background:var(--fb-bg);border-radius:var(--fb-radius-xl);padding:20px;box-shadow:var(--fb-shadow-card);border:none;text-align:left;font-family:inherit;cursor:pointer;transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column;gap:10px}.docs-adr-card:hover{transform:translateY(-2px);box-shadow:0 1px 2px #0000000a,0 8px 20px #4f46e51f,0 16px 40px #0000000f}.docs-adr-card-top{display:flex;justify-content:space-between;align-items:center}.docs-adr-id{font-family:DM Mono,ui-monospace,monospace;font-size:12px;color:var(--fb-primary);font-weight:600;letter-spacing:.04em}.docs-adr-title{font-family:Syne,system-ui,sans-serif;font-size:16px;font-weight:700;color:var(--fb-text);line-height:1.35}.docs-adr-summary{font-size:13px;color:var(--fb-text-muted);line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.docs-adr-meta{display:flex;gap:6px;font-size:12px;color:var(--fb-text-muted);margin-top:auto}.docs-module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.docs-module-card{background:var(--fb-bg);border-radius:var(--fb-radius-xl);padding:20px;box-shadow:var(--fb-shadow-card);border:none;text-align:left;font-family:inherit;cursor:pointer;transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column;gap:10px;position:relative}.docs-module-card:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 1px 2px #0000000a,0 8px 20px #4f46e51f,0 16px 40px #0000000f}.docs-module-card:disabled{cursor:not-allowed;opacity:.7}.docs-module-card-top{display:flex;justify-content:space-between;align-items:center}.docs-module-order{font-family:DM Mono,ui-monospace,monospace;font-size:12px;color:var(--fb-primary);font-weight:600}.docs-module-name{font-family:Syne,system-ui,sans-serif;font-size:17px;font-weight:700;color:var(--fb-text)}.docs-module-summary{font-size:13px;color:var(--fb-text-muted);line-height:1.55}.docs-module-missing{margin-top:auto;font-size:11px;color:var(--fb-text-muted);font-style:italic}.docs-arch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.docs-arch-card{background:var(--fb-bg);border-radius:var(--fb-radius-xl);padding:20px;box-shadow:var(--fb-shadow-card);border:none;text-align:left;font-family:inherit;cursor:pointer;transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column;gap:8px}.docs-arch-card:hover{transform:translateY(-2px);box-shadow:0 1px 2px #0000000a,0 8px 20px #4f46e51f,0 16px 40px #0000000f}.docs-arch-number{font-family:DM Mono,ui-monospace,monospace;font-size:11px;color:var(--fb-primary);font-weight:600;letter-spacing:.04em}.docs-arch-title{font-family:Syne,system-ui,sans-serif;font-size:16px;font-weight:700}.docs-arch-summary{font-size:13px;color:var(--fb-text-muted);line-height:1.55}.docs-detail{display:flex;flex-direction:column;gap:20px}.docs-detail-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.docs-back-btn{background:transparent;border:none;color:var(--fb-primary);font-family:inherit;font-size:14px;cursor:pointer;padding:6px 0}.docs-back-btn:hover{color:var(--fb-primary-dark)}.docs-detail-meta{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--fb-text-muted)}.docs-detail-body{background:var(--fb-bg);border-radius:var(--fb-radius-xl);padding:40px 48px;box-shadow:var(--fb-shadow-card);max-width:900px;margin:0 auto;width:100%}.docs-detail-title{font-family:Syne,system-ui,sans-serif;font-size:30px;font-weight:700;margin-bottom:20px;line-height:1.2}.docs-md{font-size:15px;line-height:1.65;color:var(--fb-text)}.docs-md h1,.docs-md h2,.docs-md h3,.docs-md h4{font-family:Syne,system-ui,sans-serif;font-weight:700;line-height:1.3;margin-top:32px;margin-bottom:12px}.docs-md h1{font-size:26px;margin-top:0}.docs-md h2{font-size:21px;padding-top:12px;border-top:1px solid var(--fb-border)}.docs-md h3{font-size:17px}.docs-md h4{font-size:15px}.docs-md p{margin-bottom:14px}.docs-md ul,.docs-md ol{margin-bottom:14px;padding-left:24px}.docs-md li{margin-bottom:4px}.docs-md a{color:var(--fb-primary);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s}.docs-md a:hover{border-bottom-color:var(--fb-primary)}.docs-md code{font-family:DM Mono,ui-monospace,monospace;font-size:.88em;background:var(--fb-bg-secondary);padding:1px 6px;border-radius:var(--fb-radius-sm)}.docs-md pre{background:var(--fb-bg-secondary);padding:16px 20px;border-radius:var(--fb-radius-lg);overflow-x:auto;margin-bottom:14px;font-size:13px}.docs-md pre code{background:transparent;padding:0;font-size:13px;line-height:1.55}.docs-md table{width:100%;border-collapse:collapse;margin-bottom:16px;font-size:13px}.docs-md table th,.docs-md table td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--fb-border);vertical-align:top}.docs-md table th{background:var(--fb-bg-secondary);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.docs-md blockquote{margin:0 0 14px;padding:10px 16px;border-left:3px solid var(--fb-primary);background:var(--fb-primary-subtle);color:var(--fb-text);border-radius:0 var(--fb-radius-md) var(--fb-radius-md) 0;font-size:14px}.docs-md blockquote p:last-child{margin-bottom:0}.docs-md hr{border:none;border-top:1px solid var(--fb-border);margin:28px 0}.docs-mermaid{background:var(--fb-bg);border:1px solid var(--fb-border);border-radius:var(--fb-radius-lg);padding:20px;margin-bottom:16px;overflow-x:auto;text-align:center}.docs-mermaid svg{max-width:100%;height:auto}.docs-mermaid-error{background:#fee2e2;color:#991b1b;padding:14px;border-radius:var(--fb-radius-md);font-size:13px;margin-bottom:16px}.docs-mermaid-error pre{margin-top:8px;background:#fff;color:var(--fb-text);font-size:11px;padding:10px;border-radius:var(--fb-radius-sm)}.docs-roadmap{display:flex;flex-direction:column;gap:40px}.docs-roadmap-section{background:var(--fb-bg);border-radius:var(--fb-radius-xl);padding:28px;box-shadow:var(--fb-shadow-card)}.docs-roadmap-section h2{font-family:Syne,system-ui,sans-serif;font-size:20px;font-weight:700;margin-bottom:6px}.docs-roadmap-kicker{color:var(--fb-text-muted);font-size:14px;margin-bottom:20px}.docs-roadmap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:8px}.docs-roadmap-header h2{margin-bottom:0}.docs-roadmap-chain{list-style:none;padding:0;display:flex;flex-wrap:wrap;align-items:center;gap:8px}.docs-roadmap-chain-item{display:flex;align-items:center;gap:8px}.docs-roadmap-module{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--fb-bg-secondary);border:1px solid var(--fb-border);border-radius:var(--fb-radius-lg);font-family:inherit;cursor:pointer;transition:all .15s}.docs-roadmap-module:not(:disabled):hover{background:var(--fb-primary-subtle);border-color:var(--fb-primary)}.docs-roadmap-module:disabled{cursor:default;opacity:.7}.docs-roadmap-order{font-family:DM Mono,ui-monospace,monospace;font-size:11px;color:var(--fb-primary);font-weight:600}.docs-roadmap-name{font-size:13px;font-weight:500;color:var(--fb-text)}.docs-roadmap-arrow{color:var(--fb-text-muted);font-size:14px}.docs-roadmap-timeline{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.docs-roadmap-phase{background:var(--fb-bg-page);border-radius:var(--fb-radius-lg);padding:18px;border-left:3px solid var(--fb-primary)}.docs-roadmap-phase-head{margin-bottom:12px}.docs-roadmap-phase-label{display:block;font-family:DM Mono,ui-monospace,monospace;font-size:11px;color:var(--fb-primary);font-weight:600;letter-spacing:.04em}.docs-roadmap-phase-title{font-family:Syne,system-ui,sans-serif;font-size:15px;font-weight:700;margin-top:4px}.docs-roadmap-phase-items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.docs-roadmap-phase-items li{font-size:13px;color:var(--fb-text);padding-left:16px;position:relative;line-height:1.5}.docs-roadmap-phase-items li:before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%;background:var(--fb-primary)}.docs-roadmap-timeline-vert{display:flex;flex-direction:column;position:relative}.docs-roadmap-timeline-vert:before{content:"";position:absolute;left:90px;top:14px;bottom:14px;width:2px;background:var(--fb-border)}.docs-roadmap-adr{display:grid;grid-template-columns:96px auto 1fr;align-items:center;gap:16px;padding:10px 12px;background:transparent;border:none;font-family:inherit;text-align:left;cursor:pointer;border-radius:var(--fb-radius-md);transition:background .15s}.docs-roadmap-adr:hover{background:var(--fb-bg-hover)}.docs-roadmap-adr-date{font-family:DM Mono,ui-monospace,monospace;font-size:12px;color:var(--fb-text-muted)}.docs-roadmap-adr-dot{width:12px;height:12px;border-radius:50%;background:var(--fb-primary);border:3px solid var(--fb-bg);box-shadow:0 0 0 2px var(--fb-primary);justify-self:center}.docs-roadmap-adr-body{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.docs-roadmap-adr-body strong{font-family:DM Mono,ui-monospace,monospace;font-size:12px;color:var(--fb-primary);font-weight:600}.docs-roadmap-adr-body>span:nth-child(2){font-size:14px;color:var(--fb-text)}@media (max-width: 720px){.docs-header{flex-direction:column;align-items:flex-start}.docs-main{padding:20px 16px 48px}.docs-tabs{padding:0 16px;overflow-x:auto}.docs-detail-body{padding:28px 20px}.docs-roadmap-section{padding:20px}.docs-roadmap-timeline-vert:before{left:76px}.docs-roadmap-adr{grid-template-columns:80px auto 1fr;gap:12px}}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
  Theme: GitHub
  Description: Light theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-light
  Current colors taken from GitHub's CSS
*/.hljs{color:#24292e;background:#fff}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#d73a49}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#6f42c1}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#005cc5}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#032f62}.hljs-built_in,.hljs-symbol{color:#e36209}.hljs-comment,.hljs-code,.hljs-formula{color:#6a737d}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#22863a}.hljs-subst{color:#24292e}.hljs-section{color:#005cc5;font-weight:700}.hljs-bullet{color:#735c0f}.hljs-emphasis{color:#24292e;font-style:italic}.hljs-strong{color:#24292e;font-weight:700}.hljs-addition{color:#22863a;background-color:#f0fff4}.hljs-deletion{color:#b31d28;background-color:#ffeef0}
