*,*:before,*:after{box-sizing:border-box}:root{--bg: #f6f3ee;--bg-warm: #efe9e0;--surface: #fffcf8;--surface-2: #f0ebe3;--border: #e2dcd2;--border-strong: #cfc6b8;--text: #2c2825;--muted: #6b6560;--ink: #0d5c5c;--ink-deep: #084848;--ink-soft: #e8f4f4;--copper: #b8734a;--copper-soft: #faf0e8;--success: #2d7a4f;--warn: #9a7224;--error: #b83c3c;--radius: 14px;--radius-sm: 10px;--shadow: 0 4px 24px rgba(44, 40, 37, .06);--shadow-hover: 0 12px 40px rgba(44, 40, 37, .1);--font: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--mono: "JetBrains Mono", ui-monospace, monospace}html,body,#root{height:100%;margin:0}body{font-family:var(--font);font-size:15px;background:var(--bg);color:var(--text);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.app{position:relative;min-height:100%;display:flex;flex-direction:column}.app-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background-color:var(--bg);background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23d4ccc0' fill-opacity='0.25'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.app-bg-blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.35}.app-bg-blob-1{width:380px;height:380px;background:#a8d4d4;top:-120px;right:-80px}.app-bg-blob-2{width:320px;height:320px;background:#e8c4a8;bottom:-100px;left:-60px}.page-enter{animation:rise .55s cubic-bezier(.22,1,.36,1) both}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow .25s ease,transform .25s ease}.card:hover{box-shadow:var(--shadow-hover)}.header{position:relative;z-index:1;background:#fffcf8d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:1.15rem 1.5rem}.header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:1600px;margin:0 auto}.brand{display:flex;align-items:center;gap:1rem}.brand-mark{flex-shrink:0;line-height:0;transition:transform .3s cubic-bezier(.34,1.4,.64,1)}.brand-mark:hover{transform:rotate(-4deg) scale(1.04)}.brand-mark svg{display:block;filter:drop-shadow(0 4px 12px rgba(13,92,92,.2))}.brand-bg{fill:var(--ink)}.brand-lines{stroke:#fffcf8f2}.brand-corner{fill:var(--copper)}.brand-eyebrow{margin:0 0 .1rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--ink)}.header h1{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.03em;color:var(--text);line-height:1.2}.tagline{margin:.2rem 0 0;font-size:.9rem;color:var(--muted);font-weight:400}.tagline-accent{font-style:italic;font-weight:500;color:var(--copper)}.header-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.2rem;height:1.2rem;padding:0 .35rem;margin-left:.35rem;font-size:.65rem;font-weight:700;background:var(--ink);color:#fff;border-radius:999px}.view-tabs{display:flex;gap:.25rem;padding:.2rem;background:var(--surface-2);border-radius:var(--radius-sm);border:1px solid var(--border);position:relative}.view-tab{font-family:inherit;font-size:.875rem;font-weight:500;padding:.45rem 1rem;border:none;border-radius:8px;background:transparent;color:var(--muted);cursor:pointer;transition:color .2s,background .2s;position:relative;z-index:1}.view-tab:hover:not(.active){color:var(--text)}.view-tab.active{color:var(--ink-deep);background:var(--surface);font-weight:600;box-shadow:0 1px 4px #2c282514}.history-panel{position:relative;z-index:1;background:#fffcf8eb;border-bottom:1px solid var(--border);padding:.85rem 1.5rem 1rem;max-height:220px;overflow-y:auto;animation:rise .4s ease both}.history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;max-width:1600px;margin-left:auto;margin-right:auto}.history-empty{color:var(--muted);font-size:.875rem;margin:0}.history-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:.4rem;max-width:1600px;margin:0 auto}.history-item{display:flex;align-items:stretch;gap:.35rem}.history-load{flex:1;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.55rem .8rem;cursor:pointer;color:inherit;font-family:inherit;transition:border-color .2s,transform .2s,background .2s}.history-load:hover{border-color:var(--ink);background:var(--ink-soft);transform:translate(3px)}.history-name{display:block;font-weight:600;font-size:.875rem}.history-meta{display:block;font-size:.75rem;color:var(--muted)}.history-preview{display:block;font-size:.75rem;color:var(--muted);margin-top:.2rem;font-family:var(--mono)}.history-remove{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--muted);width:2.25rem;cursor:pointer;font-size:1.1rem;transition:all .15s}.history-remove:hover{color:var(--error);border-color:#e8b4b4;background:#fdf5f5}.workspace{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;gap:1.1rem;padding:1.35rem 1.5rem 2rem;max-width:1600px;width:100%;margin:0 auto}.controls-panel{display:flex;flex-direction:column;gap:.9rem;padding:1.25rem 1.35rem}.panel-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink)}.panel-label:before{content:"— ";color:var(--copper);font-weight:400}.dropzone.compact{display:block;position:relative;padding:1.5rem 1.5rem 1.5rem 3.5rem;border:2px dashed var(--border-strong);border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--surface) 0%,var(--ink-soft) 100%);cursor:pointer;overflow:hidden;transition:border-color .25s,transform .25s,box-shadow .25s}.dropzone.compact:before{content:"";position:absolute;left:1.1rem;top:50%;transform:translateY(-50%);width:28px;height:36px;border:2px solid var(--ink);border-radius:4px;opacity:.35;background:linear-gradient(to bottom,transparent 8px,var(--ink) 8px,var(--ink) 10px,transparent 10px,transparent 16px,var(--ink) 16px,var(--ink) 18px,transparent 18px,transparent 24px,var(--ink) 24px,var(--ink) 26px);background-size:100% 100%;transition:opacity .25s}.dropzone.compact:after{content:"+";position:absolute;left:1.65rem;top:50%;transform:translateY(-58%);font-size:1rem;font-weight:700;color:var(--copper);opacity:.8}.dropzone.compact:hover,.dropzone.compact.drag-over{border-color:var(--ink);transform:translateY(-2px);box-shadow:0 8px 28px #0d5c5c1f}.dropzone.compact:hover:before,.dropzone.compact.drag-over:before{opacity:.55}.dropzone-text{text-align:left;color:var(--muted);font-size:.9rem;margin:0}.dropzone-text strong{color:var(--text);font-weight:600}.file-tabs{display:flex;flex-wrap:wrap;gap:.4rem}.file-tab{font-family:inherit;font-size:.8125rem;padding:.35rem .75rem;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:.35rem;max-width:200px;transition:all .2s}.file-tab:hover{border-color:var(--border-strong);color:var(--text)}.file-tab.active{border-color:var(--ink);color:var(--ink-deep);background:var(--ink-soft);font-weight:600}.tab-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tab-ok{color:var(--success)}.tab-err{color:var(--error)}.tab-dot{width:6px;height:6px;border-radius:50%;background:var(--copper);animation:pulse 1.2s ease infinite}@keyframes pulse{50%{opacity:.45}}.options-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.options-grid-3{grid-template-columns:repeat(3,1fr)}.mode-row-span{grid-column:1 / -1}.field-hint{font-size:.75rem;color:var(--muted);margin-top:.2rem}@media(max-width:900px){.options-grid-3{grid-template-columns:1fr 1fr}}@media(max-width:640px){.options-grid,.options-grid-3{grid-template-columns:1fr}.dropzone.compact{padding:1.25rem 1rem 1.25rem 3rem}}.mode-row{display:flex;flex-direction:column;gap:.3rem}.mode-select{font-family:inherit;font-size:.875rem;padding:.5rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:border-color .15s,box-shadow .15s}.mode-select:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px #0d5c5c26}.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.btn{font-family:inherit;font-size:.875rem;font-weight:600;padding:.52rem 1.1rem;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:transform .15s,box-shadow .2s,background .2s}.btn-sm{padding:.3rem .55rem;font-size:.8125rem}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:not(:disabled):active{transform:scale(.98)}.btn-primary{background:linear-gradient(180deg,var(--ink) 0%,var(--ink-deep) 100%);color:#fff;box-shadow:0 2px 8px #0d5c5c40}.btn-primary:hover:not(:disabled){box-shadow:0 4px 16px #0d5c5c59;transform:translateY(-1px)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled),.btn-secondary.active{border-color:var(--ink);color:var(--ink-deep);background:var(--ink-soft)}.btn-ghost{background:transparent;color:var(--muted);border:1px solid transparent}.btn-ghost:hover:not(:disabled){color:var(--text);background:var(--surface-2)}.split-view{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:1rem;min-height:420px}@media(max-width:900px){.split-view{grid-template-columns:1fr}}.split-left,.split-right{display:flex;flex-direction:column;gap:.65rem;min-height:0;padding:1.05rem 1.15rem}.preview-wrap{flex:1;min-height:360px;border-radius:var(--radius-sm);background:var(--bg-warm);border:1px solid var(--border);overflow:hidden;display:flex;align-items:center;justify-content:center;padding:.65rem;position:relative}.preview-wrap.tall{min-height:400px}.preview-wrap img{max-width:100%;max-height:100%;object-fit:contain;border-radius:6px;box-shadow:0 2px 12px #2c282514}.pdf-frame{width:100%;height:100%;min-height:380px;border:none;border-radius:6px;background:#fff}.preview-empty{color:var(--muted);font-size:.875rem;margin:0}.confidence-banner{padding:.6rem .85rem;border-radius:var(--radius-sm);font-size:.875rem;border:1px solid var(--border)}.confidence-high{background:#edf7f0;border-color:#b8dfc4;color:var(--success)}.confidence-medium{background:#faf6ed;border-color:#e8d4a8;color:var(--warn)}.confidence-low{background:#faf0f0;border-color:#e8b4b4;color:var(--error)}.confidence-tag{margin-left:.35rem;text-transform:uppercase;font-size:.65rem;font-weight:700}.output-area{flex:1;min-height:320px;width:100%;padding:.9rem 1rem;font-family:var(--mono);font-size:.8125rem;line-height:1.65;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);resize:vertical;outline:none;transition:border-color .2s,box-shadow .2s}.output-area:focus{border-color:var(--ink);box-shadow:0 0 0 3px #0d5c5c1f}.output-area:disabled{opacity:.6;background:var(--bg-warm)}.output-area::placeholder{color:var(--muted)}.meta{font-size:.8125rem;color:var(--muted);margin:0}.meta span+span:before{content:" · "}.status{padding:.7rem .95rem;border-radius:var(--radius-sm);font-size:.875rem;border-left:3px solid transparent}.status.error{background:#faf0f0;color:var(--error);border-left-color:var(--error)}.status.warn{background:#faf6ed;color:var(--warn);border-left-color:var(--copper)}.status.loading{background:var(--ink-soft);color:var(--ink-deep);border-left-color:var(--ink)}.camera-secure-banner{display:flex;flex-direction:column;gap:.35rem;padding:.9rem 1.1rem}.camera-secure-hint{margin:0;font-size:.875rem;color:var(--muted);line-height:1.55}.camera-secure-link{color:var(--ink);font-weight:600}.camera-code{font-family:var(--mono);font-size:.8rem;background:var(--surface-2);padding:.15rem .4rem;border-radius:4px;border:1px solid var(--border)}.spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .65s linear infinite;vertical-align:-2px;margin-right:.4rem}@keyframes spin{to{transform:rotate(360deg)}}.ai-scan{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;pointer-events:none;overflow:hidden;border-radius:inherit}.ai-scan-shimmer{position:absolute;top:-50%;right:-50%;bottom:-50%;left:-50%;background:conic-gradient(from 0deg,transparent 0deg,rgba(110,231,183,.08) 60deg,rgba(13,92,92,.14) 120deg,rgba(184,115,74,.1) 180deg,transparent 240deg);animation:aiShimmerRotate 4s linear infinite}@keyframes aiShimmerRotate{to{transform:rotate(360deg)}}.ai-scan-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(110,231,183,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(110,231,183,.12) 1px,transparent 1px);background-size:28px 28px;-webkit-mask-image:radial-gradient(ellipse 75% 65% at 50% 50%,#000 20%,transparent 72%);mask-image:radial-gradient(ellipse 75% 65% at 50% 50%,#000 20%,transparent 72%);animation:aiGridDrift 3.5s ease-in-out infinite alternate;opacity:.55}@keyframes aiGridDrift{0%{transform:translate(0);opacity:.35}to{transform:translate(6px,8px);opacity:.65}}.ai-scan-beam{position:absolute;left:6%;right:6%;height:3px;top:0;border-radius:999px;background:linear-gradient(90deg,transparent,rgba(110,231,183,.25),#6ee7b7,rgba(184,115,74,.9),#6ee7b7,rgba(110,231,183,.25),transparent);box-shadow:0 0 18px #6ee7b7bf,0 0 36px #0d5c5c59;animation:aiBeamSweep 2.1s cubic-bezier(.45,0,.25,1) infinite}@keyframes aiBeamSweep{0%{top:8%;opacity:0}8%{opacity:1}92%{opacity:1}to{top:88%;opacity:0}}.ai-scan-nodes{position:absolute;top:0;right:0;bottom:0;left:0}.ai-scan-node{position:absolute;width:5px;height:5px;border-radius:50%;background:#6ee7b7;box-shadow:0 0 10px #6ee7b7e6;animation:aiNodeBlink 1.8s ease-in-out infinite}.ai-scan-node:nth-child(1){left:14%;top:22%;animation-delay:0s}.ai-scan-node:nth-child(2){left:32%;top:38%;animation-delay:.2s}.ai-scan-node:nth-child(3){left:54%;top:18%;animation-delay:.45s}.ai-scan-node:nth-child(4){left:72%;top:30%;animation-delay:.1s}.ai-scan-node:nth-child(5){left:86%;top:48%;animation-delay:.55s}.ai-scan-node:nth-child(6){left:22%;top:62%;animation-delay:.35s}.ai-scan-node:nth-child(7){left:48%;top:72%;animation-delay:.7s}.ai-scan-node:nth-child(8){left:68%;top:58%;animation-delay:.25s}.ai-scan-node:nth-child(9){left:40%;top:52%;animation-delay:.6s}.ai-scan-node:nth-child(10){left:78%;top:76%;animation-delay:.15s}@keyframes aiNodeBlink{0%,to{opacity:.2;transform:scale(.7)}50%{opacity:1;transform:scale(1.15)}}.ai-scan-chip{position:absolute;left:50%;bottom:12%;transform:translate(-50%);display:inline-flex;align-items:center;gap:.45rem;padding:.4rem .85rem;border-radius:999px;background:#0d5c5ce0;border:1px solid rgba(110,231,183,.45);box-shadow:0 8px 28px #00000059;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.ai-scan-chip-pulse{width:8px;height:8px;border-radius:50%;background:#6ee7b7;box-shadow:0 0 12px #6ee7b7;animation:aiChipPulse 1s ease-in-out infinite}@keyframes aiChipPulse{50%{transform:scale(1.35);opacity:.65}}.ai-scan-chip-text{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;white-space:nowrap}.ai-scan--camera .ai-scan-chip{bottom:16%}.ai-scan--preview .ai-scan-chip{bottom:10%}.ai-scan-status{position:relative;overflow:hidden;border-left-color:var(--ink)}.ai-scan-status-track{position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--ink),#6ee7b7,var(--copper));background-size:100% 200%;animation:aiStatusTrack 1.6s ease-in-out infinite}@keyframes aiStatusTrack{0%,to{background-position:0 0%}50%{background-position:0 100%}}.ai-scan-status-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 40%,rgba(110,231,183,.12) 50%,transparent 60%);animation:aiStatusGlow 2.2s ease-in-out infinite}@keyframes aiStatusGlow{0%{transform:translate(-120%)}to{transform:translate(120%)}}.ai-scan-status-content{position:relative;display:inline-flex;align-items:center;gap:.5rem;font-weight:600}.ai-scan-status-icon{width:14px;height:14px;border-radius:50%;border:2px solid var(--ink);border-right-color:#6ee7b7;animation:spin .65s linear infinite;flex-shrink:0}.preview-wrap-scanning{border-color:var(--ink);box-shadow:0 0 0 1px #0d5c5c33,0 0 24px #6ee7b733;animation:previewScanPulse 1.8s ease-in-out infinite}@keyframes previewScanPulse{50%{box-shadow:0 0 0 1px #0d5c5c59,0 0 32px #6ee7b759}}.preview-wrap-scanning img,.preview-wrap-scanning .pdf-frame{filter:saturate(.92) contrast(1.02)}.dropzone-ai-scan{border-color:var(--ink);animation:dropzoneAiPulse 1.6s ease-in-out infinite}.dropzone-ai-scan:before{opacity:.7;animation:dropzoneDocPulse 1.2s ease-in-out infinite}@keyframes dropzoneAiPulse{50%{box-shadow:0 0 0 3px #6ee7b733}}@keyframes dropzoneDocPulse{50%{opacity:1}}.tab-dot-ai{width:7px;height:7px;background:linear-gradient(135deg,var(--ink),#6ee7b7);box-shadow:0 0 8px #6ee7b7b3;animation:tabDotAi .9s ease-in-out infinite}@keyframes tabDotAi{50%{transform:scale(1.35);opacity:.55}}.camera-badge-scan{background:linear-gradient(135deg,var(--ink-deep),#0a7070);box-shadow:0 0 14px #6ee7b773;animation:cameraBadgeScan 1s ease-in-out infinite}@keyframes cameraBadgeScan{50%{box-shadow:0 0 20px #6ee7b7bf}}.hidden-input,.sr-only-input,.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.mobile-file-actions{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.mobile-file-btn{display:inline-flex;align-items:center;justify-content:center;text-align:center;cursor:pointer}label.btn.disabled{opacity:.5;pointer-events:none}.camera-native-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;min-height:360px;padding:1rem;background:var(--bg-warm);color:var(--muted);text-align:center}.camera-last-photo{max-width:100%;max-height:240px;border-radius:var(--radius-sm);object-fit:contain}.preprocess-panel,.read-aloud,.translate-bar,.structured-panel{background:var(--bg-warm);border:1px solid var(--border);border-radius:var(--radius-sm)}.preprocess-panel{display:flex;flex-direction:column;gap:.5rem;padding:.75rem}.preprocess-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.preprocess-val{font-size:.8125rem;color:var(--muted);min-width:2.5rem}.preprocess-slider{display:flex;flex-direction:column;gap:.25rem;font-size:.8125rem;color:var(--muted)}.preprocess-slider input[type=range]{width:100%;accent-color:var(--ink)}.search-replace{display:flex;flex-direction:column;gap:.4rem}.search-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}@media(max-width:640px){.search-row{grid-template-columns:1fr}}.search-input{font-family:inherit;font-size:.875rem;padding:.45rem .65rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text)}.search-input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px #0d5c5c1f}.search-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.search-check{display:flex;align-items:center;gap:.35rem;font-size:.8125rem;color:var(--muted);cursor:pointer}.search-count{font-size:.8125rem;color:var(--muted);margin-right:auto}.structured-panel{overflow:hidden}.structured-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;border-bottom:1px solid var(--border);flex-wrap:wrap}.structured-actions{display:flex;gap:.35rem}.structured-json{margin:0;padding:.75rem 1rem;font-family:var(--mono);font-size:.75rem;line-height:1.5;max-height:220px;overflow:auto;color:var(--success)}.read-aloud,.translate-bar{display:flex;flex-direction:column;gap:.4rem;padding:.65rem .75rem}.read-aloud-row,.translate-row{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem}.read-aloud-meta{font-size:.8125rem;color:var(--muted)}.translate-row .mode-select{min-width:140px;flex:1;max-width:200px}.translate-error{margin:0;font-size:.8125rem;color:var(--error)}.action-progress{position:relative;width:100%;height:6px;border-radius:999px;background:#0d5c5c29;overflow:hidden}.action-progress-bar{display:block;width:42%;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--ink),#6ee7b7,var(--copper));animation:actionProgressSlide 1.2s ease-in-out infinite}@keyframes actionProgressSlide{0%{transform:translate(-120%)}to{transform:translate(240%)}}.voice-visualizer{width:100%;height:74px;display:grid;grid-template-columns:repeat(48,minmax(0,1fr));align-items:end;gap:2px;padding:8px 6px 4px;border-radius:var(--radius-sm);border:1px solid var(--border);background:linear-gradient(180deg,#0d5c5c14,#0d5c5c05)}.voice-visualizer span{height:100%;transform-origin:bottom;border-radius:3px 3px 0 0;background:linear-gradient(180deg,#6ee7b7,var(--ink));transition:transform 55ms linear,opacity 55ms linear}.camera-panel{display:flex;flex-direction:column;gap:.9rem;flex:1;min-height:0}.workspace:has(.camera-panel){min-height:calc(100vh - 140px)}.camera-intro{display:flex;flex-direction:column;gap:.2rem}.camera-toolbar{align-items:center}.camera-status{font-size:.8125rem;color:var(--muted);display:inline-flex;align-items:center;gap:.35rem}.camera-split{display:flex;flex-direction:column;gap:1rem;flex:1;min-height:0}.camera-preview-col{flex:1;min-height:0;display:flex;flex-direction:column}.camera-video-wrap{position:relative;flex:1;width:100%;min-height:clamp(420px,62vh,780px);background:#1a1917;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.camera-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block}.camera-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#a8a29e;background:#1a1917e0;font-size:.875rem;text-align:center;padding:1rem}.camera-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;align-items:center;justify-content:center}.camera-badge{position:absolute;top:.75rem;left:.75rem;background:var(--ink);color:#fff;font-size:.65rem;font-weight:700;padding:.28rem .55rem;border-radius:6px;text-transform:uppercase;letter-spacing:.06em}.camera-text-panel{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0;padding:1rem}.camera-text-panel .output-area{min-height:140px;max-height:220px}@media(max-width:640px){.header,.history-panel,.workspace{padding-left:1rem;padding-right:1rem}.header h1{font-size:1.25rem}.header-row{flex-direction:column;align-items:flex-start}.brand{gap:.75rem}.header-actions{width:100%}.view-tabs{flex:1}.view-tab{flex:1;text-align:center}.btn{min-height:44px}.camera-video-wrap{min-height:clamp(300px,48vh,520px)}.camera-text-panel .output-area{min-height:120px;max-height:180px}.output-area,.search-input,.mode-select{font-size:16px}.split-view{min-height:320px}.translate-row .mode-select{max-width:none;width:100%}.app-bg-blob{opacity:.2}}.app-footer{position:relative;z-index:1;margin-top:auto;padding:1rem 1.75rem 1.35rem;border-top:1px solid var(--border);background:#fffcf8d1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.app-footer-inner{display:flex;flex-direction:column;align-items:flex-end;gap:.45rem;text-align:right;max-width:100%}.app-footer-credit{margin:0;font-size:.8125rem;color:var(--muted)}.app-footer-credit strong{color:var(--text);font-weight:600}.app-footer-links{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.35rem .65rem}.app-footer-link{font-size:.8125rem;font-weight:600;color:var(--ink);text-decoration:none;padding:.2rem .45rem;border-radius:6px;transition:color .2s,background .2s}.app-footer-link:hover{color:var(--ink-deep);background:var(--ink-soft)}.app-footer-link:focus-visible{outline:2px solid var(--ink);outline-offset:2px}@media(max-width:640px){.app-footer{padding-left:1rem;padding-right:1rem}.app-footer-inner{align-items:center;text-align:center}.app-footer-links{justify-content:center}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
