.layout{min-height:100vh;display:flex;flex-direction:column}.layout-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:64px;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center}.logo{display:flex;align-items:center;gap:8px;text-decoration:none}.logo-icon{width:32px;height:32px;object-fit:contain}.logo-text{font-size:20px;font-weight:700;color:#1a2f5c}.header-nav{display:flex;align-items:center;gap:8px}.nav-link{padding:8px 16px;color:var(--text-secondary);font-weight:500;font-size:14px;border-radius:var(--radius-md);transition:all .2s}.nav-link:hover{color:var(--text);background:var(--surface-light);text-decoration:none}.nav-link.active{color:var(--text);background:var(--surface-light);font-weight:600}.header-right{display:flex;align-items:center}.user-menu{display:flex;align-items:center;gap:12px}.user-avatar{width:36px;height:36px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.user-name{color:var(--text);font-weight:500;font-size:14px}.layout-content{flex:1;display:flex;flex-direction:column}.dashboard{padding:32px;max-width:1400px;margin:0 auto;animation:fadeIn .3s ease}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.header-content h1{font-size:28px;margin-bottom:8px;color:var(--text)}.header-content p{color:var(--text-muted)}.header-actions{display:flex;gap:12px}.extension-hint{display:flex;align-items:center;gap:8px;padding:5px 16px;background:var(--surface-light);border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;color:var(--text-secondary)}.hint-icon{font-size:16px}.dashboard-error{padding:16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#dc2626;margin-bottom:24px}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:80px 32px;background:var(--surface);border-radius:var(--radius-xl);border:1px dashed var(--border)}.empty-icon{font-size:64px;margin-bottom:24px}.empty-state h2{font-size:24px;margin-bottom:12px;color:var(--text)}.empty-state p{max-width:500px;margin-bottom:32px;line-height:1.6;color:var(--text-secondary)}.empty-steps{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:500px}.empty-step{display:flex;align-items:center;gap:12px;padding:16px;background:var(--surface-light);border:1px solid var(--border);border-radius:var(--radius-md);text-align:left}.step-number{width:28px;height:28px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.guides-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.guide-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s;position:relative}.guide-card:hover{border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.guide-cover{position:relative;height:180px;background:var(--surface-light);overflow:hidden}.guide-cover img{width:100%;height:100%;object-fit:cover}.cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--surface-light);font-size:48px}.guide-status{position:absolute;top:12px;right:12px;display:flex;gap:6px}.status-badge{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.draft{background:#f59e0b26;color:#b45309}.status-badge.published{background:#22c55e26;color:#15803d}.status-badge.archived{background:#6b728026;color:#4b5563}.status-badge.public{background:#0000001a;color:var(--text)}.guide-content{padding:20px}.guide-title{font-size:18px;margin-bottom:8px;line-height:1.3;color:var(--text)}.guide-description{font-size:14px;color:var(--text-muted);margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.guide-meta{display:flex;flex-wrap:wrap;gap:12px}.meta-item{font-size:12px;color:var(--text-muted)}.guide-actions{padding:16px 20px;border-top:1px solid var(--border);display:flex;gap:8px}.guide-actions .btn{flex:1}.guide-actions .btn:last-child{flex:0}.delete-confirm{position:absolute;top:0;right:0;bottom:0;left:0;background:#fffffff2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px;animation:fadeIn .2s ease}.delete-confirm p{color:var(--text);font-weight:500}.delete-actions{display:flex;gap:8px}@media (max-width: 768px){.dashboard{padding:20px}.dashboard-header{flex-direction:column;gap:16px}.empty-steps,.guides-grid{grid-template-columns:1fr}}.dashboard-filter{margin-bottom:24px}.filter-dropdown{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);font-size:14px;cursor:pointer;outline:none;transition:border-color .2s}.filter-dropdown:hover,.filter-dropdown:focus{border-color:var(--primary)}.guide-shared-by{font-size:12px;color:var(--primary);margin-bottom:6px;font-weight:500}.step-item{display:flex;align-items:center;gap:10px;padding:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;margin-bottom:8px;position:relative}.step-item:hover{border-color:var(--border-light);background:var(--surface-light);transform:translate(2px)}.step-item.selected{border-color:var(--primary);background:#24428214}.step-item.dragging{box-shadow:var(--shadow-lg);z-index:10}.step-number-column{width:24px;height:24px;flex-shrink:0;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;background:var(--surface-light);border-radius:50%;color:var(--text-secondary)}.step-item.selected .step-number-column{background:var(--primary);color:#fff}.step-drag-handle{cursor:grab;color:var(--text-muted);padding:4px;display:flex;align-items:center;justify-content:center;opacity:.5;transition:opacity .2s}.step-item:hover .step-drag-handle,.step-drag-handle:hover{opacity:1}.step-drag-handle:active{cursor:grabbing}.step-thumbnail{width:60px;height:40px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;position:relative;background:var(--surface-light);border:1px solid var(--border)}.step-thumbnail img{width:100%;height:100%;object-fit:cover}.annotation-badge{position:absolute;top:-3px;right:-3px;width:18px;height:18px;background:var(--accent);color:#fff;font-size:9px;font-weight:600;border-radius:50%;display:flex;align-items:center;justify-content:center}.step-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.step-title{font-size:13px;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;width:70px}.step-delete{position:absolute;top:4px;right:4px;width:20px;height:20px;background:transparent;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s}.step-item:hover .step-delete{opacity:1}.step-delete:hover{background:var(--danger);color:#fff}.annotation-canvas-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;position:relative}.canvas-wrapper{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:var(--surface);border:1px solid var(--border)}.canvas-wrapper canvas{display:block}.canvas-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#ffffffe6;z-index:10;border-radius:var(--radius-lg)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.canvas-hint{position:absolute;bottom:16px;left:50%;transform:translate(-50%);padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;color:var(--text-muted);white-space:nowrap;pointer-events:none;opacity:.9}.canvas-wrapper .canvas-container{border-radius:var(--radius-lg)}.upper-canvas{border-radius:var(--radius-lg)!important}.step-details{padding:20px}.details-section{margin-bottom:24px}.section-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.section-title .count{background:var(--surface-light);padding:2px 8px;border-radius:10px;font-size:11px;color:var(--text-muted)}.meta-list{display:flex;flex-direction:column;gap:12px}.meta-item{display:flex;flex-direction:column;gap:4px}.meta-label{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.meta-value{font-size:13px;color:var(--text);word-break:break-word}.meta-value.code{font-family:SF Mono,Monaco,monospace;font-size:12px;background:var(--surface-light);padding:6px 8px;border-radius:var(--radius-sm);color:var(--text-secondary);border:1px solid var(--border)}.meta-value.link{color:var(--primary)}.meta-value.link:hover{text-decoration:underline}.annotations-list{list-style:none;display:flex;flex-direction:column;gap:8px}.annotation-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface-light);border:1px solid var(--border);border-radius:var(--radius-md);transition:background .2s}.annotation-item:hover{background:var(--surface-hover)}.annotation-type{width:24px;height:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:14px}.annotation-info{flex:1;font-size:13px;color:var(--text-secondary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.annotation-color{width:16px;height:16px;border-radius:4px;flex-shrink:0;border:1px solid var(--border)}.annotation-delete{width:20px;height:20px;background:transparent;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s}.annotation-item:hover .annotation-delete{opacity:1}.annotation-delete:hover{background:var(--danger);color:#fff}.share-popover-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300}.share-popover{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-height:70vh;overflow-y:auto;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 8px 24px #0000001f;z-index:301;padding:20px;display:flex;flex-direction:column;gap:14px}.share-popover h3{margin:0;font-size:15px;font-weight:600;color:#111827}.share-invite-form{display:flex;flex-direction:column;gap:8px}.share-invite-row{display:flex;gap:8px}.share-invite-row input[type=email]{flex:1;padding:7px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;outline:none}.share-invite-row input[type=email]:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f126}.share-role-select{padding:7px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;background:#fff;cursor:pointer;outline:none}.share-invite-btn{padding:7px 14px;background:#6366f1;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap}.share-invite-btn:disabled{opacity:.6;cursor:not-allowed}.share-section{display:flex;flex-direction:column;gap:8px}.share-section-header{display:flex;align-items:center;justify-content:space-between}.share-section-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.manage-btn{padding:4px 10px;background:transparent;border:1px solid #e5e7eb;border-radius:5px;font-size:12px;color:#6366f1;cursor:pointer;font-weight:500}.manage-btn:hover{background:#f5f3ff;border-color:#c4b5fd}.avatar-stack{display:flex;align-items:center;gap:4px}.avatar-stack .avatar{margin-right:-6px;border:2px solid #fff}.avatar-stack .avatar:last-of-type{margin-right:0}.avatar-overflow{font-size:12px;color:#6b7280;margin-left:10px}.link-toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer}.link-toggle input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.link-toggle-track{width:36px;height:20px;background:#d1d5db;border-radius:999px;transition:background .2s;position:relative}.link-toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s}.link-toggle input:checked+.link-toggle-track{background:#6366f1}.link-toggle input:checked+.link-toggle-track:after{transform:translate(16px)}.link-toggle input:disabled+.link-toggle-track{opacity:.5;cursor:not-allowed}.link-mode-label{font-size:13px;color:#374151;font-weight:500}.link-public-desc,.link-restricted-desc{font-size:12px;color:#6b7280;margin:0}.public-role-row{display:flex;align-items:center;justify-content:space-between}.public-role-label{font-size:13px;color:#374151}.share-copy-link-btn{width:100%;padding:8px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;cursor:pointer;color:#374151;font-weight:500}.share-copy-link-btn:hover:not(:disabled){background:#e5e7eb}.share-copy-link-btn:disabled{opacity:.6;cursor:not-allowed}.share-feedback{font-size:12px;padding:6px 10px;border-radius:6px}.share-feedback.success{background:#d1fae5;color:#065f46}.share-feedback.error{background:#fee2e2;color:#991b1b}.share-role-badge{align-items:center;justify-content:center;padding:2px 8px;font-size:11px;font-weight:600;border-radius:999px;text-transform:capitalize;height:auto!important}.share-role-badge.owner{background:#ede9fe;color:#5b21b6}.share-role-badge.editor{background:#dbeafe;color:#1e40af}.share-role-badge.viewer{background:#f3f4f6;color:#374151}.share-divider{border:none;border-top:1px solid #e5e7eb;margin:0}.share-loading{font-size:13px;color:#9ca3af;text-align:center;padding:8px 0}.manage-collaborators-view{display:flex;flex-direction:column;gap:12px}.manage-header{display:flex;align-items:center;gap:10px}.back-btn{background:transparent;border:none;font-size:18px;cursor:pointer;color:#374151;padding:2px 6px;border-radius:4px;line-height:1}.back-btn:hover{background:#f3f4f6}.manage-title{font-size:15px;font-weight:600;color:#111827}.collaborator-list{display:flex;flex-direction:column;gap:4px}.collaborator-list.scrollable{max-height:280px;overflow-y:auto;padding-right:8px}.collaborator-list.scrollable::-webkit-scrollbar{width:6px}.collaborator-list.scrollable::-webkit-scrollbar-track{background:transparent}.collaborator-list.scrollable::-webkit-scrollbar-thumb{background:#9ca3af4d;border-radius:3px}.collaborator-list.scrollable::-webkit-scrollbar-thumb:hover{background:#9ca3af80}.collaborator-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid #f3f4f6}.collaborator-row:last-child{border-bottom:none}.collaborator-info{flex:1;min-width:0}.collaborator-name{font-size:13px;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collaborator-email{font-size:11px;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.remove-btn{padding:4px 10px;background:transparent;border:1px solid #e5e7eb;border-radius:5px;font-size:12px;color:#ef4444;cursor:pointer;white-space:nowrap}.remove-btn:hover:not(:disabled){background:#fee2e2;border-color:#fca5a5}.remove-btn:disabled{opacity:.5;cursor:not-allowed}.editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);gap:20px;position:relative;z-index:200}.toolbar-left{display:flex;align-items:center;gap:12px;min-width:0}.guide-title-input{background:transparent;border:none;font-size:18px;font-weight:600;color:var(--text);padding:8px 0;min-width:200px;max-width:400px;text-overflow:ellipsis}.guide-title-input:focus{outline:none}.guide-title-input::placeholder{color:var(--text-muted)}.unsaved-indicator{font-size:12px;color:var(--warning);padding:4px 10px;background:#f59e0b1a;border-radius:12px;flex-shrink:0}.toolbar-center{display:flex;align-items:center;gap:12px}.tool-group{display:flex;background:var(--surface-light);border:1px solid var(--border);border-radius:var(--radius-md);padding:4px;gap:4px}.tool-btn{width:36px;height:36px;background:transparent;border:none;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.tool-btn:hover{background:var(--surface-hover);color:var(--text)}.tool-btn.active{background:var(--primary);color:#fff}.tool-divider{width:1px;height:24px;background:var(--border)}.color-picker{display:flex;gap:6px;padding:6px;background:var(--surface-light);border:1px solid var(--border);border-radius:var(--radius-md)}.color-btn{width:24px;height:24px;border:2px solid transparent;border-radius:50%;cursor:pointer;transition:all .2s}.color-btn:hover{transform:scale(1.1)}.color-btn.active{border-color:var(--primary);box-shadow:0 0 0 2px #0000001a}.toolbar-right{display:flex;align-items:center;gap:10px}.toggle-btn{padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.toggle-btn:hover{border-color:var(--border-light)}.toggle-btn.active{background:#22c55e1a;border-color:var(--success);color:#15803d}@media (max-width: 1200px){.toolbar-center{display:none}}@media (max-width: 768px){.editor-toolbar{flex-wrap:wrap;gap:12px}.toolbar-left,.toolbar-right{width:100%;justify-content:center}}.share-btn-wrapper{position:relative}.tool-btn:disabled,.color-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.dialog{background:var(--surface, #fff);border-radius:12px;width:480px;max-width:calc(100vw - 32px);max-height:90vh;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;overflow:hidden}.dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border, #e5e7eb)}.dialog-header h2{font-size:18px;font-weight:600;color:var(--text, #111);margin:0}.dialog-close{background:none;border:none;font-size:16px;color:var(--text-muted, #6b7280);cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1}.dialog-close:hover{background:var(--border, #e5e7eb)}.dialog-body{padding:20px 24px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;flex:1}.dialog-field{display:flex;flex-direction:column;gap:6px}.dialog-field label{font-size:13px;font-weight:500;color:var(--text-secondary, #374151)}.optional{font-weight:400;color:var(--text-muted, #9ca3af)}.dialog-input{padding:8px 12px;border:1px solid var(--border, #d1d5db);border-radius:8px;font-size:14px;color:var(--text, #111);background:var(--bg, #fff);outline:none;transition:border-color .15s;width:100%;box-sizing:border-box}.dialog-input:focus{border-color:var(--primary, #7c3aed)}.dialog-input.input-error{border-color:#ef4444}.dialog-textarea{resize:vertical;min-height:60px;font-family:inherit;line-height:1.5}select.dialog-input{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drop-zone{border:2px dashed var(--border, #d1d5db);border-radius:10px;min-height:160px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s,background .15s;overflow:hidden}.drop-zone:hover,.drop-zone.dragging{border-color:var(--primary, #7c3aed);background:#7c3aed0a}.drop-zone.has-preview{border-style:solid;min-height:unset}.drop-zone-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;padding:24px;text-align:center}.drop-zone-icon{font-size:32px}.drop-zone-placeholder p{font-size:14px;color:var(--text-secondary, #6b7280);margin:0}.drop-zone-link{color:var(--primary, #7c3aed);font-weight:500}.drop-zone-hint{font-size:12px!important;color:var(--text-muted, #9ca3af)!important}.drop-zone-preview{width:100%;height:auto;display:block;max-height:220px;object-fit:contain}.remove-image{font-size:12px;color:var(--text-muted, #9ca3af);margin-top:4px;align-self:flex-start;padding:3px}.remove-image:hover{color:#ef4444}.dialog-error{font-size:13px;color:#ef4444;margin:0}.dialog-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px 20px;border-top:1px solid var(--border, #e5e7eb)}.editor{display:flex;flex-direction:column;height:calc(100vh - 64px);overflow:hidden}.editor-loading,.editor-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100vh - 64px);gap:16px}.editor-error h2{font-size:24px;color:var(--text)}.editor-error p{color:var(--text-muted);margin-bottom:16px}.editor-content{display:flex;flex:1;overflow:hidden}.editor-sidebar{width:280px;background:#fffffff2;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.sidebar-header h3{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.step-count{background:var(--surface-light);padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600;color:var(--text-muted)}.steps-list{flex:1;overflow-y:auto;padding:12px}.editor-main{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;background-image:url(/images/background-noise.webp);background-repeat:repeat;background-attachment:fixed;overflow:auto}.no-step-selected{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-muted)}.editor-details{width:320px;background:#fffffff2;border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}@media (max-width: 1200px){.editor-sidebar{width:240px}.editor-details{width:280px}}@media (max-width: 900px){.editor-content{flex-direction:column}.editor-sidebar{width:100%;height:150px;border-right:none;border-bottom:1px solid var(--border)}.steps-list{display:flex;gap:8px;padding:8px;overflow-x:auto}.editor-details{width:100%;height:200px;border-left:none;border-top:1px solid var(--border)}}.sidebar-header-actions{display:flex;align-items:center;gap:8px}.btn-add-step{width:26px;height:26px;border-radius:6px;border:none;background:var(--primary, #7c3aed);color:#fff;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.btn-add-step:hover{background:var(--primary-light)}.viewer{min-height:100vh;display:flex;flex-direction:column}.viewer-loading,.viewer-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;padding:24px;text-align:center}.error-icon{font-size:64px;margin-bottom:16px}.viewer-error h1{font-size:28px;color:var(--text)}.viewer-error p{margin-bottom:24px;color:var(--text-secondary)}.viewer-header-container{position:sticky;top:0;z-index:100;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.viewer-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:64px;border-bottom:1px solid var(--border);gap:12px}.viewer-logo{display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;flex-shrink:0}.viewer-logo .logo-icon{width:32px;height:32px;object-fit:contain}.viewer-logo .logo-text{font-size:20px;font-weight:700;color:#1a2f5c}.header-center{flex:1;text-align:center;min-width:0}.guide-title{font-size:18px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.step-indicator{font-size:14px;color:var(--text-secondary);background:var(--surface-light);padding:6px 12px;border-radius:var(--radius-md);white-space:nowrap}.progress-bar{height:2px;background:var(--surface-light)}.progress-fill{height:100%;background:var(--primary);transition:width .3s ease}.viewer-main{flex:1;padding:24px}.viewer-layout{display:flex;gap:32px;max-width:1400px;margin:0 auto}.viewer-sidebar{width:260px;flex-shrink:0;position:sticky;top:88px;max-height:calc(100vh - 104px);display:flex;flex-direction:column;overflow:hidden}.sidebar-title{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.steps-nav{display:flex;flex-direction:column;gap:8px;padding:4px;overflow-y:auto;flex:1;scrollbar-width:none;scroll-behavior:smooth}.steps-nav::-webkit-scrollbar{display:none}.step-nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;text-align:left}.step-nav-item:hover{border-color:var(--border-light);background:var(--surface-light);transform:translate(2px)}.step-nav-item.active{border-color:var(--primary);background:#24428214}.step-nav-number{width:28px;height:28px;background:var(--surface-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;color:var(--text-secondary);flex-shrink:0}.step-nav-item.active .step-nav-number{background:var(--primary);color:#fff}.step-nav-title{font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.step-content{flex:1;min-width:0}.step-header{margin-bottom:24px}.step-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.step-number{font-size:12px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:8px;background:none;width:auto}.step-title-viewer{font-size:28px;font-weight:600;color:var(--text);margin-top:15px}.screenshot-container{position:relative;display:inline-block;width:100%;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);margin-bottom:24px;box-shadow:var(--shadow-lg);border:1px solid var(--border)}.screenshot{width:100%;height:auto;display:block}.annotations-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible}.annotation{position:absolute;pointer-events:none}.annotation-rect{border-style:solid;border-radius:4px;background:transparent}.annotation-text{font-weight:700;font-family:Inter,sans-serif;text-shadow:1px 1px 3px rgba(0,0,0,.5),-1px -1px 3px rgba(255,255,255,.8);white-space:nowrap}.step-description{font-size:16px;color:var(--text-secondary);line-height:1.7;margin-bottom:20px}.step-meta{margin-bottom:24px;margin-top:8px}.meta-item{color:var(--text-muted);font-size:14px;font-weight:500}.navigation-buttons{display:flex;gap:12px}.viewer-footer{padding:24px;text-align:center;border-top:1px solid var(--border);background:#fffffff2}.viewer-footer p{font-size:14px;color:var(--text-muted)}.print-mode .progress-bar,.print-mode .mobile-meta-bar{display:none!important}.print-mode .pdf-page{width:794px!important;min-height:1123px!important;padding:40px!important}.pdf-page{width:794px;min-height:1123px;padding:40px;background:#fff;box-sizing:border-box}.print-layout{color:#000;padding:20px;width:100%;max-width:100%;margin:0 auto}.print-header{text-align:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #333}.print-layout .print-guide-title{text-align:center;font-size:24px;margin-bottom:10px;color:#000;font-weight:700}.print-step-count{font-size:16px;color:#666;font-weight:500}.print-footer{text-align:center;margin-top:40px;padding-top:20px}.print-footer p{font-size:14px;color:#666}.print-footer a{color:#333;text-decoration:underline}.print-step{page-break-after:always;page-break-inside:avoid;margin-bottom:40px;padding-bottom:20px;border-bottom:1px solid #ddd}.print-step:last-child{page-break-after:auto;border-bottom:none}.print-step .step-header{margin-bottom:16px}.print-step .step-number{color:#333}.print-step .step-title-viewer{color:#000;font-size:20px}.print-step .screenshot-container{margin-bottom:16px;box-shadow:none;border:1px solid #ccc}.print-step .screenshot{width:100%;display:block}.print-step .step-description{color:#333;font-size:14px;line-height:1.6}.mobile-meta-bar{display:none}.mobile-guide-title{font-size:17px;font-weight:600;color:var(--text);line-height:1.4;padding:16px 16px 0}.mobile-nav-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 4px;gap:12px}.mobile-step-indicator{font-size:13px;font-weight:500;color:var(--text-secondary);white-space:nowrap}.mobile-nav-buttons{display:flex;gap:8px}.mobile-nav-buttons .btn{padding:7px 14px;font-size:13px}@media (max-width: 1200px){.viewer-sidebar{width:220px;top:80px;max-height:calc(100vh - 96px)}.viewer-layout{gap:24px}.step-title-viewer{font-size:24px}}@media (max-width: 900px){.viewer-header{padding:0 16px;height:56px}.header-center,.step-indicator{display:none}.viewer-header-container{margin-bottom:8px}.mobile-meta-bar{display:block}.mobile-guide-title{margin-bottom:4px}.desktop-nav-row{display:none}.viewer-main{padding:16px}.viewer-layout{flex-direction:column;gap:16px}.viewer-sidebar{display:none}.step-title-viewer{font-size:22px;margin-top:10px}.print-layout .progress-bar,.print-layout .mobile-meta-bar,.print-layout .desktop-nav-row{display:none}.viewer-layout .pdf-page,.pdf-page:not(.print-layout .pdf-page){width:100%;min-height:unset;padding:20px 16px}.print-layout .pdf-page{width:794px!important;min-height:1123px!important;padding:40px!important}}@media (max-width: 600px){.viewer-header{padding:0 12px;height:52px}.viewer-logo .logo-icon{width:28px;height:28px}.viewer-logo .logo-text{font-size:17px}.header-right .btn.btn-secondary{padding:6px 10px;font-size:13px}.mobile-guide-title{font-size:15px;padding:10px 12px 0;margin-bottom:4px}.mobile-nav-row{padding:8px 12px 4px}.mobile-nav-buttons .btn{padding:7px 12px;font-size:13px}.viewer-main{padding:12px}.step-title-viewer{font-size:18px;margin-top:8px}.step-description{font-size:14px}.screenshot-container{border-radius:var(--radius-md);margin-bottom:16px}.viewer-footer{padding:16px}.viewer-layout .pdf-page,.pdf-page:not(.print-layout .pdf-page){width:100%;min-height:unset;padding:16px 12px}.print-layout .pdf-page{width:794px!important;min-height:1123px!important;padding:40px!important}}.auth-page{min-height:100vh;display:flex}.auth-container{flex:1;max-width:480px;display:flex;flex-direction:column;justify-content:center;padding:48px;background:#fffffff2}.auth-header{margin-bottom:32px}.auth-logo{display:flex;align-items:center;gap:8px;margin-bottom:24px}.auth-logo .logo-icon{width:40px;height:40px;object-fit:contain}.auth-logo .logo-text{font-size:24px;font-weight:700;color:#1a2f5c}.logo-cirq{background:linear-gradient(to bottom,#1a2f5c,#1a2f5c 50%,#c8352e 50%,#c8352e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header h1{font-size:28px;margin-bottom:8px;color:var(--text)}.auth-header p{color:var(--text-muted)}.auth-form{margin-bottom:24px}.auth-error{padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#dc2626;font-size:14px;margin-bottom:20px}.auth-submit{width:100%;margin-top:8px}.auth-footer{text-align:center;color:var(--text-muted);font-size:14px}.auth-footer a{color:var(--primary);font-weight:500}.auth-decoration{flex:1;background:var(--primary);display:flex;align-items:center;justify-content:center;padding:48px;position:relative;overflow:hidden}.auth-decoration:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.1) 0%,transparent 40%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 40%)}.decoration-content{position:relative;max-width:400px;text-align:center;color:#fff}.decoration-content h2{font-size:32px;margin-bottom:16px;color:#fff}.decoration-content p{font-size:16px;color:#ffffffe6;margin-bottom:32px;line-height:1.6}.decoration-features{display:flex;flex-direction:column;gap:16px}.feature{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 20px;background:#ffffff26;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff}.feature-icon{font-size:20px}@media (max-width: 900px){.auth-decoration{display:none}.auth-container{max-width:100%;padding:32px}}:root{--primary: #1a2f5c;--primary-light: #3d5a99;--primary-dark: #1a2f5c;--secondary: #666666;--secondary-light: #888888;--accent: #C8352E;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--background: #ffffff;--background-secondary: #f8f8f8;--surface: #ffffff;--surface-light: #f5f5f5;--surface-hover: #ebebeb;--text: #000000;--text-secondary: #444444;--text-muted: #888888;--border: rgba(0, 0, 0, .1);--border-light: rgba(0, 0, 0, .15);--gradient-primary: linear-gradient(135deg, #244282 0%, #5a7cc2 100%);--gradient-surface: linear-gradient(180deg, var(--surface) 0%, var(--background-secondary) 100%);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-glow: 0 0 30px rgba(0, 0, 0, .1);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background-color:var(--background);background-image:url(/images/background-noise.webp);background-repeat:repeat;background-attachment:fixed;color:var(--text);line-height:1.6;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--text)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}p{color:var(--text-secondary)}a{color:var(--primary);text-decoration:none;transition:color .2s}a:hover{color:var(--secondary);text-decoration:underline}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;font-family:inherit;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover:not(:disabled){background:var(--primary-light);transform:translateY(-1px);box-shadow:var(--shadow-lg);color:#fff}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-light)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface-light);color:var(--text)}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:14px 28px;font-size:16px}.btn-icon{padding:10px;width:40px;height:40px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:14px;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.form-input,.form-textarea{width:100%;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-family:inherit;font-size:14px;transition:all .2s}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0000001a}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{min-height:100px;resize:vertical}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;transition:all .2s}.card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--background-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn .3s ease}.animate-slide-in{animation:slideIn .3s ease}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.text-gradient{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.glass{background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border)}
