:root{--color-bg: #E8E0D0;--color-surface: #faf6ef;--color-surface-alt: #efe7d6;--color-border: #d4c4a8;--color-border-light: #e4d8c4;--color-primary: #3a6b1a;--color-primary-dark: #2b5219;--color-primary-bg: #e8f0e0;--color-accent: #c47a1e;--color-accent-light: #f5e8d0;--color-text: #1c1c1a;--color-text-muted: #7a6952;--color-text-subtle: #a8967e;--color-thinking-bg: #f0ead8;--color-thinking-text:#6b5c44;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(44, 30, 10, .08);--shadow-md: 0 4px 12px rgba(44, 30, 10, .1);--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: ui-monospace, "Cascadia Code", "Fira Code", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}[hidden]{display:none!important}html{height:100%}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);min-height:100%;line-height:1.6;-webkit-font-smoothing:antialiased}.login-screen{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 56px);padding:2rem 1rem}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2rem;width:100%;max-width:360px}.login-title{font-size:1.15rem;font-weight:600;color:var(--color-text);margin-bottom:1.5rem}.login-form{display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.35rem}.form-label{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}.form-input{font-family:var(--font-sans);font-size:.95rem;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.6rem .875rem;outline:none;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3a6b1a26}.setup-intro{font-size:.875rem;color:var(--color-text-muted);margin-top:-.75rem;margin-bottom:.5rem}.login-error{font-size:.85rem;color:var(--color-accent);background:var(--color-accent-light);border:1px solid rgba(196,122,30,.3);border-radius:var(--radius-sm);padding:.5rem .75rem}.login-btn{font-family:var(--font-sans);font-size:.9rem;font-weight:600;color:#fff;background:var(--color-primary);border:none;border-radius:var(--radius-md);padding:.65rem 1.4rem;cursor:pointer;transition:background .15s,box-shadow .15s;box-shadow:var(--shadow-sm);margin-top:.25rem}.login-btn:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-md)}.login-btn:disabled{opacity:.55;cursor:not-allowed}.app-header{background:var(--color-primary-dark);border-bottom:3px solid var(--color-accent);padding:0 1.5rem;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-md)}.header-inner{max-width:900px;margin:0 auto;height:56px;display:flex;align-items:center}.logo{display:flex;align-items:center;gap:.6rem}.logo-icon{font-size:1.2rem;color:var(--color-accent);line-height:1}.logo-text{font-size:1rem;font-weight:600;color:#fff;letter-spacing:.01em}.header-actions{margin-left:auto;display:flex;align-items:center;gap:.5rem}.logout-btn{font-family:var(--font-sans);font-size:.78rem;font-weight:500;color:#ffffffbf;background:none;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-sm);padding:.3rem .75rem;cursor:pointer;transition:color .15s,border-color .15s}.logout-btn:hover{color:#fff;border-color:#fff9}.app-main{max-width:900px;margin:0 auto;padding:2rem 1.5rem 4rem;display:flex;flex-direction:column;gap:1.25rem}.section-label{display:block;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:.5rem}.prompt-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.25rem 1rem;box-shadow:var(--shadow-sm)}.prompt-row{display:flex;gap:.75rem;align-items:flex-end}.prompt-textarea{flex:1;font-family:var(--font-sans);font-size:.95rem;line-height:1.55;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.65rem .875rem;resize:vertical;min-height:80px;transition:border-color .15s,box-shadow .15s;outline:none}.prompt-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3a6b1a26}.prompt-textarea:disabled{opacity:.6;cursor:not-allowed}.generate-btn{font-family:var(--font-sans);font-size:.9rem;font-weight:600;color:#fff;background:var(--color-primary);border:none;border-radius:var(--radius-md);padding:.65rem 1.4rem;cursor:pointer;white-space:nowrap;transition:background .15s,transform .1s,box-shadow .15s;box-shadow:var(--shadow-sm)}.generate-btn:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-md)}.generate-btn:active:not(:disabled){transform:translateY(1px)}.generate-btn:disabled{opacity:.55;cursor:not-allowed}.generate-btn--danger{background:#b03a2e}.generate-btn--danger:hover:not(:disabled){background:#922b21;box-shadow:var(--shadow-md)}.thinking-section{background:var(--color-thinking-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.thinking-toggle{width:100%;display:flex;align-items:center;gap:.5rem;padding:.7rem 1.25rem;background:none;border:none;cursor:pointer;text-align:left;color:var(--color-text-muted);font-family:var(--font-sans);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:background .15s}.thinking-toggle:hover{background:#0000000a}.toggle-icon{font-size:.65rem;transition:transform .2s ease;display:inline-block}.thinking-section.is-open .toggle-icon{transform:rotate(90deg)}.thinking-status{margin-left:auto;font-size:.68rem;color:var(--color-accent);font-weight:500;letter-spacing:0;text-transform:none}.thinking-body{height:0;overflow:hidden;transition:height .25s ease}.thinking-section.is-open .thinking-body{height:30vh;overflow-y:auto;border-top:1px solid var(--color-border-light)}.thinking-content{padding:1rem 1.25rem;font-family:var(--font-mono);font-size:.8rem;line-height:1.65;color:var(--color-thinking-text);font-style:italic;white-space:pre-wrap;word-break:break-word}.thinking-placeholder{color:var(--color-text-subtle);font-style:italic;font-family:var(--font-sans)}.content-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-sm);flex:1}.content-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.content-output{font-size:.95rem;line-height:1.75;color:var(--color-text);min-height:120px;white-space:pre-wrap;word-break:break-word}.content-placeholder{color:var(--color-text-subtle);font-style:italic}.copy-btn{font-family:var(--font-sans);font-size:.78rem;font-weight:500;color:var(--color-primary);background:var(--color-primary-bg);border:1px solid rgba(58,107,26,.25);border-radius:var(--radius-sm);padding:.3rem .75rem;cursor:pointer;transition:background .15s,color .15s}.copy-btn:hover{background:var(--color-primary);color:#fff}.copy-btn.copied{background:var(--color-primary-dark);color:#fff}.content-output h1,.content-output h2,.content-output h3,.content-output h4,.thinking-content h1,.thinking-content h2,.thinking-content h3,.thinking-content h4{font-weight:600;line-height:1.3;margin:1.25em 0 .4em;color:var(--color-primary-dark)}.content-output h1{font-size:1.3rem}.content-output h2{font-size:1.1rem}.content-output h3,.thinking-content h1{font-size:1rem}.thinking-content h2,.thinking-content h3{font-size:.9rem}.thinking-content h1,.thinking-content h2,.thinking-content h3{color:var(--color-thinking-text)}.content-output h1:first-child,.content-output h2:first-child,.content-output h3:first-child,.thinking-content h1:first-child,.thinking-content h2:first-child,.thinking-content h3:first-child{margin-top:0}.content-output p,.thinking-content p{margin:.6em 0}.content-output p:first-child,.thinking-content p:first-child{margin-top:0}.content-output p:last-child,.thinking-content p:last-child{margin-bottom:0}.content-output ul,.content-output ol,.thinking-content ul,.thinking-content ol{margin:.6em 0;padding-left:1.5em}.content-output li,.thinking-content li{margin:.25em 0}.content-output strong{font-weight:600;color:var(--color-text)}.content-output em{font-style:italic;color:var(--color-text-muted)}.thinking-content strong{font-weight:600;color:var(--color-thinking-text)}.thinking-content em{font-style:italic}.content-output a,.thinking-content a{color:var(--color-primary);text-decoration:underline;text-underline-offset:2px}.content-output code,.thinking-content code{font-family:var(--font-mono);font-size:.85em;background:var(--color-surface-alt);border:1px solid var(--color-border-light);border-radius:4px;padding:.1em .35em}.content-output pre,.thinking-content pre{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.875rem 1rem;overflow-x:auto;margin:.75em 0}.content-output pre code,.thinking-content pre code{background:none;border:none;padding:0;font-size:.83rem}.content-output blockquote,.thinking-content blockquote{border-left:3px solid var(--color-accent);margin:.75em 0;padding:.25em 0 .25em 1rem;color:var(--color-text-muted);font-style:italic}.content-output hr,.thinking-content hr{border:none;border-top:1px solid var(--color-border);margin:1em 0}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.cursor{display:inline-block;width:2px;height:1em;background:var(--color-accent);vertical-align:text-bottom;margin-left:1px;animation:blink .9s step-end infinite}.tab-bar{background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:56px;z-index:99;box-shadow:var(--shadow-sm)}.tab-bar-inner{max-width:900px;margin:0 auto;padding:0 1.5rem;display:flex}.tab{font-family:var(--font-sans);font-size:.875rem;font-weight:500;color:var(--color-text-muted);text-decoration:none;padding:.75rem 1.25rem;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.tab:hover{color:var(--color-text)}.tab.is-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.selection-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.25rem 1rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.75rem}.selection-tabs{display:flex;gap:0;border-bottom:1px solid var(--color-border);margin:0 -1.25rem;padding:0 1.25rem}.selection-tab{background:none;border:none;border-bottom:2px solid transparent;padding:.4rem .875rem;margin-bottom:-1px;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:color .15s,border-color .15s}.selection-tab:hover{color:var(--color-text)}.selection-tab.is-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.selection-panel{display:flex;flex-direction:column;gap:.75rem}.drive-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.25rem 1rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.75rem}.drive-status-text{margin:0;color:var(--color-text-secondary);font-size:.875rem}.drive-connected-actions{display:flex;gap:.75rem;align-items:center}.drive-picker-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.25rem 1rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.75rem}.drive-search-input{width:100%}.drive-file-list{display:flex;flex-direction:column;gap:.25rem;max-height:240px;overflow-y:auto}.drive-file-item{text-align:left;background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.5rem .75rem;font-size:.875rem;color:var(--color-text);cursor:pointer;transition:background .15s}.drive-file-item:hover{background:var(--color-border)}.drive-loading,.drive-empty{font-size:.875rem;color:var(--color-text-secondary);padding:.5rem 0}.vision-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.25rem 1rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.75rem}.file-upload-row{display:flex;align-items:center;gap:.75rem}.file-input-btn{font-family:var(--font-sans);font-size:.85rem;font-weight:500;color:var(--color-primary);background:var(--color-primary-bg);border:1px solid rgba(58,107,26,.25);border-radius:var(--radius-sm);padding:.35rem .875rem;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}.file-input-btn:hover{background:var(--color-primary);color:#fff}.file-input-hidden{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.vision-file-name{font-size:.875rem;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.vision-prompt-textarea{min-height:56px}.vision-preview{border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border);background:var(--color-surface-alt)}.vision-preview img,.vision-preview video{display:block;width:100%;max-height:300px;object-fit:contain}.vision-actions{display:flex;align-items:center;gap:.875rem}.vision-error{font-size:.85rem;color:var(--color-accent);font-style:italic}.vision-result-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem}.vision-description{font-size:.95rem;line-height:1.7;color:var(--color-text);margin:0}.vision-meta-row{display:flex;gap:1.5rem}.vision-meta-item{display:flex;flex-direction:column;gap:.2rem}.vision-meta-label{font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}.vision-meta-value{font-size:.9rem;font-weight:500;color:var(--color-text);text-transform:capitalize}.vision-meta-group,.vision-notes-row{display:flex;flex-direction:column;gap:.4rem}.vision-notes-row .prompt-textarea{width:100%;box-sizing:border-box}.vision-save-row{display:flex;align-items:center;gap:.875rem;padding-top:.25rem}.vision-save-success{font-size:.85rem;color:var(--color-primary);font-style:italic}.tag-list{display:flex;flex-wrap:wrap;gap:.4rem}.tag{display:inline-block;font-size:.78rem;font-weight:500;color:var(--color-primary);background:var(--color-primary-bg);border:1px solid rgba(58,107,26,.2);border-radius:999px;padding:.2rem .65rem;line-height:1.5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c1c1a80;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:200}.modal-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2rem;width:100%;max-width:360px}.create-user-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.25rem}.cancel-btn{font-family:var(--font-sans);font-size:.9rem;font-weight:500;color:var(--color-text-muted);background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.65rem 1.4rem;cursor:pointer;transition:background .15s}.cancel-btn:hover{background:var(--color-surface-alt)}.create-user-success{font-size:.85rem;color:var(--color-primary);background:var(--color-primary-bg);border:1px solid rgba(58,107,26,.3);border-radius:var(--radius-sm);padding:.5rem .75rem}.image-suggestion-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-sm)}.image-suggestion-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.image-suggestion-match{display:flex;gap:1rem;align-items:flex-start}.suggestion-img{width:120px;height:90px;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--color-border);flex-shrink:0;background:var(--color-surface-alt)}.suggestion-meta{display:flex;flex-direction:column;gap:.5rem;min-width:0}.suggestion-description{font-size:.9rem;line-height:1.55;color:var(--color-text);margin:0}.suggestion-footer{display:flex;align-items:center;gap:.75rem}.suggestion-filename{font-size:.8rem;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.suggestion-score{font-size:.78rem;font-weight:600;color:var(--color-primary);background:var(--color-primary-bg);border:1px solid rgba(58,107,26,.2);border-radius:999px;padding:.15rem .55rem;white-space:nowrap;flex-shrink:0}.suggestion-no-match{font-size:.875rem;color:var(--color-text-muted);font-style:italic;margin:0}.suggestion-error{font-size:.85rem;color:var(--color-accent);font-style:italic}.search-query-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-sm)}.search-results{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem}.search-result-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:row;gap:1rem;align-items:flex-start}.search-result-img{width:110px;height:82px;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--color-border);flex-shrink:0;background:var(--color-surface-alt)}.search-result-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.5rem}.search-result-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.search-result-filename{font-size:.85rem;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.search-result-score{font-size:.78rem;font-weight:600;color:var(--color-primary);background:var(--color-primary-bg);border:1px solid rgba(58,107,26,.2);border-radius:999px;padding:.15rem .55rem;white-space:nowrap;flex-shrink:0}.search-result-description{font-size:.9rem;line-height:1.55;color:var(--color-text);margin:0}.search-result-meta{display:flex;gap:.5rem;flex-wrap:wrap}.search-result-meta-item{font-size:.78rem;color:var(--color-text-muted);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.1rem .45rem}.search-empty{font-size:.875rem;color:var(--color-text-muted);font-style:italic;margin:.5rem 0 0}.drive-breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:.1rem}.drive-crumb{font-family:var(--font-sans);font-size:.8rem;font-weight:500;color:var(--color-primary);background:none;border:none;padding:.15rem .3rem;cursor:pointer;border-radius:var(--radius-sm);transition:background .15s}.drive-crumb:hover:not(:disabled){background:var(--color-primary-bg)}.drive-crumb.is-current{color:var(--color-text);font-weight:600;cursor:default}.drive-crumb-sep{color:var(--color-text-subtle);font-size:.9rem;-webkit-user-select:none;user-select:none;padding:0 .1rem}.drive-folder-list{display:flex;flex-direction:column;gap:.25rem;max-height:240px;overflow-y:auto}.drive-folder-group{display:flex;flex-direction:column;gap:.25rem}.drive-folder-group+.drive-folder-group{margin-top:.5rem}.drive-folder-group-label{display:block;font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);padding:.2rem .1rem}.drive-folder-item{text-align:left;background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.5rem .75rem;font-size:.875rem;color:var(--color-text);cursor:pointer;transition:background .15s}.drive-folder-item:hover{background:var(--color-surface-alt)}.drive-folder-actions{padding-top:.25rem}.drive-folder-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.drive-selected-folder-name{font-size:.875rem;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.drive-batch-section{border-top:1px solid var(--color-border-light);padding-top:.75rem;display:flex;flex-direction:column;gap:.5rem}.drive-batch-controls{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.drive-batch-label{display:flex;align-items:center;gap:.4rem;font-size:.875rem;color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.drive-batch-label input[type=checkbox]{accent-color:var(--color-primary);width:14px;height:14px;cursor:pointer}.drive-job-status{font-size:.85rem;color:var(--color-text-muted);font-style:italic}.drive-job-status--success{color:var(--color-primary);font-style:normal;font-weight:500}.drive-job-status--warning{color:var(--color-accent);font-style:normal;font-weight:500}.drive-job-status--error{color:var(--color-accent);font-style:italic}@media(max-width:640px){.app-main{padding:1.25rem 1rem 3rem}.prompt-row{flex-direction:column;align-items:stretch}.generate-btn{width:100%}}
