@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{color-scheme:light dark}:root,html[data-theme=dark]{--color-bg: #08080e;--color-bg-rgb: 8, 8, 14;--color-surface: #0f0f18;--color-surface-2: #161622;--color-surface-hover: #1c1c2e;--color-border: #1e1e30;--color-border-subtle: #14141f;--color-accent: #4f8ef7;--color-accent-dim: #3a6fd4;--color-accent-glow: rgba(79, 142, 247, .15);--color-accent-glow-2: rgba(79, 142, 247, .06);--color-success: #34d399;--color-success-dim: rgba(52, 211, 153, .12);--color-warning: #f59e0b;--color-warning-dim: rgba(245, 158, 11, .12);--color-danger: #f87171;--color-danger-dim: rgba(248, 113, 113, .12);--color-text-primary: #e8e8f0;--color-text-secondary: #8888a8;--color-text-tertiary: #55556a;--color-text-accent: #4f8ef7;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .6);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .7);--shadow-accent: 0 0 20px rgba(79, 142, 247, .2);--color-topbar-bg: rgba(8, 8, 14, .85);--color-overlay-bg: rgba(8, 8, 14, .85)}html[data-theme=light]{--color-bg: #f6f8fa;--color-bg-rgb: 246, 248, 250;--color-surface: #ffffff;--color-surface-2: #edf1f5;--color-surface-hover: #e4eaf0;--color-border: #d1d9e2;--color-border-subtle: #e9eef3;--color-accent: #2563eb;--color-accent-dim: #1d4ed8;--color-accent-glow: rgba(37, 99, 235, .08);--color-accent-glow-2: rgba(37, 99, 235, .03);--color-success: #059669;--color-success-dim: rgba(5, 150, 105, .08);--color-warning: #d97706;--color-warning-dim: rgba(217, 119, 6, .08);--color-danger: #dc2626;--color-danger-dim: rgba(220, 38, 38, .08);--color-text-primary: #0f172a;--color-text-secondary: #475569;--color-text-tertiary: #64748b;--color-text-accent: #2563eb;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 12px rgba(15, 23, 42, .05);--shadow-lg: 0 10px 25px -5px rgba(15, 23, 42, .08), 0 8px 16px -6px rgba(15, 23, 42, .08);--shadow-xl: 0 20px 32px -12px rgba(15, 23, 42, .12), 0 16px 20px -10px rgba(15, 23, 42, .1);--shadow-accent: 0 0 16px rgba(37, 99, 235, .12);--color-topbar-bg: rgba(255, 255, 255, .85);--color-overlay-bg: rgba(246, 248, 250, .85)}:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--text-xs: .6875rem;--text-sm: .8125rem;--text-base: .9375rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.375rem;--text-2xl: 1.75rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-loose: 1.75;--letter-spacing-tight: -.02em;--letter-spacing-wide: .04em;--letter-spacing-wider: .08em;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--topbar-height: 64px;--content-max-width: 900px;--modal-width: 480px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg);min-height:100vh;overflow-x:hidden}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-text-primary)}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none}input,textarea,select{font-family:inherit;outline:none}ul,ol{list-style:none}img,svg,canvas{display:block;max-width:100%}p{line-height:var(--line-height-loose)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-surface)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}::selection{background:var(--color-accent-glow);color:var(--color-text-primary)}body,.topbar,.main-content,.provider-picker,.provider-card,.file-table,.notes-grid,.modal-content,.btn,.status-indicator,.input-group input,.input-group textarea,.provider-badge,.tab-btn{transition:background-color var(--transition-normal),color var(--transition-normal),border-color var(--transition-normal),box-shadow var(--transition-normal),background var(--transition-normal)}#app{display:flex;flex-direction:column;min-height:100vh}.topbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--topbar-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);background:var(--color-topbar-bg);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-bottom:1px solid var(--color-border)}.topbar__brand{display:flex;align-items:center;gap:var(--space-3)}.topbar__logo{width:28px;height:28px;color:var(--color-accent);flex-shrink:0}.topbar__name{font-size:var(--text-md);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary)}.topbar__name span{color:var(--color-accent)}.topbar__right{display:flex;align-items:center;gap:var(--space-4)}.status-indicator{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.status-dot{width:7px;height:7px;border-radius:var(--radius-full);background:var(--color-text-tertiary);transition:background var(--transition-normal);flex-shrink:0}.status-dot--connected{background:var(--color-success);box-shadow:0 0 8px #34d39980;animation:pulse-dot 2.5s ease-in-out infinite}.main-content{margin-top:var(--topbar-height);flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-10) var(--space-6)}.content-wrapper{width:100%;max-width:var(--content-max-width)}.view-panel{display:none;animation:fadeInUp .3s ease-out forwards}.view-panel--active{display:block}.section-header{margin-bottom:var(--space-6)}.section-header h2{font-size:var(--text-xl);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary);margin-bottom:var(--space-1)}.section-header p{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.auth-gate{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - var(--topbar-height) - 80px);text-align:center;gap:var(--space-6);animation:fadeInUp .4s ease-out forwards}.auth-gate__icon{width:64px;height:64px;color:var(--color-accent);opacity:.7}.auth-gate__title{font-size:var(--text-2xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary);max-width:380px}.auth-gate__description{font-size:var(--text-base);color:var(--color-text-secondary);max-width:420px;line-height:var(--line-height-loose)}.auth-gate__features{display:flex;gap:var(--space-8);margin-top:var(--space-2)}.auth-feature{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-tertiary)}.auth-feature svg{width:20px;height:20px;color:var(--color-accent)}.warning-banner{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-warning-dim);border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-lg);margin-bottom:var(--space-6);font-size:var(--text-sm);color:var(--color-warning);line-height:var(--line-height-loose)}.warning-banner svg{width:16px;height:16px;flex-shrink:0;margin-top:2px}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);background:var(--color-overlay-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity var(--transition-normal)}.loading-overlay--active{opacity:1;pointer-events:all}.loading-overlay__text{font-size:var(--text-sm);color:var(--color-text-secondary);letter-spacing:var(--letter-spacing-wide)}@media (max-width: 640px){.topbar{padding:0 var(--space-4)}.topbar__name{font-size:var(--text-sm)}.main-content{padding:var(--space-6) var(--space-4)}.auth-gate__features{flex-direction:column;gap:var(--space-4)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-weight-medium);line-height:1;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;text-decoration:none;height:36px}.btn svg{width:14px;height:14px;flex-shrink:0}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn--primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.btn--primary:hover{background:var(--color-accent-dim);border-color:var(--color-accent-dim);box-shadow:var(--shadow-accent);transform:translateY(-1px)}.btn--primary:active{transform:translateY(0);box-shadow:none}.btn--ghost{background:transparent;color:var(--color-text-secondary);border-color:var(--color-border)}.btn--ghost:hover{background:var(--color-surface-hover);color:var(--color-text-primary);border-color:var(--color-text-tertiary)}.btn--danger{background:var(--color-danger-dim);color:var(--color-danger);border-color:var(--color-danger-dim)}.btn--danger:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn--icon{padding:0;width:36px;height:36px;border-radius:var(--radius-md)}.btn--icon svg{width:16px;height:16px}.btn--lg{height:44px;padding:var(--space-3) var(--space-6);font-size:var(--text-base);border-radius:var(--radius-lg)}.btn--lg svg{width:18px;height:18px}.tab-control{display:flex;gap:var(--space-1);padding:var(--space-1);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-8);width:fit-content}.tab-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer;border:none;background:none;height:36px}.tab-btn svg{width:14px;height:14px}.tab-btn:hover{color:var(--color-text-primary);background:var(--color-surface-hover)}.tab-btn--active{background:var(--color-surface-2);color:var(--color-text-primary);border:1px solid var(--color-border)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;font-size:var(--text-xs)}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-base);color:var(--color-text-primary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);height:44px;font-family:var(--font-sans)}.form-input::placeholder{color:var(--color-text-tertiary)}.form-input:hover{border-color:var(--color-text-tertiary)}.form-input:focus{border-color:var(--color-accent);background:var(--color-surface-2);box-shadow:0 0 0 3px var(--color-accent-glow-2)}.form-input--mono{font-family:var(--font-mono);font-size:var(--text-sm);letter-spacing:.05em}.form-input--error{border-color:var(--color-danger)!important;box-shadow:0 0 0 3px var(--color-danger-dim)!important}.form-error{font-size:var(--text-sm);color:var(--color-danger);display:flex;align-items:center;gap:var(--space-2)}.form-error svg{width:14px;height:14px;flex-shrink:0}.form-hint{font-size:var(--text-xs);color:var(--color-text-tertiary);line-height:var(--line-height-loose)}.input-wrapper{position:relative}.input-wrapper .form-input{padding-right:44px}.input-toggle-btn{position:absolute;right:0;top:0;height:100%;width:44px;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);cursor:pointer;border:none;background:none;transition:color var(--transition-fast)}.input-toggle-btn:hover{color:var(--color-text-secondary)}.input-toggle-btn svg{width:16px;height:16px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:var(--space-6);opacity:0;pointer-events:none;transition:opacity var(--transition-normal)}.modal-backdrop--active{opacity:1;pointer-events:all}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:var(--modal-width);box-shadow:var(--shadow-xl);transform:translateY(16px) scale(.98);transition:transform var(--transition-normal);overflow:hidden}.modal-backdrop--active .modal{transform:translateY(0) scale(1)}.modal__header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border-subtle)}.modal__title{font-size:var(--text-lg);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary)}.modal__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1);line-height:var(--line-height-normal)}.modal__close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-tertiary);cursor:pointer;border:none;background:none;transition:all var(--transition-fast);flex-shrink:0}.modal__close:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.modal__close svg{width:16px;height:16px}.modal__body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}.modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-subtle)}.method-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.method-card{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);padding:var(--space-4);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.method-card:hover{border-color:var(--color-text-tertiary);background:var(--color-surface-hover)}.method-card--selected{border-color:var(--color-accent)!important;background:var(--color-accent-glow-2);box-shadow:0 0 0 1px var(--color-accent-glow)}.method-card__icon{width:32px;height:32px;border-radius:var(--radius-md);background:var(--color-accent-glow);display:flex;align-items:center;justify-content:center;color:var(--color-accent)}.method-card__icon svg{width:16px;height:16px}.method-card__title{font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.method-card__desc{font-size:var(--text-xs);color:var(--color-text-tertiary);line-height:var(--line-height-normal)}.data-table-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.data-table thead{background:var(--color-surface)}.data-table th{padding:var(--space-3) var(--space-5);text-align:left;font-size:var(--text-xs);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase;border-bottom:1px solid var(--color-border);white-space:nowrap}.data-table tbody tr{background:var(--color-surface-2);border-bottom:1px solid var(--color-border-subtle);transition:background var(--transition-fast)}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:var(--color-surface-hover)}.data-table td{padding:var(--space-4) var(--space-5);color:var(--color-text-primary);vertical-align:middle}.data-table td:last-child{width:80px}.file-icon-cell{display:flex;align-items:center;gap:var(--space-3);min-width:0}.file-icon-cell svg{width:16px;height:16px;color:var(--color-accent);flex-shrink:0}.file-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--text-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);white-space:nowrap}.badge svg{width:11px;height:11px}.badge--accent{background:var(--color-accent-glow);color:var(--color-accent);border:1px solid rgba(79,142,247,.2)}.badge--success{background:var(--color-success-dim);color:var(--color-success);border:1px solid rgba(52,211,153,.2)}.badge--warning{background:var(--color-warning-dim);color:var(--color-warning);border:1px solid rgba(245,158,11,.2)}.spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:var(--radius-full);animation:spin .7s linear infinite;flex-shrink:0}.spinner--sm{width:16px;height:16px;border-width:1.5px}.spinner--lg{width:36px;height:36px;border-width:3px}.divider{display:flex;align-items:center;gap:var(--space-3);color:var(--color-text-tertiary);font-size:var(--text-xs);letter-spacing:var(--letter-spacing-wide)}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.copy-block{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md)}.copy-block__text{flex:1;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-accent);word-break:break-all;letter-spacing:.05em;line-height:var(--line-height-loose)}.copy-block__btn{flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);text-align:center;gap:var(--space-4)}.empty-state svg{width:40px;height:40px;color:var(--color-text-tertiary);opacity:.5}.empty-state__title{font-size:var(--text-base);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.empty-state__desc{font-size:var(--text-sm);color:var(--color-text-tertiary);max-width:320px}.qr-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.qr-container canvas{border-radius:var(--radius-md)}.qr-container__label{font-size:var(--text-sm);color:var(--color-text-secondary);text-align:center;line-height:var(--line-height-normal)}.info-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--color-accent-glow-2);border:1px solid rgba(79,142,247,.15);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--line-height-loose)}.info-card svg{width:15px;height:15px;color:var(--color-accent);flex-shrink:0;margin-top:2px}.danger-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--color-danger-dim);border:1px solid rgba(248,113,113,.2);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--color-danger);line-height:var(--line-height-loose)}.danger-card svg{width:15px;height:15px;flex-shrink:0;margin-top:2px}:root{--color-note: #a78bfa;--color-note-dim: rgba(167, 139, 250, .12)}.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4);padding-bottom:var(--space-6)}.note-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);display:flex;flex-direction:column;position:relative}.note-card:hover{border-color:var(--color-note);box-shadow:0 0 0 1px var(--color-note-dim),var(--shadow-md);transform:translateY(-2px)}.note-card__body{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5);cursor:pointer;flex:1;outline:none}.note-card__body:focus-visible{box-shadow:inset 0 0 0 2px var(--color-accent);border-radius:var(--radius-lg)}.note-card__icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--color-note-dim);display:flex;align-items:center;justify-content:center;color:var(--color-note)}.note-card__icon svg{width:16px;height:16px}.note-card__name{font-size:var(--text-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:var(--letter-spacing-tight)}.note-card__meta{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.note-card__hint{font-size:var(--text-xs);color:var(--color-text-tertiary);opacity:0;transition:opacity var(--transition-fast)}.note-card:hover .note-card__hint{opacity:1}.note-card__actions{display:flex;justify-content:flex-end;padding:var(--space-2) var(--space-3);border-top:1px solid var(--color-border-subtle)}.note-card__del{opacity:0;transition:opacity var(--transition-fast)}.note-card:hover .note-card__del{opacity:1}.note-editor-backdrop{align-items:stretch;padding:var(--space-4)}.note-editor-modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;width:100%;max-width:860px;height:calc(100vh - var(--space-8));max-height:90vh;margin:auto;overflow:hidden;transform:translateY(16px) scale(.98);transition:transform var(--transition-normal)}.modal-backdrop--active .note-editor-modal{transform:translateY(0) scale(1)}.note-editor-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.note-editor-title{font-size:var(--text-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:var(--letter-spacing-tight)}.note-editor-body{flex:1;display:flex;overflow:hidden}.note-editor-textarea{flex:1;padding:var(--space-6);font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--line-height-loose);color:var(--color-text-primary);background:var(--color-surface-2);border:none;outline:none;resize:none;overflow-y:auto}.note-editor-textarea::placeholder{color:var(--color-text-tertiary)}.note-editor-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-6);border-top:1px solid var(--color-border-subtle);flex-shrink:0;background:var(--color-surface)}.preview-backdrop{align-items:stretch;padding:var(--space-4);background:#000000d9}.preview-modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;width:100%;max-width:1100px;height:calc(100vh - var(--space-8));max-height:92vh;margin:auto;overflow:hidden;transform:translateY(16px) scale(.98);transition:transform var(--transition-normal)}.modal-backdrop--active .preview-modal{transform:translateY(0) scale(1)}.preview-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0;gap:var(--space-3)}.preview-modal__filename{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-modal__body{flex:1;overflow:auto;display:flex;background:var(--color-bg);position:relative}.preview-text{flex:1;padding:var(--space-6);font-family:var(--font-mono);font-size:var(--text-sm);line-height:var(--line-height-loose);color:var(--color-text-primary);white-space:pre-wrap;word-break:break-word;margin:0;overflow:auto;width:100%}.preview-image-wrap{display:flex;align-items:center;justify-content:center;flex:1;padding:var(--space-6);min-height:0}.preview-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}.preview-iframe{width:100%;height:100%;border:none;flex:1}.preview-video{max-width:100%;max-height:100%;margin:auto;display:block;border-radius:var(--radius-md)}.preview-audio-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-6);flex:1;padding:var(--space-8)}.preview-audio{width:100%;max-width:480px}.preview-unsupported{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);flex:1;padding:var(--space-8);color:var(--color-text-tertiary);text-align:center}.totp-save-offer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-success-dim);border-top:1px solid rgba(52,211,153,.2);flex-wrap:wrap}.provider-picker{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-8) var(--space-6);background:var(--color-bg);animation:providerFadeIn .4s var(--ease-out) both}.provider-picker__inner{width:100%;max-width:760px;display:flex;flex-direction:column;gap:var(--space-10)}.provider-picker__hero{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4)}.provider-picker__shield{width:56px;height:56px;color:var(--color-accent);filter:drop-shadow(0 0 18px var(--color-accent-glow));animation:pickerShieldPulse 3s ease-in-out infinite}.provider-picker__title{font-size:clamp(1.5rem,4vw,1.875rem);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary);line-height:1.2}.provider-picker__subtitle{font-size:var(--text-base);color:var(--color-text-secondary);max-width:480px;line-height:var(--line-height-loose)}.provider-picker__subtitle strong{color:var(--color-accent)}.provider-picker__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-4)}.provider-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-6);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);position:relative;overflow:hidden;outline:none}.provider-card:hover{border-color:var(--color-accent);background:var(--color-surface-hover);box-shadow:0 0 0 1px var(--color-accent-glow),var(--shadow-lg);transform:translateY(-2px)}.provider-card:focus-visible{box-shadow:0 0 0 3px var(--color-accent-glow-2)}.provider-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(79,142,247,.04) 0%,transparent 60%);opacity:0;transition:opacity var(--transition-fast);pointer-events:none}.provider-card:hover:before{opacity:1}.provider-card--selecting{transform:scale(.97);border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow-2)}.provider-card--disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.provider-card--needs-setup{border-color:#f59e0b40}.provider-card--needs-setup:hover{border-color:var(--color-warning);box-shadow:0 0 0 1px var(--color-warning-dim),var(--shadow-lg)}.provider-card__icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary)}.provider-card__icon svg{width:24px;height:24px}.provider-card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.provider-card__name-row{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.provider-card__name{font-size:var(--text-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.provider-card__desc{font-size:var(--text-sm);color:var(--color-text-tertiary);line-height:var(--line-height-normal)}.provider-card__arrow{flex-shrink:0;color:var(--color-text-tertiary);transition:color var(--transition-fast),transform var(--transition-fast)}.provider-card__arrow svg{width:16px;height:16px}.provider-card:hover .provider-card__arrow{color:var(--color-accent);transform:translate(3px)}.provider-card__badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:10px;font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;border-radius:var(--radius-sm);white-space:nowrap}.provider-card__badge--soon{background:var(--color-surface-2);color:var(--color-text-tertiary);border:1px solid var(--color-border)}.provider-card__badge--setup{background:#f59e0b1f;color:#f59e0b;border:1px solid rgba(245,158,11,.25)}.provider-picker__footer{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-tertiary);text-align:center;justify-content:center;line-height:var(--line-height-loose)}.provider-picker__footer svg{width:14px;height:14px;flex-shrink:0;color:var(--color-accent)}.provider-badge{display:inline-flex;align-items:center;gap:4px;height:22px;padding:0 8px;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--color-text-secondary);opacity:0;max-width:0;overflow:hidden;transition:opacity var(--transition-fast),max-width .3s ease,transform var(--transition-fast);transform:translateY(2px);pointer-events:none}.provider-badge--visible{opacity:1;max-width:150px;transform:translateY(0)}.provider-badge__icon{display:flex;align-items:center;flex-shrink:0}.provider-badge__icon svg{width:12px;height:12px}.provider-badge__label{white-space:nowrap;font-weight:var(--font-weight-medium)}.btn--icon-only{padding:0;width:32px;height:32px}.btn--icon-only svg{width:14px;height:14px}@keyframes pickerShieldPulse{0%,to{filter:drop-shadow(0 0 12px rgba(79,142,247,.5))}50%{filter:drop-shadow(0 0 28px rgba(79,142,247,.9))}}@keyframes providerFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.switch-toggle-container{display:flex;align-items:center;gap:var(--space-2);margin-right:var(--space-2)}.switch-toggle{position:relative;display:inline-block;width:32px;height:18px;cursor:pointer}.switch-toggle input{opacity:0;width:0;height:0}.switch-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-danger);transition:background-color var(--transition-fast);border-radius:var(--radius-full)}.switch-slider:before{position:absolute;content:"";height:14px;width:14px;left:2px;bottom:2px;background-color:#fff;transition:transform var(--transition-fast);border-radius:var(--radius-full);box-shadow:0 1px 3px #0003}.switch-toggle input:checked+.switch-slider{background-color:var(--color-success)}.switch-toggle input:checked+.switch-slider:before{transform:translate(14px)}.about-modal{max-width:700px!important}.about-modal__header-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-accent-glow);display:flex;align-items:center;justify-content:center;color:var(--color-accent);flex-shrink:0}.about-modal__header-icon svg{width:20px;height:20px}.about-modal__body{padding:var(--space-6)!important}.about-modal__content{max-height:55vh;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-6);padding-right:var(--space-2);scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.about-modal__content::-webkit-scrollbar{width:6px}.about-modal__content::-webkit-scrollbar-track{background:transparent}.about-modal__content::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:var(--radius-full)}.about-card{padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-surface-2)}.intro-card{background:linear-gradient(135deg,var(--color-surface-2),var(--color-accent-glow-2));border-color:#4f8ef733}.intro-card h3,.security-details h3,.contact-section h3{font-size:var(--text-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.intro-card p,.contact-section p{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--line-height-loose);margin:0}.flow-visualizer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-4) var(--space-2);background:var(--color-surface-hover);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.flow-node{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);text-align:center;padding:var(--space-2)}.flow-node svg{width:24px;height:24px;color:var(--color-text-secondary)}.flow-node span{font-size:var(--text-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);white-space:nowrap}.flow-node--accent svg{color:var(--color-accent);filter:drop-shadow(0 0 6px var(--color-accent-glow))}.flow-node--accent span{color:var(--color-accent)}.flow-arrow{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--color-text-tertiary);flex-shrink:0}.flow-arrow svg{width:16px;height:16px;margin-top:2px}.flow-arrow__label{font-size:var(--text-xs);font-weight:var(--font-weight-normal);color:var(--color-text-tertiary);transform:scale(.85)}.detail-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4);margin-top:var(--space-3)}.detail-item{border-left:2px solid var(--color-accent);padding-left:var(--space-4)}.detail-item__title{font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.detail-item__body{font-size:var(--text-xs);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.about-modal__danger{padding:var(--space-4) var(--space-5)!important;border-radius:var(--radius-lg)!important}.contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-top:var(--space-3)}.contact-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition-fast);cursor:pointer}.contact-card:hover{border-color:var(--color-accent);background:var(--color-surface-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.contact-card__icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--color-accent-glow);display:flex;align-items:center;justify-content:center;color:var(--color-accent);flex-shrink:0}.contact-card__icon svg{width:16px;height:16px}.contact-card__label{display:block;font-size:var(--text-xs);color:var(--color-text-tertiary);margin-bottom:2px}.contact-card__email{display:block;font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);word-break:break-all}@media (max-width: 640px){.about-btn-text{display:none}.flow-visualizer{flex-direction:column;gap:var(--space-4);padding:var(--space-5) var(--space-4)}.flow-arrow{transform:rotate(90deg);margin:var(--space-1) 0}.flow-arrow__label{transform:translateY(-2px)}.contact-cards{grid-template-columns:1fr;gap:var(--space-3)}}.dropzone{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);min-height:280px;padding:var(--space-10) var(--space-8);background:var(--color-surface);border:1.5px dashed var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-normal);text-align:center;overflow:hidden}.dropzone:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:300px;height:300px;background:radial-gradient(circle,var(--color-accent-glow-2) 0%,transparent 70%);pointer-events:none;transition:opacity var(--transition-slow)}.dropzone:hover{border-color:var(--color-text-tertiary);background:var(--color-surface-2)}.dropzone:hover:before{background:radial-gradient(circle,var(--color-accent-glow) 0%,transparent 70%)}.dropzone--active{border-color:var(--color-accent)!important;background:var(--color-surface-2)!important;box-shadow:0 0 0 4px var(--color-accent-glow-2),var(--shadow-accent)}.dropzone--active:before{background:radial-gradient(circle,rgba(79,142,247,.2) 0%,transparent 70%)}.dropzone--active .dropzone__icon{color:var(--color-accent);transform:scale(1.1) translateY(-4px)}.dropzone--staged{border-color:var(--color-success);border-style:solid}.dropzone__icon{width:48px;height:48px;color:var(--color-text-tertiary);transition:all var(--transition-normal)}.dropzone__title{font-size:var(--text-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight)}.dropzone__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary)}.dropzone__hint{font-size:var(--text-xs);color:var(--color-text-tertiary);letter-spacing:var(--letter-spacing-wide);margin-top:var(--space-2)}.dropzone__browse{color:var(--color-accent);cursor:pointer;transition:color var(--transition-fast)}.dropzone__browse:hover{color:#fff}.staged-files{width:100%;display:flex;flex-direction:column;gap:var(--space-2);max-height:200px;overflow-y:auto;margin-top:var(--space-2)}.staged-file{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm)}.staged-file svg{width:14px;height:14px;color:var(--color-success);flex-shrink:0}.staged-file__name{flex:1;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.staged-file__size{color:var(--color-text-tertiary);flex-shrink:0}.staged-file__remove{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast);border:none;background:none;flex-shrink:0}.staged-file__remove:hover{color:var(--color-danger);background:var(--color-danger-dim)}.staged-file__remove svg{width:12px;height:12px;color:inherit}#file-input{display:none}.upload-progress{width:100%;display:flex;flex-direction:column;gap:var(--space-2)}.upload-progress__bar-track{width:100%;height:3px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.upload-progress__bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-full);transition:width .3s ease;box-shadow:0 0 8px #4f8ef799}.upload-progress__text{font-size:var(--text-xs);color:var(--color-text-secondary);text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(16px)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 8px #34d39980}50%{opacity:.7;box-shadow:0 0 16px #34d399cc}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.skeleton{background:linear-gradient(90deg,var(--color-surface) 25%,var(--color-surface-hover) 50%,var(--color-surface) 75%);background-size:200% 100%;animation:shimmer 1.6s infinite;border-radius:var(--radius-md)}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:9000;display:flex;flex-direction:column;gap:var(--space-3);pointer-events:none}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);min-width:280px;max-width:380px;pointer-events:all;animation:slideInRight .25s ease-out forwards}.toast--leaving{animation:slideOutRight .25s ease-in forwards}.toast__icon{width:18px;height:18px;flex-shrink:0;margin-top:1px}.toast__body{flex:1;min-width:0}.toast__title{font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-tight);margin-bottom:2px}.toast__message{font-size:var(--text-xs);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.toast--success{border-left:3px solid var(--color-success)}.toast--success .toast__icon{color:var(--color-success)}.toast--error{border-left:3px solid var(--color-danger)}.toast--error .toast__icon{color:var(--color-danger)}.toast--info{border-left:3px solid var(--color-accent)}.toast--info .toast__icon{color:var(--color-accent)}.toast--warning{border-left:3px solid var(--color-warning)}.toast--warning .toast__icon{color:var(--color-warning)}.animate-fade-in{animation:fadeIn .3s ease-out forwards}.animate-fade-in-up{animation:fadeInUp .35s ease-out forwards}.animate-scale-in{animation:scaleIn .2s ease-out forwards}.stagger-children>*{opacity:0;animation:fadeInUp .3s ease-out forwards}.stagger-children>*:nth-child(1){animation-delay:0ms}.stagger-children>*:nth-child(2){animation-delay:60ms}.stagger-children>*:nth-child(3){animation-delay:.12s}.stagger-children>*:nth-child(4){animation-delay:.18s}.stagger-children>*:nth-child(5){animation-delay:.24s}
