@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Inter:wght@400;500;600&display=swap";
:root{--bg-primary:#f4f5fb;--bg-secondary:#fff;--bg-glass:#fffc;--border-color:#14142b1a;--text-primary:#1e1e2e;--text-secondary:#6b7280;--accent-primary:#8b5cf6;--accent-secondary:#d946ef;--accent-gradient:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));--success:#10b981;--warning:#f59e0b;--error:#ef4444;--font-heading:"Outfit", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);background-image:radial-gradient(circle at 12% 18%,#8b5cf61f,#0000 32%),radial-gradient(circle at 88% 12%,#d946ef1a,#0000 34%),radial-gradient(circle at 75% 90%,#6366f114,#0000 30%);background-attachment:fixed;min-height:100vh;line-height:1.5;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600}.text-accent{color:var(--accent-primary)}.glass-panel{background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 10px 34px #14142b12}.btn{font-weight:500;font-family:var(--font-body);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 14px #8b5cf64d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 22px #8b5cf666}.btn-primary:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);background:#14142b0a}.btn-secondary:hover{background:#14142b14}.dropzone{border:2px dashed var(--border-color);text-align:center;cursor:pointer;background:#14142b05;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;min-height:260px;padding:48px 24px;transition:all .3s;display:flex}.dropzone:hover,.dropzone.active{border-color:var(--accent-primary);background:#8b5cf612}.dropzone-icon{width:64px;height:64px;color:var(--accent-primary);opacity:.9;margin-bottom:16px}.dropzone-title{margin-bottom:8px;font-size:20px}.dropzone-desc{color:var(--text-secondary);font-size:14px}.image-preview-container{border:1px solid var(--border-color);background:#eef0f6;border-radius:16px;position:relative;overflow:hidden}.image-preview{width:100%;height:auto;display:block}.remove-image-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;cursor:pointer;background:#14142b8c;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex;position:absolute;top:12px;right:12px}.remove-image-btn:hover{background:var(--error)}.loading-state{flex-direction:column;justify-content:center;align-items:center;gap:20px;padding:60px 20px;display:flex}.spinner{border:4px solid #8b5cf633;border-top-color:var(--accent-primary);border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.status-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;display:grid}.status-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:transform .2s,box-shadow .2s}.status-card:hover{transform:translateY(-2px);box-shadow:0 8px 22px #14142b14}.status-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.status-card-title{font-size:16px;font-weight:500}.badge{border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.badge.pass{color:#059669;background:#10b9811f;border:1px solid #10b9814d}.badge.fail{color:#dc2626;background:#ef44441f;border:1px solid #ef44444d}.badge.warning{color:#d97706;background:#f59e0b24;border:1px solid #f59e0b4d}.badge.pending{color:var(--text-secondary);border:1px solid var(--border-color);background:#14142b0f}.violation-list{flex-direction:column;gap:8px;margin-top:16px;display:flex}.violation-item{color:var(--text-secondary);border-left:3px solid var(--error);background:#ef44440f;border-radius:6px;gap:8px;padding:8px 12px;font-size:13px;display:flex}.ocr-text{color:var(--text-secondary);white-space:pre-wrap;border:1px solid var(--border-color);background:#14142b0a;border-radius:8px;max-height:200px;padding:16px;font-family:SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;overflow-y:auto}.tabs{border-bottom:1px solid var(--border-color);gap:8px;margin-bottom:24px;padding-bottom:16px;display:flex}.tab-btn{color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 16px;font-weight:500;transition:all .2s}.tab-btn:hover{color:var(--text-primary);background:#14142b0d}.tab-btn.active{color:var(--accent-primary);background:#8b5cf61f}.extracted-data{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.data-field{border:1px solid var(--border-color);background:#14142b05;border-radius:8px;padding:12px 16px}.data-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:12px}.data-value{font-size:15px;font-weight:500}.text-input{border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);font-family:var(--font-body);border-radius:8px;padding:10px 14px;font-size:14px;transition:border-color .2s}.text-input:focus{border-color:var(--accent-primary);outline:none}.btn-sm{padding:7px 14px;font-size:13px}.btn-google{width:100%}.icon-btn{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;background:#14142b0d;border:none;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:inline-flex}.icon-btn:hover{background:var(--error);color:#fff}.form-error{color:#dc2626;background:#ef444414;border:1px solid #ef444440;border-radius:8px;padding:10px 14px;font-size:14px}.app-shell{min-height:100vh}.app-nav{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);z-index:50;background:#ffffffd9;justify-content:space-between;align-items:center;padding:14px 28px;display:flex;position:sticky;top:0}.app-nav-brand{font-family:var(--font-heading);color:var(--text-primary);align-items:center;gap:8px;font-size:17px;font-weight:600;text-decoration:none;display:flex}.app-nav-user{align-items:center;gap:14px;display:flex}.app-nav-name{color:var(--text-secondary);font-size:14px}.app-nav-link{color:var(--text-secondary);border-radius:7px;align-items:center;gap:5px;padding:6px 10px;font-size:13px;text-decoration:none;transition:all .2s;display:inline-flex}.app-nav-link:hover{color:var(--accent-primary);background:#8b5cf614}.app-main{max-width:1100px;margin:0 auto;padding:36px 24px 64px}.page-loading{justify-content:center;align-items:center;min-height:100vh;display:flex}.page-head{margin-bottom:24px}.page-head-title{align-items:center;gap:8px;margin-bottom:6px;display:flex}.page-head-title h1{margin:0;font-size:28px}.page-head h1{margin-bottom:6px;font-size:28px}.page-head p{color:var(--text-secondary);font-size:15px}.form-field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.form-label{color:var(--text-secondary);font-size:13px;font-weight:500}textarea.text-input{resize:vertical;min-height:80px;font-family:inherit;line-height:1.5}.back-link{color:var(--text-secondary);align-items:center;gap:4px;margin-bottom:14px;font-size:14px;text-decoration:none;display:inline-flex}.back-link:hover{color:var(--accent-primary)}.section-title{margin-bottom:12px;font-size:17px}.empty-state{color:var(--text-secondary);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:48px 20px;display:flex}.muted-text{color:var(--text-secondary);font-size:14px}.inline-form{gap:10px;margin-bottom:20px;padding:14px;display:flex}.inline-form .text-input{flex:1}.stack-form{flex-direction:column;gap:10px;margin-bottom:20px;padding:16px;display:flex}.card-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.entity-card{text-align:left;cursor:pointer;align-items:center;gap:14px;padding:18px;transition:transform .2s,box-shadow .2s;display:flex}.entity-card:hover{transform:translateY(-2px);box-shadow:0 10px 26px #14142b1a}.entity-card-icon{background:#8b5cf61a;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.entity-card-body{flex:1;min-width:0}.entity-card-title{margin-bottom:2px;font-size:16px;font-weight:600}.entity-card-meta{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.entity-card-arrow{color:var(--text-secondary);flex-shrink:0}.two-col{grid-template-columns:1fr;gap:32px;display:grid}@media (min-width:900px){.two-col{grid-template-columns:2fr 1fr}}.member-list{flex-direction:column;display:flex}.member-row{border-bottom:1px solid var(--border-color);align-items:center;gap:10px;padding:12px 16px;display:flex}.member-row:last-child{border-bottom:none}.member-info{flex:1;min-width:0}.member-name{font-size:14px;font-weight:500;display:block}.member-email{color:var(--text-secondary);font-size:12px;display:block}.role-badge{border-radius:12px;padding:3px 9px;font-size:11px;font-weight:600}.role-badge.owner{color:var(--accent-primary);background:#8b5cf61f}.role-badge.member{color:var(--text-secondary);background:#14142b0f}.login-wrap{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{width:100%;max-width:400px;padding:36px 32px}.login-brand{justify-content:center;align-items:center;gap:10px;display:flex}.login-brand h1{font-size:22px}.login-sub{text-align:center;color:var(--text-secondary);margin:8px 0 24px;font-size:14px}.login-tabs{background:#14142b0a;border-radius:10px;gap:6px;margin-bottom:20px;padding:4px;display:flex}.login-tab{font-family:var(--font-body);color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:7px;flex:1;padding:9px;font-size:14px;font-weight:500;transition:all .2s}.login-tab.active{background:var(--bg-secondary);color:var(--accent-primary);box-shadow:0 2px 8px #14142b14}.login-form{flex-direction:column;gap:12px;display:flex}.login-form .btn{margin-top:4px}.login-divider{color:var(--text-secondary);align-items:center;gap:12px;margin:20px 0;font-size:12px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border-color);flex:1;height:1px}.panel-section{margin-bottom:24px;padding:22px}.section-head{align-items:center;gap:12px;margin-bottom:16px;display:flex}.section-head h2{flex:1;align-items:center;gap:8px;font-size:17px;display:flex}.doc-list{flex-direction:column;gap:8px;display:flex}.doc-row{border:1px solid var(--border-color);background:#14142b05;border-radius:8px;align-items:center;gap:10px;padding:10px 14px;display:flex}.doc-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:14px;overflow:hidden}.doc-size{color:var(--text-secondary);font-size:12px}.doc-status{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.doc-status.parsing{color:var(--accent-primary);background:#8b5cf61a;animation:1.4s ease-in-out infinite pulse}.doc-status.failed{color:#dc2626;background:#ef44441a}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.spin-slow{animation:1.6s linear infinite spin}.doc-row-clickable{cursor:pointer;transition:background .18s,border-color .18s}.doc-row-clickable:hover{border-color:var(--accent-primary);background:#8b5cf60f}.doc-row-clickable:hover .doc-name{color:var(--accent-primary)}.doc-row-clickable:focus-visible{outline:2px solid var(--accent-primary);outline-offset:1px}.doc-row.uploading{opacity:.95;background:#8b5cf60d;border-style:dashed}.doc-meta{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;font-size:13px;display:flex}.parsed-text{color:var(--text-primary);white-space:pre-wrap;word-break:break-word;border:1px solid var(--border-color);background:#14142b0a;border-radius:8px;max-height:55vh;margin:0;padding:14px;font-family:SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.55;overflow-y:auto}.runner{grid-template-columns:1fr;gap:24px;display:grid}@media (min-width:860px){.runner{grid-template-columns:340px 1fr}}.runner-hint{color:var(--text-secondary);text-align:center;margin-top:10px;font-size:12px}.runner-result{min-width:0}.results-content{animation:.3s fadein}@keyframes fadein{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.status-ok{color:var(--success);align-items:center;gap:6px;font-size:14px;display:flex}.status-muted{color:var(--text-secondary);font-size:13px}.ocr-note{color:var(--text-secondary);margin-bottom:12px;font-size:14px}.history-list{flex-direction:column;gap:8px;display:flex}.history-row{border:1px solid var(--border-color);cursor:pointer;text-align:left;background:#14142b05;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;transition:background .2s;display:flex}.history-row:hover{background:#8b5cf60f}.history-info{flex:1;min-width:0}.history-product{font-size:14px;font-weight:500;display:block}.history-meta{color:var(--text-secondary);font-size:12px;display:block}.history-badges{flex-shrink:0;gap:6px;display:flex}.mini-badge{border-radius:10px;padding:3px 8px;font-size:11px;font-weight:600}.mini-badge.fail{color:#dc2626;background:#ef44441f}.mini-badge.warning{color:#d97706;background:#f59e0b24}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;background:#14142b73;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);flex-direction:column;width:100%;max-width:760px;max-height:88vh;display:flex}.modal-head{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-head h3{font-size:17px}.modal-body{padding:22px;overflow-y:auto}.modal-image{object-fit:contain;border:1px solid var(--border-color);background:#eef0f6;border-radius:10px;width:100%;max-height:320px}.modal-image-single{margin-bottom:20px}.modal-image-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin-bottom:20px;display:grid}.modal-image-grid .modal-image{max-height:200px}.thumb-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;display:grid}.thumb{aspect-ratio:1;border:1px solid var(--border-color);background:#eef0f6;border-radius:10px;position:relative;overflow:hidden}.thumb img{object-fit:cover;width:100%;height:100%;display:block}.thumb-remove{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#14142b99;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;transition:background .15s;display:flex;position:absolute;top:6px;right:6px}.thumb-remove:hover{background:var(--error)}.thumb-index{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#14142b99;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;position:absolute;bottom:6px;left:6px}.thumb-add{aspect-ratio:1;border:2px dashed var(--border-color);color:var(--text-secondary);cursor:pointer;background:#14142b05;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:4px;font-size:13px;transition:all .2s;display:flex}.thumb-add:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#8b5cf612}
