.detail-label{font-size:1em;color:var(--muted);font-weight:500;margin-bottom:2px}.detail-value{font-size:1.1em;color:var(--text);font-weight:600;word-break:break-word;white-space:pre-line}.detail-value.filename{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block;cursor:pointer}.plan-sidebar{max-width:320px;min-width:260px;width:100%;box-sizing:border-box;display:flex;flex-direction:column;gap:20px}:root{--bg: #ffffff;--surface: #ffffff;--text: #0f172a;--muted: #6b7280;--muted-2: #9ca3af;--accent: #0b69ff;--border: #e5e7eb;--border-2: #d1d5db;--bg-gray: #f3f4f6;--bg-light: #f8fafc;--border-light: #e2e8f0;--text-dark: #374151;--spacing-xs: 8px;--spacing-sm: 12px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 999px;--card-radius: 14px;--shadow-xs: 0 2px 4px rgba(0,0,0,.02);--shadow-sm: 0 2px 8px rgba(0,0,0,.12);--shadow-md: 0 4px 12px rgba(0,0,0,.05);--shadow-lg: 0 6px 12px rgba(11,105,255,.12);--shadow-card: 0 6px 18px rgba(16,24,40,.06);--transition-fast: .2s ease;--transition-base: .3s ease}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial;background:var(--bg);color:var(--text)}.app-root{display:flex;min-height:100vh;background:var(--bg-gray);color:var(--text)}.app-sidebar{width:230px;background:var(--surface);color:var(--text);display:flex;flex-direction:column;padding:var(--spacing-xl) 20px;gap:var(--spacing-lg);border-right:1px solid var(--border);box-shadow:0 1px 3px #0000000a;justify-content:space-between;position:fixed;left:0;top:0;height:100vh;overflow-y:auto;z-index:100}.sidebar-top{display:flex;flex-direction:column;gap:var(--spacing-lg)}.app-brand{width:56px;height:56px;border-radius:18px;background:#0b69ff14;display:flex;align-items:center;justify-content:center;border:1px solid rgba(11,105,255,.12);overflow:hidden;margin:0 auto}.app-brand img{width:100%;height:100%;display:block;border-radius:inherit;object-fit:cover}.app-sidebar nav{display:flex;flex-direction:column;gap:var(--spacing-xs)}.sidebar-footer{position:sticky;bottom:0;background:var(--surface);border-top:1px solid var(--border);padding-top:var(--spacing-md);margin-top:auto;padding-bottom:var(--spacing-md)}.user-info{padding:0 var(--spacing-md) var(--spacing-md);font-size:14px}.user-name{font-weight:600;color:var(--text);margin-bottom:4px}.user-email{font-size:12px;color:var(--muted)}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 14px;border-radius:var(--radius-md);color:var(--muted);font-weight:500;text-decoration:none;transition:background var(--transition-fast),color var(--transition-fast)}.sidebar-link:hover,.sidebar-link:focus-visible{background:var(--bg-gray);color:var(--text)}.sidebar-link.active{background:var(--accent);color:#fff}.logout-btn{width:100%;margin-top:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);font-size:13px}.app-main{flex:1;padding:var(--spacing-lg);overflow-y:auto;max-width:none;margin-left:230px}.page-shell{max-width:none;margin:0;min-height:100%;width:100%}@media (max-width:960px){.app-root{flex-direction:column}.app-sidebar{position:fixed;width:100%;flex-direction:row;align-items:center;padding:var(--spacing-md) 20px;height:auto;z-index:100}.app-sidebar nav{flex-direction:row;flex:1;justify-content:space-around}.sidebar-link{padding:10px var(--spacing-sm);border-radius:10px;font-size:14px}.app-main{margin-left:0;padding:var(--spacing-lg) var(--spacing-md);margin-top:70px}.plan-layout{grid-template-columns:1fr;gap:var(--spacing-md)}.plan-sidebar{order:-1}.sidebar-footer{position:static;border-top:none;padding-top:0;margin-top:0}}.card{background:var(--surface);padding:20px;border-radius:var(--card-radius);box-shadow:var(--shadow-card);border:1px solid rgba(15,23,42,.03)}.card h1,.card h2{margin-top:0;color:var(--text)}.login-card.card{padding:var(--spacing-lg) var(--spacing-md)}.msg{margin-top:8px;padding:10px;border-radius:10px}.msg.success{background:#eff6ff;color:#0369a1}.msg.error{background:#fff1f2;color:#9f1239}.upload-card{display:flex;flex-direction:column;gap:var(--spacing-lg)}.upload-card-header h2{margin:0;font-size:var(--spacing-lg);font-weight:600}.upload-card-header p{margin:6px 0 0;color:var(--muted);font-size:14px}.dropzone{position:relative;border:1px dashed #d0d7e2;border-radius:var(--radius-lg);padding:52px var(--spacing-lg);background:var(--bg-light);cursor:pointer;display:flex;align-items:center;justify-content:center;text-align:center;transition:border-color var(--transition-fast),background var(--transition-fast)}.dropzone.dragover{border-color:#1a73e899;background:#1a73e80d}.upload-drop-inner{display:flex;flex-direction:column;align-items:center;gap:14px;max-width:320px}.upload-icon{width:72px;height:72px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#1a73e81f,#1a73e80a);display:flex;align-items:center;justify-content:center}.upload-drop-title{margin:0;font-weight:600;color:var(--text);font-size:16px}.upload-drop-hint{margin:0;color:var(--muted);font-size:13px}.upload-selected{display:flex;align-items:center;gap:var(--spacing-sm);border-radius:var(--radius-md);border:1px solid var(--border-light);padding:var(--spacing-xs) var(--spacing-sm);background:var(--surface);font-size:14px}.upload-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.visually-hidden{position:absolute;left:-9999px}.upload-meta{margin-top:var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-sm);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:10px var(--spacing-sm);background:var(--bg-light);font-size:13px}.upload-meta span{color:var(--muted);font-weight:500}.upload-meta code{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px var(--spacing-xs);color:var(--text)}.btn,.plan-action-btn{background:var(--accent);border:none;padding:10px 18px;border-radius:var(--radius-full);color:#fff;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:background var(--transition-fast),transform var(--transition-fast);box-shadow:var(--shadow-lg)}.plan-action-btn{font-size:13px;padding:var(--spacing-xs) var(--spacing-sm)}.btn:disabled,.plan-action-btn:disabled{opacity:.6;cursor:not-allowed}.btn.ghost,.plan-action-btn.ghost{background:var(--surface);color:var(--text-dark);border:2px solid var(--border-2);box-shadow:var(--shadow-md)}.btn.ghost:hover,.plan-action-btn.ghost:hover{background:#f9fafb;border-color:var(--muted-2);transform:translateY(-1px)}.btn.danger,.plan-action-btn.danger{background:var(--surface);color:#dc2626;border:2px solid #dc2626;box-shadow:0 2px 4px #dc26261a}.btn.danger:hover,.plan-action-btn.danger:hover{background:#dc2626;color:#fff;transform:translateY(-1px)}.btn-link{background:transparent;border:none;color:var(--accent);text-decoration:underline;cursor:pointer}.progress-bar,.plan-progress-bar{position:relative;height:10px;background:#f1f5f9;border-radius:var(--radius-full);overflow:hidden;margin-top:var(--spacing-xs)}.plan-progress-bar{height:12px}.progress-fill,.plan-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#34d399);transition:width .2s ease}.plan-progress-fill{background:linear-gradient(90deg,var(--accent),#38bdf8)}.plan-layout{display:grid;grid-template-columns:calc(65% - 1.5vw) calc(35% - 1.5vw);gap:3vw;max-width:1200px;width:100%;margin:0 auto;overflow-x:hidden;box-sizing:border-box}.plan-main{display:flex;flex-direction:column;gap:var(--spacing-md);min-width:0}.plan-analysis-card{display:flex;flex-direction:column;gap:var(--spacing-md);min-width:0;width:100%;max-width:1200px;margin:var(--spacing-lg) auto 0;min-height:0;box-sizing:border-box}.plan-analysis-card.card{width:calc(100% - 2px);max-width:1198px}.plan-header{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:var(--spacing-lg);position:relative}.plan-header h1,.plan-header h2{margin-bottom:6px;font-size:30px}.plan-header h2{margin:0;font-size:24px}.plan-header p{margin:0;color:var(--muted)}.plan-status{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);justify-content:flex-end}.plan-chip{display:inline-flex;align-items:center;gap:6px;padding:6px var(--spacing-sm);border-radius:var(--radius-full);font-size:13px;font-weight:600}.plan-chip--success{background:#34d39924;color:#047857}.plan-chip--neutral{background:#f1f5f9;color:#1f2937}.plan-progress{display:flex;flex-direction:column;gap:var(--spacing-xs)}.plan-progress-top{display:flex;justify-content:space-between;align-items:center}.plan-progress-label{margin:0;font-size:13px;color:var(--muted)}.plan-progress-value{font-weight:600;color:var(--text)}.plan-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.plan-details{margin:0;display:grid;gap:var(--spacing-md)}.plan-details div{display:flex;justify-content:space-between;gap:var(--spacing-sm)}.plan-details dt{font-size:13px;color:var(--muted);font-weight:500}.plan-details dd{margin:0;font-weight:600;color:var(--text)}.plan-timeline{list-style:none;margin:0;padding:0;display:grid;gap:14px}.plan-timeline li{display:grid;grid-template-columns:20px 1fr;gap:var(--spacing-sm);align-items:center}.plan-timeline .dot{width:var(--spacing-sm);height:var(--spacing-sm);border-radius:var(--radius-full);background:var(--border-2);position:relative}.plan-timeline li[data-status=complete] .dot{background:#22c55e}.plan-timeline li[data-status=current] .dot{background:var(--accent)}.plan-timeline li strong{display:block;font-size:14px;color:var(--text)}.plan-timeline li span{font-size:12px;color:var(--muted)}.plan-panel{display:flex;flex-direction:column;gap:18px}.plan-panel header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm)}.plan-panel h2{margin:0;color:var(--text);font-size:18px}.plan-stat-list{list-style:none;margin:0;padding:0;display:grid;gap:var(--spacing-sm);font-size:14px}.plan-stat-list li{display:flex;justify-content:space-between;color:var(--text)}.plan-stat-list li span{color:var(--muted)}.plan-note{margin:0;font-size:13px;color:#475569;line-height:1.45}.plan-actions{display:grid;grid-template-columns:1fr;gap:var(--spacing-xs)}@media (max-width:768px){.app-main{padding:var(--spacing-md)}.pages-header,.pages-grid{padding:0 var(--spacing-md)}.plans-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.plan-actions{grid-template-columns:1fr;gap:6px}.pages-header{flex-direction:column;gap:var(--spacing-md);align-items:flex-start}.plan-header{flex-direction:column;gap:var(--spacing-md)}}.plan-selector{margin:var(--spacing-md) 0;padding:var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-light)}.plan-selector-label{display:block;margin-bottom:6px;font-size:14px;font-weight:600;color:var(--text)}.plan-selector-dropdown{width:100%;padding:10px var(--spacing-sm);border:1px solid var(--border-2);border-radius:var(--radius-sm);font-size:14px;background:var(--surface);color:var(--text)}.plan-selector-dropdown:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #0b69ff1a}.modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--surface);border-radius:var(--radius-lg);max-width:90vw;max-height:80vh;overflow:hidden;box-shadow:0 20px 40px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px var(--spacing-lg);border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:18px;color:var(--text)}.modal-body{padding:var(--spacing-lg);max-height:60vh;overflow-y:auto}.pages-grid{display:flex;flex-direction:column;gap:var(--spacing-xl);width:100%;padding:0;box-sizing:border-box}.page-item{background:var(--surface);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-md);border:1px solid var(--border)}.page-number{font-size:14px;font-weight:600;color:var(--muted);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:.5px}.page-image{width:100%;max-width:900px;height:auto;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);display:block;margin:0 auto}.page-filename{font-size:12px;color:var(--muted-2);margin-top:var(--spacing-xs);text-align:center;font-family:monospace}.no-pages{background:var(--bg-light);border:1px dashed var(--border-2);border-radius:var(--radius-md)}.toast{position:fixed;top:20px;right:20px;z-index:1000;max-width:400px;transform:translate(100%);animation:slideIn var(--transition-base) ease-out forwards}.toast-content{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);box-shadow:0 8px 32px #0000001f;border:1px solid rgba(0,0,0,.05)}.toast--success .toast-content{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.toast--error .toast-content{background:#fef2f2;border-color:#fecaca;color:#dc2626}.toast--info .toast-content{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.toast-icon{font-weight:700;font-size:16px;width:20px;text-align:center}.toast-message{flex:1;font-size:14px;font-weight:500}.toast-close{background:none;border:none;font-size:18px;cursor:pointer;opacity:.7;color:inherit;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.toast-close:hover{opacity:1}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.plan-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);box-shadow:var(--shadow-xs)}.plan-card:hover{border-color:var(--border-2);box-shadow:var(--shadow-md);transform:translateY(-1px)}.plan-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.plan-title{margin:0;font-size:16px;font-weight:600;color:var(--text);line-height:1.3}.plan-id{font-family:monospace;font-size:12px;color:var(--muted);background:var(--bg-gray);padding:4px var(--spacing-xs);border-radius:6px}.plan-details{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:20px}.plan-detail{display:flex;justify-content:space-between;align-items:center}.no-plans,.no-plan-selected,.no-pages{text-align:center;padding:60px 20px;color:var(--muted);font-style:normal}.loading-state{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:60px 20px;color:var(--muted)}.loading-spinner{width:var(--spacing-xl);height:var(--spacing-xl);border:3px solid var(--bg-gray);border-top:3px solid var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-gray);padding:var(--spacing-lg);width:100%;margin-left:0;position:fixed;left:0;right:0;top:0;overflow-y:auto}.login-card{width:100%;max-width:400px;margin:0 auto;display:flex;flex-direction:column;align-items:center;position:relative}.login-header{text-align:center;margin-bottom:var(--spacing-md);display:flex;flex-direction:column;align-items:center;width:100%}.login-brand{width:56px;height:56px;border-radius:var(--radius-xl);background:#0b69ff14;display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-sm);border:1px solid rgba(11,105,255,.12);overflow:hidden}.login-brand img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.login-header h1{margin:0 auto 4px;font-size:24px;font-weight:700;color:var(--text);text-align:center;width:100%}.login-header p{margin:0 auto;color:var(--muted);font-size:14px;text-align:center;width:100%}.login-form{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.form-field{display:flex;flex-direction:column;gap:4px}.form-field label{font-size:14px;font-weight:600;color:var(--text)}.form-input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-2);border-radius:var(--radius-md);font-size:14px;background:var(--surface);transition:border-color var(--transition-fast);color:var(--text)}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #0b69ff1a}.form-input::placeholder{color:var(--muted-2)}.form-options{display:flex;justify-content:space-between;align-items:center;font-size:14px;margin-top:4px;width:100%;gap:var(--spacing-md)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;color:var(--text);flex-shrink:0}.checkbox-label input{display:none}.checkbox-custom{width:var(--spacing-md);height:var(--spacing-md);border:2px solid var(--border-2);border-radius:4px;position:relative;transition:background var(--transition-fast),border-color var(--transition-fast)}.checkbox-label input:checked+.checkbox-custom{background:var(--accent);border-color:var(--accent)}.checkbox-label input:checked+.checkbox-custom:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.forgot-link{color:var(--accent);text-decoration:none;font-weight:500;flex-shrink:0;white-space:nowrap}.forgot-link:hover{text-decoration:underline}.login-btn{width:100%;padding:12px;font-size:15px;font-weight:600}.login-footer{text-align:center;margin-bottom:var(--spacing-sm)}.login-footer p{margin:0;font-size:14px;color:var(--muted)}.signup-link{color:var(--accent);text-decoration:none;font-weight:600;margin-left:4px}.signup-link:hover{text-decoration:underline}.login-divider{position:relative;text-align:center;margin:var(--spacing-sm) 0}.login-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border);z-index:0}.login-divider span{position:relative;background:var(--surface);padding:0 var(--spacing-md);color:var(--muted);font-size:13px;z-index:1}.social-login{display:flex;gap:var(--spacing-sm)}.social-btn{flex:1;background:var(--surface);color:var(--text-dark);border:1px solid var(--border-2);box-shadow:none;font-weight:500}.social-btn:hover{background:#f9fafb;border-color:var(--muted-2)}.tab-container{display:flex;gap:var(--spacing-sm);border-bottom:2px solid var(--border);margin-bottom:var(--spacing-lg)}.tab-button{border:none;border-radius:0;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);border-bottom:2px solid transparent;transition:border-color var(--transition-fast)}.tab-button.active{border-bottom:2px solid var(--accent)}.tab-button:not(.active){border-bottom:2px solid transparent}.user-info-link{display:flex;align-items:center;justify-content:space-between;text-decoration:none;color:inherit;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);transition:all var(--transition-fast);margin-bottom:var(--spacing-sm);cursor:pointer;gap:var(--spacing-sm)}.user-info-link:hover{background:var(--bg-gray);border-color:var(--accent);transform:translateY(-1px)}.user-info-link .user-info{flex:1;padding:0;margin:0}.user-info-link .user-name{margin-bottom:2px}.user-info-link .user-email{margin-bottom:0}.user-info-link svg{flex-shrink:0;opacity:.6}.form-options-centered{display:flex;justify-content:center}
