*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--ink:#1a1a18;--ink-2:#3d3d39;--ink-3:#6b6b65;--ink-4:#9a9a93;--paper:#f4f1eb;--paper-2:#ece9e1;--paper-3:#e2dfd5;--rule:#ccc9be;--rule-dark:#a8a59a;--accent:#1a1a18;--error:#8b2020;--warn:#7a5c00;--gemini-col:#1a6b3c;--claude-col:#7c4a00;--openai-col:#1a3a6b;--sidebar-w:300px;--font-serif:"EB Garamond", Georgia, serif;--font-mono:"IBM Plex Mono", "Courier New", monospace;--font-sans:"IBM Plex Sans", Helvetica, Arial, sans-serif;--radius:2px;--gap:1px}html,body{background:var(--paper);height:100%;color:var(--ink);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}.app{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);border-right:1px solid var(--rule-dark);background:var(--paper-2);flex-direction:column;display:flex;overflow:hidden}.main{background:var(--paper);flex:1;overflow-y:auto}.sidebar-head{border-bottom:1px solid var(--rule);padding:20px 18px 16px}.logo{align-items:baseline;gap:8px;margin-bottom:4px;display:flex}.logo-mark{font-family:var(--font-serif);color:var(--ink);border:1.5px solid var(--ink);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:28px;font-weight:400;line-height:1;display:flex}.logo-name{font-family:var(--font-mono);letter-spacing:.18em;color:var(--ink);font-size:13px;font-weight:500}.tagline{font-family:var(--font-mono);color:var(--ink-4);letter-spacing:.06em;text-transform:uppercase;font-size:10px}.sidebar-upload{border-bottom:1px solid var(--rule);padding:14px}.upload-zone-wrapper{flex-direction:column;gap:6px;display:flex}.upload-zone{border:1px dashed var(--rule-dark);background:var(--paper);cursor:pointer;text-align:center;-webkit-user-select:none;user-select:none;padding:20px 12px;transition:border-color .15s,background .15s}.upload-zone:hover:not(.disabled){border-color:var(--ink-2);background:var(--paper-2)}.upload-zone.dragging{border-color:var(--ink);background:var(--paper-3);border-style:solid}.upload-zone.disabled{opacity:.5;cursor:not-allowed}.upload-content{flex-direction:column;align-items:center;gap:8px;display:flex}.upload-icon{color:var(--ink-3)}.upload-zone.dragging .upload-icon{color:var(--ink)}.upload-primary{font-family:var(--font-sans);color:var(--ink-2);font-size:13px;font-weight:500}.upload-secondary{font-family:var(--font-mono);color:var(--ink-4);font-size:10px;line-height:1.5}.upload-link{color:var(--ink-2);text-underline-offset:2px;text-decoration:underline}.upload-error{font-family:var(--font-mono);color:var(--error);padding:4px 0;font-size:10px}.sidebar-history{flex:1;padding:10px 0;overflow-y:auto}.history-loading,.history-empty{font-family:var(--font-mono);color:var(--ink-4);text-align:center;padding:12px 16px;font-size:10px}.history-header{justify-content:space-between;align-items:center;padding:0 14px 8px;display:flex}.history-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);font-size:10px}.clear-btn{font-family:var(--font-mono);color:var(--ink-3);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;font-size:10px;text-decoration:underline}.clear-btn:hover{color:var(--error)}.history-list{flex-direction:column;gap:1px;display:flex}.image-card{cursor:pointer;border-left:3px solid #0000;align-items:center;gap:10px;padding:8px 14px;transition:background .1s;display:flex;position:relative}.image-card:hover{background:var(--paper-3)}.image-card.active{background:var(--paper);border-left-color:var(--ink)}.card-thumb{border:1px solid var(--rule);background:var(--paper-3);flex-shrink:0;width:44px;height:44px;position:relative;overflow:hidden}.thumb-img{object-fit:cover;width:100%;height:100%}.thumb-placeholder{background:var(--paper-3);width:100%;height:100%}.thumb-overlay{background:#f4f1ebbf;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.error-overlay{background:#8b20201f}.error-mark{font-family:var(--font-mono);color:var(--error);font-size:18px;font-weight:500}.card-meta{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.card-filename{font-family:var(--font-sans);color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.card-detail{font-family:var(--font-mono);color:var(--ink-4);font-size:10px}.error-text{color:var(--error)}.card-remove{font-family:var(--font-mono);color:var(--ink-4);cursor:pointer;opacity:0;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:16px;line-height:1;transition:opacity .1s,color .1s}.image-card:hover .card-remove{opacity:1}.card-remove:hover{color:var(--error)}.provider-badge{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;border:1px solid;border-radius:1px;padding:1px 5px;font-size:9px;font-weight:500}.provider-badge[data-provider=gemini]{color:var(--gemini-col);border-color:var(--gemini-col)}.provider-badge[data-provider=claude]{color:var(--claude-col);border-color:var(--claude-col)}.provider-badge[data-provider=openai]{color:var(--openai-col);border-color:var(--openai-col)}.spinner{border:2px solid var(--rule);border-top-color:var(--ink);border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-foot{border-top:1px solid var(--rule);flex-direction:column;gap:8px;padding:12px 14px;display:flex}.session-note{font-family:var(--font-mono);color:var(--ink-4);font-size:9px;line-height:1.5}.provider-status{flex-wrap:wrap;gap:5px;display:flex}.provider-status.warn{font-family:var(--font-mono);color:var(--warn);font-size:10px;line-height:1.5}.provider-pill{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--rule);color:var(--ink-3);align-items:center;gap:4px;padding:2px 6px;font-size:9px;display:flex}.provider-pill.ok{border-color:var(--rule-dark)}.provider-pill.limited{opacity:.5}.pill-dot{background:var(--rule-dark);border-radius:50%;width:5px;height:5px}.provider-pill.ok .pill-dot{background:var(--gemini-col)}.pill-count{color:var(--ink-4);font-size:8px}.panel-empty{justify-content:center;align-items:center;height:100%;display:flex}.panel-empty-inner{text-align:center;max-width:280px}.panel-empty-mark{color:var(--rule-dark);margin-bottom:16px;font-size:36px;line-height:1}.panel-empty-text{font-family:var(--font-serif);color:var(--ink-2);margin-bottom:8px;font-size:20px;line-height:1.3}.panel-empty-sub{font-family:var(--font-mono);color:var(--ink-4);font-size:11px}.analysis-panel{max-width:720px;margin:0 auto;padding:40px 48px 80px}.panel-image-wrap{border:1px solid var(--rule-dark);margin-bottom:28px}.panel-image{object-fit:contain;background:var(--paper-3);width:100%;max-height:480px;display:block}.panel-image-skeleton{background:var(--paper-3);width:100%;height:320px;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.panel-header{border-bottom:1px solid var(--rule-dark);margin-bottom:28px;padding-bottom:16px}.panel-title-row{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:10px;display:flex}.panel-filename{font-family:var(--font-serif);color:var(--ink);word-break:break-all;font-size:26px;font-weight:400;line-height:1.2}.panel-stats{font-family:var(--font-mono);color:var(--ink-4);white-space:nowrap;flex-shrink:0;gap:12px;font-size:10px;display:flex}.panel-original-name{font-family:var(--font-mono);color:var(--ink-4);margin-top:-6px;margin-bottom:6px;font-size:10px}.panel-model-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.model-label{font-family:var(--font-mono);color:var(--ink-4);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.model-name{font-family:var(--font-mono);color:var(--ink-2);font-size:11px;font-weight:500}.model-name[data-provider=gemini]{color:var(--gemini-col)}.model-name[data-provider=claude]{color:var(--claude-col)}.model-name[data-provider=openai]{color:var(--openai-col)}.model-provider{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);border:1px solid var(--rule);padding:1px 5px;font-size:9px}.status-dot{background:var(--rule-dark);border-radius:50%;width:7px;height:7px}.status-dot.done{background:#2a7a4a}.panel-body{min-height:180px}.analysis-loading{flex-direction:column;gap:14px;display:flex}.loading-bar{background:var(--rule);height:2px;overflow:hidden}.loading-bar-fill{background:var(--ink-2);width:40%;height:100%;animation:1.4s ease-in-out infinite loading-slide}@keyframes loading-slide{0%{transform:translate(-200%)}to{transform:translate(400%)}}.loading-text{font-family:var(--font-serif);color:var(--ink-2);font-size:20px;font-style:italic}.loading-sub{font-family:var(--font-mono);color:var(--ink-4);font-size:11px}.analysis-error{border-left:3px solid var(--error);flex-direction:column;gap:8px;padding-left:16px;display:flex}.error-label{font-family:var(--font-mono);color:var(--error);text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:500}.error-message{font-family:var(--font-sans);color:var(--ink-2);font-size:13px}.error-hint{font-family:var(--font-mono);color:var(--ink-4);font-size:10px}.analysis-text{flex-direction:column;gap:20px;display:flex}.analysis-text p{font-family:var(--font-serif);color:var(--ink);text-align:justify;-webkit-hyphens:auto;hyphens:auto;font-size:19px;line-height:1.72}.analysis-text p:first-child:first-letter{float:left;color:var(--ink);margin-top:4px;margin-right:6px;font-size:58px;font-weight:500;line-height:.85}.panel-footer{border-top:1px solid var(--rule);font-family:var(--font-mono);color:var(--ink-4);gap:16px;margin-top:40px;padding-top:14px;font-size:10px;display:flex}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--rule-dark);border-radius:0}::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}@media (max-width:700px){.app{flex-direction:column;height:auto;min-height:100vh;overflow:auto}.sidebar{width:100%;min-width:unset;border-right:none;border-bottom:1px solid var(--rule-dark)}.main{overflow:visible}.analysis-panel{padding:24px 20px 48px}.panel-filename{font-size:22px}.analysis-text p{font-size:17px}}::selection{background:var(--ink);color:var(--paper)}.audio-player-wrap{border-top:1px solid var(--rule);margin-top:32px;padding-top:20px}.audio-player{flex-direction:column;gap:8px;display:flex}.audio-progress-wrap{background:var(--rule);height:2px;overflow:hidden}.audio-progress-fill{background:var(--ink-2);height:100%;transition:width .2s linear}.audio-player.generating .audio-progress-fill,.audio-player.saving .audio-progress-fill{animation:1.4s ease-in-out infinite loading-slide;width:40%!important}.audio-controls{align-items:center;gap:10px;display:flex}.audio-btn-main{border:1px solid var(--rule-dark);background:var(--paper-2);width:30px;height:30px;color:var(--ink);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;transition:background .1s,border-color .1s;display:flex}.audio-btn-main:hover:not(:disabled){background:var(--paper-3);border-color:var(--ink-2)}.audio-btn-main:disabled{opacity:.5;cursor:not-allowed}.audio-player.playing .audio-btn-main{border-color:var(--ink);background:var(--ink);color:var(--paper)}.audio-info{flex:1;align-items:baseline;gap:8px;min-width:0;display:flex}.audio-status-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);white-space:nowrap;font-size:10px}.audio-player.playing .audio-status-label{color:var(--ink)}.audio-time{font-family:var(--font-mono);color:var(--ink-4);white-space:nowrap;font-size:10px}.audio-btn-secondary{border:1px solid var(--rule);width:24px;height:24px;color:var(--ink-3);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;transition:border-color .1s,color .1s;display:flex}.audio-btn-secondary:hover{border-color:var(--rule-dark);color:var(--ink)}.audio-btn-discard{font-family:var(--font-mono);color:var(--ink-4);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:14px;line-height:1;transition:color .1s}.audio-btn-discard:hover{color:var(--error)}.audio-spinner{border:1.5px solid var(--rule-dark);border-top-color:var(--ink);border-radius:50%;width:12px;height:12px;animation:.7s linear infinite spin;display:block}.audio-error{font-family:var(--font-mono);color:var(--error);padding-left:40px;font-size:10px}.upload-mobile{border:1px solid var(--rule-dark);align-items:stretch;gap:0;display:flex}.upload-mobile.disabled{opacity:.5;pointer-events:none}.upload-mobile-btn{background:var(--paper);cursor:pointer;color:var(--ink-2);-webkit-tap-highlight-color:transparent;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:5px;padding:16px 10px;transition:background .1s;display:flex}.upload-mobile-btn:active:not(:disabled){background:var(--paper-3)}.upload-mobile-btn.camera{background:var(--paper-2);border-right:1px solid var(--rule)}.upload-mobile-btn.camera:active:not(:disabled){background:var(--paper-3)}.upload-mobile-label{font-family:var(--font-sans);color:var(--ink);font-size:13px;font-weight:500}.upload-mobile-sub{font-family:var(--font-mono);color:var(--ink-4);text-align:center;font-size:9px}.upload-mobile-divider{width:28px;font-family:var(--font-mono);color:var(--ink-4);background:var(--paper-2);border-left:1px solid var(--rule);border-right:1px solid var(--rule);writing-mode:vertical-rl;letter-spacing:.1em;flex-shrink:0;justify-content:center;align-items:center;font-size:9px;display:flex}
