@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Noto+Sans+Thai:wght@300;400;500;600;700&display=swap";:root{--green-900:#0a2e18;--green-800:#0f3e22;--green-700:#14532d;--green-600:#166534;--green-500:#16a34a;--green-400:#22c55e;--green-300:#4ade80;--green-200:#86efac;--green-100:#bbf7d0;--green-50:#f0fdf4;--bg:#fff;--bg-subtle:#f8faf9;--bg-hover:#f0f5f2;--bg-card:#fff;--border:#e2e8f0;--border-strong:#cbd5e1;--text:#1e293b;--text-secondary:#475569;--text-muted:#94a3b8;--accent:var(--green-800);--accent-hover:var(--green-700);--accent-light:var(--green-50);--accent-glow:#16a34a14;--red:#dc2626;--red-light:#fef2f2;--amber:#d97706;--amber-light:#fffbeb;--blue:#2563eb;--blue-light:#eff6ff;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000d;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--radius:10px;--radius-sm:6px;--radius-lg:16px;--transition:.2s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:15px}body{background:var(--bg-subtle);color:var(--text);word-break:break-word;min-height:100vh;font-family:Inter,Noto Sans Thai,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}.bg-grid,.bg-glow{display:none}.app{flex-direction:column;min-height:100vh;display:flex;position:relative}.app-header{z-index:50;background:var(--green-900);color:#fff;justify-content:space-between;align-items:center;height:64px;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:0 1px 3px #0000001f}.header-left{align-items:center;gap:16px;display:flex}.logo-container{flex-direction:column;display:flex}.logo{align-items:center;gap:12px;display:flex}.logo-icon{color:var(--green-300)}.logo-text{color:#fff;letter-spacing:-.02em;font-size:1.15rem;font-weight:700}.logo-sub{color:var(--green-300);text-transform:uppercase;letter-spacing:.06em;margin-top:1px;font-size:.65rem;font-weight:500}.header-actions{align-items:center;gap:10px;display:flex}.btn-menu{border-radius:var(--radius-sm);width:38px;height:38px;color:var(--green-200);cursor:pointer;transition:all var(--transition);background:#ffffff14;border:1px solid #ffffff1f;justify-content:center;align-items:center;display:flex}.btn-menu:hover{color:#fff;background:#ffffff26}.btn-new-session{border-radius:var(--radius-sm);color:#fff;cursor:pointer;transition:all var(--transition);background:#ffffff14;border:1px solid #fff3;align-items:center;gap:8px;padding:8px 18px;font-family:inherit;font-size:.82rem;font-weight:600;display:flex}.btn-new-session:hover{background:#ffffff26}.export-group-header{border-radius:var(--radius-sm);background:#ffffff0f;border:1px solid #ffffff1a;gap:4px;padding:3px;display:flex}.btn-export{cursor:pointer;transition:all var(--transition);text-transform:uppercase;letter-spacing:.04em;border:none;border-radius:4px;align-items:center;gap:5px;padding:5px 10px;font-family:inherit;font-size:.7rem;font-weight:700;display:flex}.btn-export.docx{color:#93bbfc;background:#2563eb26}.btn-export.docx:hover{color:#fff;background:#2563eb4d}.btn-export.xlsx{color:var(--green-300);background:#16a34a26}.btn-export.xlsx:hover{color:#fff;background:#16a34a4d}.btn-export.pptx{color:#fdba74;background:#ea580c26}.btn-export.pptx:hover{color:#fff;background:#ea580c4d}.btn-export.md{color:var(--green-200);background:#ffffff14}.btn-export.md:hover{color:#fff;background:#ffffff26}.app-main{flex:1;width:100%;max-width:880px;margin:0 auto;padding:32px 28px}.upload-section{flex-direction:column;gap:24px;max-width:640px;margin:60px auto;display:flex}.upload-zone{border:2px dashed var(--border-strong);border-radius:var(--radius-lg);background:var(--bg);cursor:pointer;min-height:260px;transition:all var(--transition);justify-content:center;align-items:center;padding:40px;display:flex;position:relative;overflow:hidden}.upload-zone:before{content:"";background:radial-gradient(circle at center, var(--accent-glow) 0%, transparent 70%);opacity:0;transition:opacity .4s;position:absolute;inset:0}.upload-zone:hover:before{opacity:1}.upload-zone:hover{border-color:var(--green-500);box-shadow:0 0 0 4px var(--accent-glow)}.upload-zone.drag-over{border-color:var(--green-400);background:var(--green-50);border-style:solid;box-shadow:0 0 0 4px #22c55e26}.upload-zone.disabled{opacity:.5;pointer-events:none}.upload-zone-content{text-align:center;z-index:1;flex-direction:column;align-items:center;gap:14px;display:flex;position:relative}.upload-icon{background:var(--green-50);width:64px;height:64px;color:var(--green-600);border-radius:50%;justify-content:center;align-items:center;transition:transform .3s;display:flex}.upload-zone:hover .upload-icon{transform:translateY(-4px)}.upload-title{color:var(--text);font-size:1.2rem;font-weight:700}.upload-subtitle{color:var(--text-muted);font-size:.88rem}.upload-formats{gap:8px;margin-top:6px;display:flex}.format-badge{color:var(--green-700);background:var(--green-50);border:1px solid var(--green-100);text-transform:uppercase;letter-spacing:.04em;border-radius:20px;padding:4px 12px;font-size:.7rem;font-weight:700}.upload-file-info{flex-direction:column;gap:4px;display:flex}.upload-file-name{color:var(--green-600);font-size:1rem;font-weight:600}.upload-file-size{color:var(--text-muted);font-size:.8rem}.upload-hint{color:var(--text-muted);font-size:.75rem;font-style:italic}.upload-error{color:#fff;background:var(--red);border-radius:var(--radius-sm);margin-top:8px;padding:10px 14px;font-size:.8rem}.status-indicator{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:28px;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.status-pipeline{flex-direction:column;display:flex}.pipeline-step{align-items:flex-start;gap:16px;padding:12px 0;display:flex;position:relative}.pipeline-step .pipeline-connector{background:var(--border);width:2px;height:18px;position:absolute;top:-6px;left:15px}.pipeline-step .pipeline-connector.filled{background:var(--green-600)}.pipeline-node-circle{background:var(--bg);border:2px solid var(--border);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.pipeline-step.complete .pipeline-node-circle{background:var(--green-600);border-color:var(--green-600);color:#fff}.pipeline-step.active .pipeline-node-circle{border-color:var(--green-500);color:var(--green-500);box-shadow:0 0 0 4px var(--accent-glow)}.pipeline-step.error .pipeline-node-circle{background:var(--red);border-color:var(--red);color:#fff}.pipeline-spinner{border:2px solid #0000;border-top-color:var(--green-500);border-right-color:var(--green-500);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.pipeline-label{align-items:flex-start;gap:10px;min-height:32px;padding-top:5px;display:flex}.pipeline-step-icon{font-size:1rem;line-height:1.4}.pipeline-step-label{color:var(--text-secondary);font-size:.88rem;font-weight:600}.pipeline-step.active .pipeline-step-label,.pipeline-step.complete .pipeline-step-label{color:var(--text)}.pipeline-step-desc{color:var(--text-muted);margin-top:2px;font-size:.78rem}.status-detail{background:var(--green-50);border-left:3px solid var(--green-500);color:var(--text-secondary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-top:14px;padding:12px 16px;font-size:.82rem}.status-detail.error{background:var(--red-light);border-left-color:var(--red);color:var(--red)}.dashboard{flex-direction:column;gap:0;animation:.5s fadeIn;display:flex}.dash-topbar{background:var(--green-900);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;padding:24px 28px;display:flex;position:relative;overflow:hidden}.dash-topbar:after{content:"";pointer-events:none;background:radial-gradient(circle,#4ade8014,#0000 70%);width:200px;height:200px;position:absolute;top:-40px;right:-40px}.dash-meeting-title{color:#fff;font-size:1.5rem;font-weight:800;line-height:1.3}.dash-date{color:var(--green-300);letter-spacing:.02em;margin-top:6px;font-size:.78rem}.dash-attendees{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px;margin-bottom:24px;padding-bottom:24px;display:flex}.attendee-chip{background:var(--bg);border:1px solid var(--border);color:var(--text);box-shadow:var(--shadow-xs);transition:all var(--transition);border-radius:24px;align-items:center;gap:8px;padding:5px 14px 5px 5px;font-size:.82rem;font-weight:500;display:inline-flex}.attendee-chip:hover{box-shadow:var(--shadow-sm);border-color:var(--green-200)}.attendee-avatar{background:linear-gradient(135deg, var(--green-600), var(--green-800));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.72rem;font-weight:700;display:flex}.dash-summary{background:linear-gradient(135deg, var(--green-50), #bbf7d033);border-radius:var(--radius);border-left:4px solid var(--green-500);box-shadow:var(--shadow-xs);margin-bottom:32px;padding:24px}.dash-summary p{color:var(--text);font-size:.95rem;line-height:1.8}.dash-section{margin-bottom:32px}.section-heading{color:var(--text);border-bottom:2px solid var(--green-800);align-items:center;gap:10px;margin-bottom:18px;padding-bottom:14px;font-size:.92rem;font-weight:700;display:flex}.section-heading-risk{border-bottom-color:var(--amber)}.section-icon{background:var(--green-50);width:28px;height:28px;color:var(--green-700);border-radius:6px;justify-content:center;align-items:center;font-size:.82rem;font-weight:700;display:flex}.section-count{background:var(--green-800);color:#fff;border-radius:13px;justify-content:center;align-items:center;min-width:26px;height:26px;margin-left:auto;padding:0 8px;font-size:.72rem;font-weight:700;display:flex}.section-count.risk{background:var(--amber)}.section-count.warning{background:var(--red)}.decision-list{flex-direction:column;gap:12px;display:flex}.decision-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);box-shadow:var(--shadow-xs);padding:20px}.decision-card:hover{box-shadow:var(--shadow-md);border-color:var(--green-200);transform:translateY(-1px)}.decision-card h3{color:var(--text);margin-bottom:8px;font-size:.95rem;font-weight:600}.decision-rationale{color:var(--text-secondary);font-size:.85rem;line-height:1.7}.decision-window{background:var(--green-50);color:var(--green-700);border:1px solid var(--green-100);border-radius:20px;align-items:center;gap:4px;margin-top:10px;padding:4px 12px;font-size:.72rem;font-weight:600;display:inline-flex}.table-wrap{border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow-x:auto}.action-table{border-collapse:collapse;text-align:left;width:100%}.action-table th{text-transform:uppercase;letter-spacing:.06em;color:#fff;background:var(--green-800);border-bottom:2px solid var(--green-700);white-space:nowrap;padding:14px 18px;font-size:.75rem;font-weight:700}.action-table th:first-child{border-radius:var(--radius) 0 0 0}.action-table th:last-child{border-radius:0 var(--radius) 0 0}.action-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:14px 18px;font-size:.88rem}.action-table tr:last-child td{border-bottom:none}.action-table tbody tr{transition:background var(--transition)}.action-table tbody tr:hover{background:var(--green-50)}.col-num{width:44px;color:var(--text-muted);font-weight:700}.col-task{color:var(--text);min-width:200px;font-weight:500}.col-owner{min-width:120px}.col-deadline{min-width:100px;color:var(--text-secondary);font-size:.85rem}.col-context{color:var(--text-muted);min-width:180px;font-size:.85rem}.owner-tag{background:var(--green-50);color:var(--green-700);border:1px solid var(--green-100);border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-block}.owner-tag.unassigned{background:var(--amber-light);color:var(--amber);border-color:#fde68a}.risk-list{flex-direction:column;gap:12px;display:flex}.risk-card{border-radius:var(--radius);box-shadow:var(--shadow-xs);transition:all var(--transition);background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fde68a;padding:20px}.risk-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.risk-card h3{color:var(--text);margin-bottom:8px;font-size:.92rem;font-weight:600}.risk-card p{color:var(--text-secondary);font-size:.85rem;line-height:1.7}.risk-impact{margin-top:10px;font-weight:700;color:var(--red)!important}.topic-list{flex-direction:column;gap:8px;display:flex}.topic-item{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-xs);transition:all var(--transition);overflow:hidden}.topic-item:hover{box-shadow:var(--shadow-sm)}.topic-title{color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition);justify-content:space-between;align-items:center;padding:16px 20px;font-size:.92rem;font-weight:600;list-style:none;display:flex}.topic-title:after{content:"▸";color:var(--text-muted);font-size:.8rem;transition:transform .2s}.topic-item[open] .topic-title:after{transform:rotate(90deg)}.topic-title:hover{background:var(--bg-hover)}.topic-title::marker{display:none}.topic-title::-webkit-details-marker{display:none}.topic-item[open] .topic-title{border-bottom:1px solid var(--border);background:var(--bg-subtle)}.topic-body{padding:16px 20px}.topic-body p{color:var(--text-secondary);font-size:.85rem;line-height:1.8}.topic-nuance{border-top:1px solid var(--border);margin-top:12px;padding-top:12px;font-style:italic}.open-list{flex-direction:column;gap:8px;padding:0;list-style:none;display:flex}.open-list li{color:var(--text);background:var(--red-light);border-radius:var(--radius);transition:all var(--transition);border:1px solid #fecaca;padding:14px 18px 14px 42px;font-size:.88rem;line-height:1.6;position:relative}.open-list li:hover{box-shadow:var(--shadow-sm)}.open-list li:before{content:"?";color:var(--red);justify-content:center;align-items:center;width:18px;height:18px;font-size:.82rem;font-weight:800;display:flex;position:absolute;top:14px;left:16px}.snapshot-strip{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:14px;padding-bottom:12px;display:flex;overflow-x:auto}.snapshot-strip::-webkit-scrollbar{height:6px}.snapshot-strip::-webkit-scrollbar-track{background:var(--bg-subtle);border-radius:3px}.snapshot-strip::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.snapshot-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);min-width:220px;box-shadow:var(--shadow-sm);scroll-snap-align:start;transition:all var(--transition);flex:none;overflow:hidden}.snapshot-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.snapshot-card-label{background:var(--green-800);color:#fff;text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:8px;padding:6px 12px;font-size:.72rem;font-weight:700;display:flex}.snapshot-card img{width:100%;display:block}.dash-transcript{border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-xs);margin-top:24px;overflow:hidden}.dash-transcript summary{color:var(--text-muted);cursor:pointer;background:var(--bg-card);-webkit-user-select:none;user-select:none;transition:all var(--transition);padding:16px 20px;font-size:.88rem;font-weight:600}.dash-transcript summary:hover{background:var(--bg-hover);color:var(--text)}.dash-transcript pre{color:var(--text-secondary);background:var(--bg-subtle);white-space:pre-wrap;word-break:break-word;border-top:1px solid var(--border);max-height:400px;padding:20px;font-size:.82rem;line-height:1.8;overflow-y:auto}.app-footer{text-align:center;border-top:1px solid var(--border);background:var(--bg);padding:20px 28px}.app-footer p{color:var(--text-muted);letter-spacing:.02em;font-size:.72rem}@media (width<=768px){.app-header{height:56px;padding:0 16px}.app-main{padding:20px 16px}.dash-meeting-title{font-size:1.2rem}.dash-topbar{padding:20px}.logo-sub,.export-group-header{display:none}}.sidebar-backdrop{-webkit-backdrop-filter:blur(4px);z-index:100;opacity:0;pointer-events:none;background:#0a2e1866;transition:opacity .3s cubic-bezier(.4,0,.2,1);position:fixed;inset:0}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.history-sidebar{background:var(--bg);width:340px;box-shadow:var(--shadow-xl);z-index:101;flex-direction:column;transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%)}.history-sidebar.open{transform:translate(0)}.history-header{border-bottom:1px solid var(--border);background:var(--green-900);z-index:10;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:sticky;top:0}.history-header h3{color:#fff;letter-spacing:-.01em;font-size:1rem;font-weight:700}.btn-icon{color:var(--green-200);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;transition:all .2s;display:flex}.btn-icon:hover{color:#fff;background:#ffffff1f}.history-list{flex-direction:column;gap:4px;padding:12px;display:flex}.history-status,.history-error{color:var(--text-muted);text-align:center;padding:24px 16px;font-size:.85rem}.history-error{color:var(--red)}.history-item{border-radius:var(--radius-sm);text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;flex-direction:column;gap:4px;padding:14px 16px;transition:all .2s;display:flex}.history-item:hover{background:var(--green-50);border-color:var(--green-100)}.history-item-title{color:var(--text);font-family:Inter,Noto Sans Thai,sans-serif;font-size:.9rem;font-weight:600;line-height:1.35}.history-item-date{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem}.history-item-wrapper{border-radius:var(--radius-sm);transition:background .2s}.history-item-wrapper:hover{background:var(--green-50)}
