@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Space+Grotesk:wght@500;600;700&display=swap";:root{--s2f-ink: #0A0A0A;--s2f-paper: #FAFAF7;--s2f-muted: #6B6B66;--s2f-teal-50: #E6F2F0;--s2f-teal-100: #CCE5E1;--s2f-teal-300: #66B3A8;--s2f-teal-500: #0F8F80;--s2f-teal-700: #006B5F;--s2f-teal-900: #003F37;--s2f-fg-1: var(--s2f-ink);--s2f-fg-2: var(--s2f-muted);--s2f-fg-3: rgba(10, 10, 10, .3);--s2f-bg-1: var(--s2f-paper);--s2f-bg-2: rgba(230, 242, 240, .4);--s2f-accent: var(--s2f-teal-700);--s2f-accent-hover-on-ink: var(--s2f-teal-900);--s2f-rule: rgba(10, 10, 10, .1);--s2f-selection-bg: rgba(0, 107, 95, .2);--s2f-font-sans: "Inter", system-ui, -apple-system, sans-serif;--s2f-font-display: "Space Grotesk", "Inter", system-ui, sans-serif;--s2f-t-display-xl: 72px;--s2f-t-display-lg: 60px;--s2f-t-display-md: 48px;--s2f-t-display-sm: 36px;--s2f-t-h3: 24px;--s2f-t-body-lg: 20px;--s2f-t-body: 18px;--s2f-t-body-sm: 16px;--s2f-t-small: 14px;--s2f-t-eyebrow: 14px;--s2f-t-fineprint: 11px;--s2f-w-regular: 400;--s2f-w-medium: 500;--s2f-w-semibold: 600;--s2f-w-bold: 700;--s2f-lh-tight: 1.02;--s2f-lh-snug: 1.1;--s2f-lh-normal: 1.35;--s2f-lh-body: 1.55;--s2f-tr-eyebrow: .18em;--s2f-tr-tight: -.01em;--s2f-container-max: 1024px;--s2f-container-pad: 24px;--s2f-container-pad-md: 40px;--s2f-radius-sm: 2px;--s2f-radius-md: 8px;--s2f-radius-lg: 28px;--s2f-radius-pill: 9999px;--s2f-shadow-bubble: 4px 4px 0 0 rgba(10, 10, 10, .08);--s2f-shadow-bubble-hover: 6px 6px 0 0 rgba(0, 107, 95, .18);--s2f-ease: cubic-bezier(.4, 0, .2, 1);--s2f-dur-fast: .15s;--s2f-dur: .18s;--s2f-dur-slow: .5s;--s2f-accent-on-dark: #66B3A8;--s2f-accent-on-dark-hover: #99CCC4;--s2f-text-on-dark: #FAFAF7;--s2f-text-on-dark-secondary: rgba(250, 250, 247, .7);--s2f-text-on-dark-tertiary: rgba(250, 250, 247, .45);--s2f-rule-on-dark: rgba(250, 250, 247, .1);--s2f-bg-on-dark-tint: rgba(102, 179, 168, .06);--s2f-bg-on-dark-tint-border: rgba(102, 179, 168, .22);--s2f-shadow-on-dark: 4px 4px 0 0 rgba(0, 0, 0, .4);--s2f-handle-port-fill-paper: var(--s2f-ink);--s2f-handle-port-fill-dark: var(--s2f-text-on-dark)}.s2f-paper{background:var(--s2f-bg-1);color:var(--s2f-fg-1);font-family:var(--s2f-font-sans);font-weight:var(--s2f-w-regular);-webkit-font-smoothing:antialiased}.s2f-eyebrow{font-family:var(--s2f-font-sans);font-weight:var(--s2f-w-regular);font-size:var(--s2f-t-eyebrow);letter-spacing:var(--s2f-tr-eyebrow);text-transform:uppercase;color:var(--s2f-accent);display:inline-block}.s2f-display{font-family:var(--s2f-font-display);font-weight:var(--s2f-w-semibold);line-height:var(--s2f-lh-tight);letter-spacing:var(--s2f-tr-tight);color:var(--s2f-fg-1);font-size:clamp(40px,7vw,72px)}.s2f-display-md{font-family:var(--s2f-font-display);font-weight:var(--s2f-w-semibold);line-height:var(--s2f-lh-snug);letter-spacing:var(--s2f-tr-tight);color:var(--s2f-fg-1);font-size:clamp(28px,4vw,48px)}.s2f-h3{font-family:var(--s2f-font-display);font-weight:var(--s2f-w-semibold);font-size:var(--s2f-t-h3);line-height:var(--s2f-lh-normal);color:var(--s2f-fg-1)}.s2f-lead{font-family:var(--s2f-font-sans);font-size:var(--s2f-t-body-lg);line-height:var(--s2f-lh-body);color:var(--s2f-fg-2)}.s2f-body{font-family:var(--s2f-font-sans);font-size:var(--s2f-t-body);line-height:var(--s2f-lh-body);color:var(--s2f-fg-2)}.s2f-meta{font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);color:var(--s2f-fg-2)}.s2f-dot{margin:0 8px;color:var(--s2f-fg-3);display:inline-block}.s2f-rule{height:1px;width:100%;background:var(--s2f-rule);border:0}.s2f-btn-pill{display:inline-flex;align-items:center;gap:.4rem;padding:12px 24px;background:var(--s2f-ink);color:var(--s2f-paper);border:none;border-radius:var(--s2f-radius-pill);font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);font-weight:var(--s2f-w-medium);text-decoration:none;cursor:pointer;transition:background var(--s2f-dur) var(--s2f-ease),color var(--s2f-dur) var(--s2f-ease)}.s2f-btn-pill:hover,.s2f-btn-pill:focus-visible{background:var(--s2f-accent-hover-on-ink);color:var(--s2f-paper)}.s2f-btn-pill:disabled{opacity:.4;cursor:not-allowed;background:var(--s2f-ink)}.s2f-link{color:var(--s2f-fg-1);text-decoration-line:underline;text-underline-offset:4px;text-decoration-color:#0a0a0a4d;transition:text-decoration-color var(--s2f-dur) var(--s2f-ease),color var(--s2f-dur) var(--s2f-ease);font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);font-weight:var(--s2f-w-medium)}.s2f-link:hover,.s2f-link:focus-visible{text-decoration-color:var(--s2f-accent)}:root{--bg: #0a0a0a;--surface: #111111;--surface2: #1a1a1a;--border: #2a2a2a;--accent: #00e5a0;--accent2: #00ffb4;--muted: #888888;--danger: #ff4444;--text: #f0f0f0;--text-dim: #999999}*{box-sizing:border-box;margin:0;padding:0}body{font-family:IBM Plex Sans,sans-serif;background:var(--bg);color:var(--text);height:100vh;overflow:hidden;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.btn{padding:.6rem 1.2rem;border-radius:6px;border:none;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;gap:.4rem}.btn-primary{background:var(--accent);color:#0a0a0a;width:100%;justify-content:center;padding:.75rem}.btn-primary:hover{background:var(--accent2)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:transparent;color:var(--danger);border:1px solid var(--danger)}.btn-danger:hover{background:#ef44441a}.btn-ghost{background:none;border:none;color:var(--muted);padding:.3rem .6rem;cursor:pointer;font-size:.8rem;font-family:inherit;transition:color .2s}.btn-ghost:hover{color:var(--text)}#editor-panel .btn-primary{background:var(--s2f-accent-on-dark);color:var(--s2f-ink);border-radius:var(--s2f-radius-pill);font-family:var(--s2f-font-sans);font-size:14px;font-weight:var(--s2f-w-medium);transition:background var(--s2f-dur) var(--s2f-ease),color var(--s2f-dur) var(--s2f-ease)}#editor-panel .btn-primary:hover{background:var(--s2f-accent-on-dark-hover)}#editor-panel .btn-primary:disabled{opacity:.4;cursor:not-allowed}#editor-panel #qa-panel .btn-primary{width:auto;flex:0 0 auto;padding:.5rem 1rem}#editor-panel .btn-secondary{background:transparent;color:var(--s2f-text-on-dark);border:1px solid var(--s2f-rule-on-dark);border-radius:var(--s2f-radius-pill);font-family:var(--s2f-font-sans);font-size:14px;font-weight:var(--s2f-w-medium);transition:border-color var(--s2f-dur) var(--s2f-ease),color var(--s2f-dur) var(--s2f-ease)}#editor-panel .btn-secondary:hover{border-color:var(--s2f-accent-on-dark);color:var(--s2f-accent-on-dark)}.s2f-spinner{display:inline-block;width:1em;height:1em;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:s2f-spin .7s linear infinite;vertical-align:-.15em;flex-shrink:0}.s2f-spinner--block{width:40px;height:40px;border-width:3px}.s2f-vh{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes s2f-spin{to{transform:rotate(360deg)}}.is-loading{position:relative;pointer-events:none;cursor:progress}.is-loading>.s2f-loading-label{visibility:hidden}.is-loading>.s2f-spinner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}@media(prefers-reduced-motion:reduce){.s2f-spinner{animation-duration:1.6s}}#auth-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--s2f-container-pad) 1rem;background:var(--s2f-bg-1);font-family:var(--s2f-font-sans);color:var(--s2f-fg-1)}.auth-card{background:var(--s2f-bg-1);border:none;border-radius:0;box-shadow:none;padding:0;width:100%;max-width:420px;font-family:var(--s2f-font-sans);color:var(--s2f-fg-1)}.auth-card>div:first-child svg rect{fill:var(--s2f-paper)!important}.auth-card>div:first-child svg g path{fill:var(--s2f-ink)!important}.auth-card h1{font-family:var(--s2f-font-display);font-size:var(--s2f-t-display-sm);font-weight:var(--s2f-w-semibold);line-height:var(--s2f-lh-snug);letter-spacing:var(--s2f-tr-tight);color:var(--s2f-fg-1);margin-bottom:.5rem}.auth-card .subtitle{font-family:var(--s2f-font-sans);color:var(--s2f-fg-2);font-size:var(--s2f-t-body);line-height:var(--s2f-lh-body);margin-bottom:2rem}.auth-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:1px solid var(--s2f-rule)}.auth-tab{padding:.6rem 1.2rem .75rem;background:none;border:none;color:var(--s2f-fg-2);cursor:pointer;font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);font-weight:var(--s2f-w-medium);border-bottom:1.5px solid transparent;margin-bottom:-1px;transition:color var(--s2f-dur) var(--s2f-ease),border-color var(--s2f-dur) var(--s2f-ease)}.auth-tab:hover{color:var(--s2f-fg-1)}.auth-tab.active{color:var(--s2f-fg-1);border-bottom-color:var(--s2f-accent)}.form-group{margin-bottom:1rem}.form-group label{display:block;font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);font-weight:var(--s2f-w-medium);color:var(--s2f-fg-1);margin-bottom:.4rem;text-transform:none;letter-spacing:0}.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--s2f-bg-1);border:1px solid var(--s2f-rule);color:var(--s2f-fg-1);padding:.7rem .9rem;border-radius:var(--s2f-radius-md);font-family:var(--s2f-font-sans);font-size:var(--s2f-t-body);line-height:var(--s2f-lh-normal);outline:none;transition:border-color var(--s2f-dur) var(--s2f-ease)}.form-group input::placeholder,.form-group select::placeholder,.form-group textarea::placeholder{color:var(--s2f-fg-3)}.form-group input:focus,.form-group input:focus-visible,.form-group select:focus,.form-group select:focus-visible,.form-group textarea:focus,.form-group textarea:focus-visible{border-color:var(--s2f-accent)}.form-group a{color:var(--s2f-fg-1);text-decoration-line:underline;text-underline-offset:4px;text-decoration-color:#0a0a0a4d;transition:text-decoration-color var(--s2f-dur) var(--s2f-ease)}.form-group a:hover{text-decoration-color:var(--s2f-accent)}#auth-screen .btn-primary{width:100%;justify-content:center;padding:.8rem 1.5rem;background:var(--s2f-ink);color:var(--s2f-paper);border:none;border-radius:var(--s2f-radius-pill);font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);font-weight:var(--s2f-w-medium);cursor:pointer;transition:background var(--s2f-dur) var(--s2f-ease)}#auth-screen .btn-primary:hover,#auth-screen .btn-primary:focus-visible{background:var(--s2f-accent-hover-on-ink);color:var(--s2f-paper)}#auth-screen .btn-primary:disabled{opacity:.4;cursor:not-allowed}#auth-screen .btn-ghost{background:transparent;border:none;color:var(--s2f-fg-2);padding:.4rem 0;cursor:pointer;font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);font-weight:var(--s2f-w-medium);transition:color var(--s2f-dur) var(--s2f-ease)}#auth-screen .btn-ghost:hover,#auth-screen .btn-ghost:focus-visible{color:var(--s2f-accent)}#auth-screen .btn-secondary{background:transparent;color:var(--s2f-fg-1);border:1px solid var(--s2f-fg-1);border-radius:var(--s2f-radius-pill);padding:.7rem 1.4rem;font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);font-weight:var(--s2f-w-medium);transition:background var(--s2f-dur) var(--s2f-ease),color var(--s2f-dur) var(--s2f-ease)}#auth-screen .btn-secondary:hover,#auth-screen .btn-secondary:focus-visible{background:var(--s2f-fg-1);color:var(--s2f-paper)}.auth-error{background:var(--s2f-bg-1);border:1px solid #b3261e;border-radius:var(--s2f-radius-md);padding:.7rem .9rem;font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);color:#b3261e;margin-top:.75rem;display:none}.auth-success{background:var(--s2f-bg-2);border:1px solid var(--s2f-accent);border-radius:var(--s2f-radius-md);padding:.7rem .9rem;font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);color:var(--s2f-accent);margin-top:.75rem;display:none}.auth-divider{display:flex;align-items:center;gap:12px;margin:1rem 0;color:var(--s2f-fg-3);font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);letter-spacing:var(--s2f-tr-eyebrow);text-transform:uppercase}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--s2f-rule)}#main-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;background:var(--s2f-bg-1);color:var(--s2f-fg-1);border-bottom:1px solid var(--s2f-rule);flex-shrink:0;position:relative;font-family:var(--s2f-font-sans)}.logo{display:inline-flex;align-items:center;gap:.5rem;letter-spacing:var(--s2f-tr-tight)}.logo>svg{display:block;height:28px;width:auto}.header-spacer{flex:1}.share-badge{background:var(--s2f-bg-2);border:1px solid var(--s2f-rule);color:var(--s2f-accent);border-radius:var(--s2f-radius-pill);padding:.25rem .75rem;font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);font-weight:var(--s2f-w-medium);letter-spacing:0}.user-info{display:flex;align-items:center;gap:1.25rem;font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);color:var(--s2f-fg-2)}.user-info .btn,.user-info .btn-ghost,.user-info a.btn-ghost{background:transparent;color:var(--s2f-fg-2);border:none;border-radius:0;padding:.25rem 0;font-family:var(--s2f-font-sans);font-size:var(--s2f-t-small);font-weight:var(--s2f-w-medium);text-decoration:none;transition:color var(--s2f-dur) var(--s2f-ease)}.user-info .btn:hover,.user-info .btn:focus-visible,.user-info .btn-ghost:hover,.user-info .btn-ghost:focus-visible,.user-info a.btn-ghost:hover,.user-info a.btn-ghost:focus-visible{color:var(--s2f-accent);background:transparent}.user-info #user-name-display{color:var(--s2f-fg-1);font-weight:var(--s2f-w-medium)}#admin-btn{background:transparent!important;color:var(--s2f-fg-2)!important;border:none!important;font-family:var(--s2f-font-sans)!important;font-size:var(--s2f-t-small)!important;font-weight:var(--s2f-w-medium)!important;padding:.25rem 0!important}#admin-btn:hover,#admin-btn:focus-visible{color:var(--s2f-accent)!important}.hamburger-btn{background:transparent;border:none;color:var(--s2f-fg-1);cursor:pointer;padding:.25rem .5rem;font-size:1.1rem}#main-app{display:flex;flex:1;overflow:hidden}#left-panel{width:340px;min-width:280px;max-width:420px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}#process-library{flex:1;display:flex;flex-direction:column;overflow:hidden}#left-panel.editing #process-library{display:none}#left-panel:not(.editing) #editor-panel{display:none}.library-header{display:flex;align-items:center;padding:.7rem 1rem;gap:.5rem}.library-header span{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:500;flex:1}.process-list{overflow-y:auto;flex:1}.process-item{padding:.6rem 1rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background .15s;border-bottom:1px solid rgba(42,47,69,.5)}.process-item:hover{background:var(--surface2)}.process-item.active{background:#00e5a014;border-left:2px solid var(--accent)}.process-item:hover .process-item-actions,.process-item.active .process-item-actions{display:flex}.process-item-name{font-size:.85rem;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.process-item-actions{display:none;gap:.2rem}.process-action-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:.2rem;font-size:.75rem;border-radius:3px;transition:all .15s}.process-action-btn:hover{color:var(--text);background:var(--border)}.process-action-btn.danger:hover{color:var(--danger)}.process-action-btn.share-btn:hover{color:var(--accent2)}body.share-mode #process-library{display:none}body.share-mode #left-panel{max-height:100%}#editor-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:1rem;gap:.75rem}#editor-panel.generating{pointer-events:none;opacity:.5}.process-title-row{display:flex;align-items:center;gap:.5rem}#process-name-input{flex:1;background:var(--surface2);border:1px solid var(--s2f-rule-on-dark);color:var(--s2f-text-on-dark);padding:.5rem .7rem;border-radius:var(--s2f-radius-md);font-family:var(--s2f-font-display);font-size:18px;font-weight:var(--s2f-w-semibold);outline:none;transition:border-color var(--s2f-dur) var(--s2f-ease)}#process-name-input::placeholder{color:var(--s2f-text-on-dark-tertiary)}#process-name-input:focus{border-color:var(--s2f-accent-on-dark)}.version-badge{font-family:var(--s2f-font-sans);font-size:.7rem;color:var(--s2f-text-on-dark-secondary);background:var(--surface2);padding:.3rem .6rem;border-radius:var(--s2f-radius-sm);border:1px solid var(--s2f-rule-on-dark);white-space:nowrap;cursor:pointer;transition:border-color var(--s2f-dur) var(--s2f-ease),color var(--s2f-dur) var(--s2f-ease)}.version-badge:hover{border-color:var(--s2f-accent-on-dark);color:var(--s2f-accent-on-dark)}#description-textarea{flex:1;min-height:100px;resize:none;background:var(--surface2);border:1px solid var(--s2f-rule-on-dark);color:var(--s2f-text-on-dark);padding:.75rem;border-radius:var(--s2f-radius-md);font-family:var(--s2f-font-sans);font-size:16px;line-height:var(--s2f-lh-body);outline:none;transition:border-color var(--s2f-dur) var(--s2f-ease)}#description-textarea:focus{border-color:var(--s2f-accent-on-dark)}#description-textarea::placeholder{color:var(--s2f-text-on-dark-tertiary)}#description-editor{flex:1;min-height:100px;display:flex;flex-direction:column}.tiptap-editor{flex:1;background:var(--surface2);border:1px solid var(--s2f-rule-on-dark);color:var(--s2f-text-on-dark);padding:.75rem;border-radius:var(--s2f-radius-md);font-family:var(--s2f-font-sans);font-size:16px;line-height:var(--s2f-lh-body);outline:none;overflow-y:auto;cursor:text;transition:border-color var(--s2f-dur) var(--s2f-ease)}.tiptap-editor:focus{border-color:var(--s2f-accent-on-dark)}.tiptap-editor>*:first-child{margin-top:0}.tiptap-editor>*:last-child{margin-bottom:0}.tiptap-editor h1,.tiptap-editor h2,.tiptap-editor h3{color:var(--s2f-text-on-dark);font-family:var(--s2f-font-display);font-weight:var(--s2f-w-semibold);margin:.6em 0 .3em;line-height:1.3}.tiptap-editor h1{font-size:1.3em}.tiptap-editor h2{font-size:1.15em}.tiptap-editor h3{font-size:1.05em}.tiptap-editor p{margin:.4em 0}.tiptap-editor ul,.tiptap-editor ol{padding-left:1.5em;margin:.3em 0}.tiptap-editor li{margin:.15em 0}.tiptap-editor strong{color:var(--s2f-text-on-dark);font-weight:var(--s2f-w-semibold)}.tiptap-editor em{color:var(--s2f-text-on-dark-secondary);font-style:italic}.tiptap-editor code{background:#ffffff0f;padding:.1em .3em;border-radius:var(--s2f-radius-sm);font-size:.85em;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.tiptap-editor p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--s2f-text-on-dark-tertiary);pointer-events:none;height:0;white-space:pre-wrap}.voice-row{display:flex;align-items:center;gap:.5rem}#record-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem .9rem;background:transparent;border:1px solid var(--s2f-rule-on-dark);border-radius:var(--s2f-radius-pill);color:var(--s2f-text-on-dark-secondary);cursor:pointer;font-family:var(--s2f-font-sans);font-size:.8rem;font-weight:var(--s2f-w-medium);transition:border-color var(--s2f-dur) var(--s2f-ease),color var(--s2f-dur) var(--s2f-ease)}#record-btn:hover{border-color:var(--s2f-accent-on-dark);color:var(--s2f-accent-on-dark)}#record-btn.recording{border-color:var(--danger);color:var(--danger);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.record-dot{width:8px;height:8px;border-radius:50%;background:currentColor}#voice-status{font-family:var(--s2f-font-sans);font-size:12px;color:var(--s2f-text-on-dark-tertiary);flex:1}#editor-panel .btn-ghost{color:var(--s2f-text-on-dark-secondary);transition:color var(--s2f-dur) var(--s2f-ease)}#editor-panel .btn-ghost:hover{color:var(--s2f-accent-on-dark)}#qa-panel{background:var(--s2f-bg-on-dark-tint);border:1px solid var(--s2f-bg-on-dark-tint-border);border-radius:var(--s2f-radius-md);padding:.75rem;display:none;max-height:300px;overflow-y:auto}#qa-panel h4{font-family:var(--s2f-font-display);font-weight:var(--s2f-w-semibold);font-size:18px;line-height:var(--s2f-lh-snug);color:var(--s2f-text-on-dark);text-transform:none;letter-spacing:0;margin-bottom:.5rem}.qa-item{margin-bottom:.75rem}.qa-question{font-family:var(--s2f-font-sans);font-size:14px;line-height:var(--s2f-lh-body);color:var(--s2f-text-on-dark-secondary);margin-bottom:.3rem}.qa-answer{width:100%;background:var(--surface2);border:1px solid var(--s2f-rule-on-dark);color:var(--s2f-text-on-dark);padding:.45rem .6rem;border-radius:var(--s2f-radius-md);font-family:var(--s2f-font-sans);font-size:14px;outline:none;resize:none;transition:border-color var(--s2f-dur) var(--s2f-ease)}.qa-answer:focus{border-color:var(--s2f-accent-on-dark)}.action-row{display:flex;gap:.5rem}.action-row .btn{flex:1;justify-content:center}#asset-panel{margin-top:.5rem;border-top:1px solid var(--s2f-rule-on-dark);padding-top:.6rem;font-family:var(--s2f-font-sans);font-size:.8rem}.asset-panel-header{font-family:var(--s2f-font-sans);font-size:11px;text-transform:uppercase;letter-spacing:var(--s2f-tr-eyebrow);color:var(--s2f-text-on-dark-tertiary);margin-bottom:.4rem}.asset-panel-empty,.asset-panel-loading{color:var(--s2f-text-on-dark-tertiary);font-size:.78rem;padding:.3rem 0}.asset-row{display:flex;align-items:center;gap:.4rem;padding:.3rem .2rem;border-radius:var(--s2f-radius-sm);transition:background var(--s2f-dur) var(--s2f-ease)}.asset-row:hover{background:#ffffff0a}.asset-row .asset-icon{font-size:1rem;line-height:1}.asset-row .asset-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--s2f-text-on-dark)}.asset-row .asset-meta{color:var(--s2f-text-on-dark-tertiary);font-size:.72rem;white-space:nowrap}.asset-row .asset-btn{background:transparent;border:none;cursor:pointer;padding:.15rem .3rem;font-size:.85rem;color:var(--s2f-text-on-dark-secondary);border-radius:var(--s2f-radius-sm);transition:color var(--s2f-dur) var(--s2f-ease),background var(--s2f-dur) var(--s2f-ease)}.asset-row .asset-btn:hover{background:#ffffff0a;color:var(--s2f-accent-on-dark)}.asset-row .asset-btn.danger:hover{color:var(--danger)}#right-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}#diagram-toolbar{display:flex;align-items:center;flex-wrap:wrap;padding:.5rem 1rem;gap:.5rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.toolbar-btn{background:none;border:1px solid var(--border);color:var(--text-dim);padding:.35rem .7rem;border-radius:5px;cursor:pointer;font-size:.78rem;font-family:inherit;transition:all .15s}.toolbar-btn:hover{border-color:var(--accent);color:var(--accent)}.toolbar-btn.active{border-color:var(--accent2);color:var(--accent2);background:#00c8ff14}.star-btn{border:none!important;background:none!important;color:var(--border);font-size:1rem;padding:.15rem .1rem;min-width:0;cursor:pointer;transition:color .1s}.star-btn:hover,.star-btn.active{color:#f5a623;background:none!important}#diagram-rating:hover .star-btn{color:var(--border)}#diagram-rating .star-btn:hover,#diagram-rating .star-btn:hover~.star-btn{color:var(--border)}#diagram-tabs{display:flex;gap:.25rem;margin-right:.5rem;padding-right:.5rem;border-right:1px solid var(--border)}#mermaid-canvas{position:absolute;top:0;right:0;bottom:0;left:0;overflow:auto;background:var(--surface);padding:2rem;display:flex;justify-content:center;align-items:flex-start}#mermaid-canvas:not(.reactflow-view)>svg{max-width:100%;height:auto}#mermaid-canvas.reactflow-view{display:block;padding:0;background:#fff}#diagram-status{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;color:var(--muted);font-family:IBM Plex Mono,monospace}#diagram-error-surface{width:100%;flex-shrink:0}#diagram-error-surface:empty{display:none}#diagram-error-surface .error-surface{margin:.5rem 1rem}#canvas-container{flex:1;position:relative;overflow:hidden}#bpmn-canvas{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff}#bpmn-canvas .djs-container,#bpmn-modal-canvas,#bpmn-modal-canvas .djs-container{background:#fff}.bjs-powered-by{display:none!important}#bpmn-canvas:not(.edit-mode) .djs-palette{display:none!important}#bpmn-canvas:not(.edit-mode) .djs-context-pad{display:none!important}#bpmn-canvas:not(.edit-mode) .djs-overlay-container{display:none!important}#bpmn-canvas:not(.edit-mode) .djs-direct-editing-parent{display:none!important}#bpmn-canvas:not(.edit-mode) .djs-element{pointer-events:none!important}#bpmn-canvas:not(.edit-mode) .djs-container{cursor:grab}#bpmn-canvas:not(.edit-mode) .djs-container:active{cursor:grabbing}#bpmn-canvas.edit-mode{outline:2px solid var(--accent2);outline-offset:-2px}.djs-context-pad .entry{background-color:var(--surface)!important;border:1px solid var(--border)!important;border-radius:4px!important}.djs-context-pad .entry:hover{background-color:var(--surface2)!important}.djs-popup{background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:6px!important;box-shadow:0 4px 12px #00000080!important;color:var(--text)!important}.djs-popup .entry{color:var(--text)!important}.djs-popup .entry:hover{background:var(--surface2)!important}.djs-popup .djs-popup-header{background:var(--surface2)!important;color:var(--text)!important;border-bottom:1px solid var(--border)!important}.djs-popup .djs-popup-title{color:var(--text)!important}.djs-popup .djs-popup-search input{background:var(--bg)!important;color:var(--text)!important;border:1px solid var(--border)!important}.djs-popup .djs-popup-body .entry{border-bottom:1px solid var(--border)!important}.djs-popup .djs-popup-label{color:var(--text)!important}.djs-popup .djs-popup-description{color:var(--text-dim)!important}.djs-direct-editing-content,.djs-direct-editing-parent{color:#111!important;background:#fff!important;border:1px solid var(--accent)!important;border-radius:3px!important;font-family:IBM Plex Sans,Arial,sans-serif!important;font-size:12px!important;padding:4px 6px!important;box-shadow:0 0 0 2px #00e5a033!important}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#0969da!important;stroke-width:3!important;filter:drop-shadow(0 0 2px rgba(9,105,218,.5))}.react-flow__edge .react-flow__edgeupdater{r:6;fill:#fff;stroke:#00e5a0;stroke-width:1.5;opacity:.85;cursor:grab;transition:opacity .12s ease-out,r .12s ease-out}.react-flow__edge .react-flow__edgeupdater:hover{opacity:1;r:8}.reactflow-view .react-flow__edgeupdater{display:none!important}.react-flow__edge.selected .react-flow__edgeupdater,.react-flow__edge:focus .react-flow__edgeupdater,.react-flow__edge:focus-visible .react-flow__edgeupdater{fill:#0969da!important;fill-opacity:.85!important;stroke:#fff!important;stroke-width:2!important}.react-flow__controls{--xy-controls-button-background-color: #21262d;--xy-controls-button-background-color-hover: #30363d;--xy-controls-button-color: #e6edf3;--xy-controls-button-border-color: #30363d}.react-flow__node-mermaidDiamond{pointer-events:none!important}.react-flow__node-mermaidDiamond polygon,.react-flow__node-mermaidDiamond .react-flow__handle,.react-flow__node-mermaidDiamond .react-flow__resize-control,.react-flow__node-mermaidDiamond .react-flow__resize-line{pointer-events:auto!important}.reactflow-view .react-flow__handle{opacity:0;pointer-events:none}.reactflow-view .react-flow__handle:before{pointer-events:none}.react-flow__handle{opacity:0;transition:opacity .12s ease-out,transform .12s ease-out,box-shadow .12s ease-out;z-index:10}.react-flow__handle:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;background:#0000;pointer-events:auto}.react-flow__node:hover .react-flow__handle,.react-flow__node.selected .react-flow__handle,.react-flow__handle:hover,.react-flow__handle.connectable.connectingfrom,.react-flow__handle.connectable.connectingto{opacity:1}.react-flow__handle:hover,.react-flow__handle.connectable.connectingfrom,.react-flow__handle.connectable.connectingto{transform:scale(1.2);box-shadow:0 0 0 2px #66b3a84d}#xml-view{display:none;position:absolute;top:0;right:0;bottom:0;left:0;overflow:auto;background:var(--surface);padding:1rem}#xml-view pre{font-family:IBM Plex Mono,monospace;font-size:.78rem;line-height:1.6;color:var(--text);white-space:pre-wrap;word-break:break-word}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0d0f12cc;display:flex;align-items:center;justify-content:center;z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.s2f-loader{position:relative;width:96px;height:96px}.s2f-loader-ring{position:absolute;top:0;right:0;bottom:0;left:0;border:3px solid transparent;border-top-color:var(--accent);border-radius:50%;animation:s2f-loader-spin 1s linear infinite}.s2f-loader-pill{position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:50%;background:#fff;box-shadow:0 8px 32px #0006;display:flex;align-items:center;justify-content:center}.s2f-loader-mark{width:70%;height:70%;object-fit:contain;animation:s2f-loader-pulse 1.6s ease-in-out infinite}@keyframes s2f-loader-spin{to{transform:rotate(360deg)}}@keyframes s2f-loader-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.78;transform:scale(.94)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;width:100%;max-width:480px;max-height:80vh;overflow-y:auto}.modal h3{font-size:1rem;font-weight:600;margin-bottom:1.25rem;color:var(--text)}.modal-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1.25rem}.version-row{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--border)}.version-info{flex:1}.version-num{font-family:IBM Plex Mono,monospace;font-size:.8rem;color:var(--accent2)}.version-meta{font-size:.75rem;color:var(--muted);margin-top:.2rem}.version-desc{font-size:.8rem;color:var(--text-dim);margin-top:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}.share-link-row{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:.6rem .75rem;margin-bottom:.5rem}.share-link-row.revoked{opacity:.4}.share-link-url{font-family:IBM Plex Mono,monospace;font-size:.72rem;color:var(--accent2);word-break:break-all;margin-bottom:.4rem}.share-link-meta{font-size:.75rem;color:var(--muted);display:flex;align-items:center;gap:.75rem}.share-link-actions{display:flex;gap:.4rem;margin-top:.4rem}.permission-badge{font-size:.7rem;padding:.15rem .5rem;border-radius:3px;font-weight:500}.permission-badge.read{background:#6b728033;color:var(--muted);border:1px solid var(--muted)}.permission-badge.write{background:#00e5a01a;color:var(--accent);border:1px solid var(--accent)}#editor-modal{z-index:150;padding:0;opacity:0;transition:opacity .15s ease}#editor-modal.visible{opacity:1}.editor-modal-dialog{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:calc(100vw - 2rem);height:calc(100vh - 2rem);display:flex;flex-direction:column;overflow:hidden;transform:scale(.97);transition:transform .2s ease-out}.visible .editor-modal-dialog{transform:scale(1)}.editor-modal-topbar{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;border-bottom:1px solid var(--border);background:var(--surface2);flex-shrink:0}.editor-modal-desc-toggle{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-dim);font-size:.8rem;padding:.3rem .6rem;cursor:pointer;white-space:nowrap}.editor-modal-desc-toggle:hover{color:var(--text);border-color:var(--text-dim)}.editor-modal-title{flex:1;text-align:center;font-size:.9rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-modal-actions{display:flex;gap:.4rem;flex-shrink:0}.editor-modal-body{position:relative;flex:1;overflow:hidden}.editor-modal-description{position:absolute;top:0;left:0;z-index:20;max-width:400px;max-height:60%;overflow-y:auto;background:#fffffff2;border:1px solid var(--border);border-radius:0 0 8px;padding:1rem;box-shadow:0 2px 8px #00000026;font-size:.85rem;line-height:1.6;color:#1a1a1a;-webkit-user-select:text;user-select:text}.editor-modal-canvas{width:100%;height:100%;position:relative}@media(max-width:768px){.editor-modal-dialog{width:calc(100vw - 1rem);height:calc(100vh - 1rem);border-radius:8px}.editor-modal-topbar{flex-wrap:wrap;padding:.4rem .6rem;gap:.4rem}.editor-modal-title{order:-1;flex-basis:100%;text-align:left;font-size:.85rem}.editor-modal-description{max-width:85vw}}#display-name-modal{z-index:160}#notifications{position:fixed;bottom:1.5rem;right:1.5rem;z-index:200;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.notification{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:.65rem 1rem;font-size:.82rem;color:var(--text);pointer-events:auto;animation:slideIn .2s ease;max-width:320px;display:flex;align-items:center;gap:.5rem}.notification.success{border-color:var(--accent);color:var(--accent)}.notification.error{border-color:var(--danger);color:#fca5a5}.notification-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;padding:0 .2rem;line-height:1;opacity:.6;flex-shrink:0}.notification-close:hover{opacity:1}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--muted);padding:2rem;text-align:center}.empty-state .icon{font-size:2.5rem}.empty-state p{font-size:.85rem;max-width:260px}.admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:100;opacity:0;pointer-events:none;transition:opacity .2s}.admin-overlay.open{opacity:1;pointer-events:auto}.admin-panel{position:fixed;top:0;right:0;bottom:0;width:760px;max-width:90vw;background:var(--bg);z-index:101;display:flex;flex-direction:column;transform:translate(100%);transition:transform .25s ease-out;box-shadow:-4px 0 24px #0000004d}.admin-panel.open{transform:translate(0)}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.admin-header h2{margin:0;font-size:1.1rem;font-weight:600}.admin-header .admin-close{background:none;border:none;color:var(--text-dim);font-size:1.3rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px}.admin-header .admin-close:hover{color:var(--text);background:var(--surface2)}.admin-breadcrumb{display:flex;align-items:center;gap:.4rem;padding:.6rem 1.25rem;font-size:.82rem;color:var(--text-dim);border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.admin-breadcrumb .crumb{cursor:pointer;color:var(--accent)}.admin-breadcrumb .crumb:hover{text-decoration:underline}.admin-breadcrumb .crumb-current{color:var(--text);cursor:default}.admin-breadcrumb .crumb-sep{color:var(--text-dim);font-size:.75rem}.admin-toolbar{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.admin-toolbar .admin-filter{flex:1;padding:.4rem .7rem;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:5px;font-size:.82rem;font-family:inherit}.admin-toolbar .admin-filter::placeholder{color:var(--text-dim)}.admin-content{flex:1;overflow-y:auto;padding:0}.admin-table{width:100%;border-collapse:collapse;font-size:.83rem}.admin-table thead th{position:sticky;top:0;background:var(--surface);text-align:left;padding:.55rem 1rem;color:var(--text-dim);font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}.admin-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.admin-table tbody tr:hover{background:var(--surface2)}.admin-table tbody tr.clickable{cursor:pointer}.admin-table td{padding:.55rem 1rem;vertical-align:middle}.status-badge{display:inline-block;font-size:.72rem;font-weight:600;padding:.15rem .5rem;border-radius:10px;letter-spacing:.02em}.status-badge.active{background:#00e5a026;color:var(--accent)}.status-badge.inactive{background:#f5a62326;color:var(--warning, #f5a623)}.status-badge.unconfirmed{background:#ff646426;color:var(--danger)}.status-badge.disabled{background:#ff3c3c26;color:var(--danger)}.key-indicator{display:inline-block;width:8px;height:8px;border-radius:50%}.key-indicator.configured{background:var(--accent)}.key-indicator.none{background:var(--border)}.admin-inline-form{display:none;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--surface)}.admin-inline-form.visible{display:flex}.admin-inline-form input,.admin-inline-form select{padding:.4rem .6rem;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:.82rem;font-family:inherit}.org-info-bar{display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;background:var(--surface);border-bottom:1px solid var(--border);font-size:.83rem;flex-shrink:0}.org-info-bar .org-domain{font-weight:600;color:var(--text)}.org-info-bar .org-meta{color:var(--text-dim);font-size:.78rem}.admin-action-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:.2rem .45rem;border-radius:4px;font-size:.75rem;font-family:inherit;white-space:nowrap}.admin-action-btn:hover{background:var(--surface2);color:var(--text)}.admin-action-btn.danger{color:var(--danger)}.admin-action-btn.accent{color:var(--accent)}.admin-action-btn.warning{color:var(--warning, #f5a623)}.admin-role-select{padding:.2rem .4rem;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:.78rem;font-family:inherit}.admin-role-select:disabled{opacity:.5}.admin-empty{padding:2rem;text-align:center;color:var(--text-dim);font-size:.85rem}#error-surface-root{position:relative}.error-surface{position:relative;margin:.75rem 0;padding:1rem 2.25rem 1rem 1.25rem;background:var(--surface);color:var(--text);border:1px solid var(--border);border-left:4px solid var(--danger);border-radius:8px;font-family:IBM Plex Sans,Arial,sans-serif;box-shadow:0 2px 10px #0000004d}.error-surface:focus,.error-surface:focus-visible{outline:2px solid var(--accent2);outline-offset:2px}.error-surface__glyph{color:var(--danger);font-size:1.05em;margin-right:.35rem}.error-surface__title{font-size:1rem;font-weight:600;margin:0 0 .5rem;color:var(--text)}.error-surface__body{font-size:.9rem;line-height:1.55;color:var(--text-dim);margin:0 0 .9rem}.error-surface__actions{display:flex;gap:.5rem;flex-wrap:wrap}.error-surface__action{background:none;border:1px solid var(--border);color:var(--text-dim);padding:.4rem .8rem;border-radius:5px;cursor:pointer;font-size:.82rem;font-family:inherit;text-decoration:none;transition:border-color .15s,color .15s}.error-surface__action:hover{border-color:var(--accent2);color:var(--accent2)}.error-surface__action--primary{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}.error-surface__action--primary:hover{background:var(--accent2);border-color:var(--accent2);color:#0a0a0a}.error-surface__action--secondary{font-size:.78rem}.error-surface__close{position:absolute;top:.4rem;right:.55rem;background:none;border:none;color:var(--text-dim);font-size:1.2rem;line-height:1;cursor:pointer;padding:.25rem .45rem;border-radius:4px}.error-surface__close:hover{color:var(--text);background:var(--surface2)}.error-surface__footer{margin-top:.9rem;display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;border-top:1px dashed var(--border);padding-top:.6rem}.error-surface__details{font-size:.78rem;color:var(--text-dim)}.error-surface__details summary{cursor:pointer;-webkit-user-select:none;user-select:none;padding:.25rem 0;color:var(--text-dim)}.error-surface__details summary:hover{color:var(--text)}.error-surface__details-body{font-family:IBM Plex Mono,monospace;font-size:.72rem;line-height:1.5;white-space:pre-wrap;margin:.4rem 0 0;padding:.5rem .65rem;background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text-dim)}.error-surface[data-error-class=network-timeout],.error-surface[data-error-class=auth-session-expired],.error-surface[data-error-class=auth-permission-denied]{border-left-color:#f5a623}.error-surface[data-error-class=generation-failure],.error-surface[data-error-class=parse-layout-failure],.error-surface[data-error-class=export-failure]{border-left-color:var(--danger)}.error-surface[data-error-class=rate-limit-hit]{border-left-color:#3aa0ff}.error-surface[data-error-class=sharing-link-expired]{border-left-color:var(--text-dim)}.error-surface[data-error-class=terms-not-accepted]{border-left-color:var(--accent2)}.error-surface[data-error-class=unknown-client-error]{border-left-color:var(--danger)}.error-surface[data-modal=true]{position:fixed;top:0;right:0;bottom:0;left:0;margin:0;padding:0;background:transparent;border:none;box-shadow:none;display:flex;align-items:center;justify-content:center;z-index:1000}.error-surface[data-modal=true]:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:-1}.error-surface[data-modal=true] .error-surface__title,.error-surface[data-modal=true] .error-surface__body,.error-surface[data-modal=true] .error-surface__actions,.error-surface[data-modal=true] .error-surface__footer,.error-surface[data-modal=true] .error-surface__close{max-width:420px}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--surface);border-top:1px solid var(--border);padding:.25rem 0;padding-bottom:env(safe-area-inset-bottom,0)}.mobile-bottom-nav button{flex:1;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.5rem 0;background:none;border:none;color:var(--muted);font-family:inherit;font-size:.65rem;font-weight:500;cursor:pointer;min-height:48px;transition:color .15s}.mobile-bottom-nav button svg{stroke:currentColor}.mobile-bottom-nav button.active{color:var(--accent)}.mobile-fab{display:none;position:fixed;bottom:calc(76px + env(safe-area-inset-bottom,0));right:16px;z-index:55;background:var(--accent);color:var(--bg);border:none;border-radius:28px;padding:.75rem 1.25rem;font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;box-shadow:0 4px 16px #00e5a04d;align-items:center;gap:.4rem;transition:transform .15s,box-shadow .15s}.mobile-fab:active{transform:scale(.95);box-shadow:0 2px 8px #00e5a033}.bottom-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:70}.bottom-sheet{position:fixed;bottom:0;left:0;right:0;z-index:71;background:var(--surface);border-radius:16px 16px 0 0;padding:1rem 1.25rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0));flex-direction:column;gap:1rem}.bottom-sheet .bottom-sheet-handle{width:36px;height:4px;background:var(--border);border-radius:2px;align-self:center;margin-bottom:.5rem}.bottom-sheet h4{margin:0;font-size:.95rem;color:var(--text)}.bottom-sheet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.bottom-sheet-grid button{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1rem;background:var(--surface2);border:1px solid var(--border);border-radius:12px;color:var(--text);font-family:inherit;font-size:.85rem;font-weight:500;cursor:pointer;min-height:80px;transition:background .15s}.bottom-sheet-grid button:active{background:var(--border)}.bottom-sheet-grid .bottom-sheet-icon{font-size:1.5rem}.hamburger-btn{display:none;background:none;border:1px solid var(--border);color:var(--text);width:40px;height:40px;border-radius:6px;cursor:pointer;font-size:1.2rem;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s}.hamburger-btn:hover{border-color:var(--accent)}.mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:49}@media(max-width:1024px){#left-panel{width:280px;min-width:240px}#editor-panel{padding:.75rem;gap:.5rem}.library-header,.process-item{padding:.5rem .75rem}#diagram-toolbar{padding:.4rem .75rem;gap:.35rem}.toolbar-btn{padding:.3rem .55rem;font-size:.75rem}.btn{font-size:.82rem;padding:.5rem 1rem}.process-item-name,.tiptap-editor{font-size:.82rem}}@media(max-width:768px){.mobile-bottom-nav,.mobile-fab{display:flex}.back-btn{display:none!important}#left-panel.editing #process-library{display:flex}#left-panel:not(.editing) #editor-panel{display:flex}.hamburger-btn{display:none!important}#main-app{flex-direction:column;padding-bottom:calc(56px + env(safe-area-inset-bottom,0))}#left-panel{width:100%;min-width:0;max-width:100%;border-right:none;flex-shrink:0}#right-panel{flex:1;min-height:0}#process-library{max-height:none}#main-header{padding:.5rem .75rem;gap:.5rem}#main-header>span[style*="position:absolute"]{display:none}#diagram-toolbar{flex-wrap:wrap;padding:.35rem .5rem;gap:.25rem}#diagram-toolbar #export-pdf-btn,#diagram-toolbar #export-ppt-btn{display:none!important}.toolbar-btn{padding:.35rem .55rem;font-size:.75rem;min-height:36px}.btn{min-height:44px;font-size:.85rem}.btn-primary{padding:.85rem}.btn-secondary{padding:.6rem 1rem}.btn-ghost{min-height:44px;padding:.5rem .75rem}.process-item-actions{display:flex}.process-action-btn{min-height:36px;min-width:36px;display:flex;align-items:center;justify-content:center}#editor-panel{padding:.75rem;gap:.5rem;overflow-y:auto}.voice-row{flex-wrap:wrap;gap:.35rem}.action-row{display:none}#diagram-type-selector{flex-wrap:wrap;gap:.5rem}.modal-backdrop{padding:0;align-items:stretch}.modal{max-width:100%;max-height:100%;border-radius:0;height:100%}#notifications{left:.75rem;right:.75rem;bottom:calc(60px + env(safe-area-inset-bottom,0) + .75rem)}#notifications .notification{max-width:100%}.auth-card{margin:1rem;max-width:100%}}@media(max-width:480px){#main-header{padding:.4rem .5rem;gap:.35rem}#editor-panel{padding:.5rem;gap:.35rem}.library-header,.process-item{padding:.4rem .5rem}#diagram-toolbar{padding:.3rem .5rem}#diagram-toolbar #xml-toggle-btn,#diagram-toolbar [onclick="copyXml()"]{display:none}.toolbar-btn{padding:.3rem .45rem;font-size:.72rem}.modal{padding:1rem}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%;justify-content:center}.user-info{gap:.3rem;font-size:.78rem}.version-desc{max-width:180px}.auth-card{margin:.5rem;padding:1.25rem}.voice-row .btn-ghost{font-size:.75rem;padding:.4rem .5rem}#record-btn{min-height:40px;min-width:40px;padding:.5rem .9rem}}
