:root{--primary: #2563eb;--primary-dark: #1e40af;--primary-light: #eff6ff;--surface: #ffffff;--surface-alt: #f8fafc;--text-main: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius-lg: 1rem;--radius-md: .75rem;--radius-sm: .5rem}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:#f1f5f9;color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased}.layout-container{height:100dvh;overflow:hidden;display:flex;flex-direction:column;background:radial-gradient(circle at top left,#e0f2fe,transparent 70%),radial-gradient(circle at bottom right,#f0fdf4,transparent 70%)}.top-nav{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--surface);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:10}.nav-brand h1{font-size:1.75rem;font-weight:800;letter-spacing:-.025em;line-height:1;color:#0f172a;margin:0}.nav-brand h1 span{color:var(--primary)}.nav-user{display:flex;align-items:center}.user-info{display:flex;align-items:center;gap:1rem}.user-name{font-size:.95rem;color:var(--text-main)}.btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;border:none}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-dark)}.btn-outline{background-color:transparent;color:var(--text-main);border:1px solid var(--border)}.btn-outline:hover{background-color:var(--surface-alt)}.main-content{flex:1;min-height:0;max-width:1200px;margin:0 auto;padding:2rem;width:100%;display:flex;flex-direction:column;gap:2rem;overflow:hidden}.links-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.service-card{display:flex;flex-direction:row;align-items:center;gap:1rem;background:var(--surface);padding:1.25rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);text-decoration:none;border:1px solid transparent;transition:all .2s ease}.service-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-light)}.card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:var(--radius-sm);color:var(--primary);flex-shrink:0}.card-icon svg{width:24px;height:24px}.card-details h3{font-size:1rem;font-weight:600;color:var(--text-main);margin-bottom:.25rem}.card-details span{font-size:.8rem;color:var(--text-muted)}.chat-section{flex:1;min-height:0;display:flex;flex-direction:column}.chat-container{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;border:1px solid var(--border)}@media(max-width:768px){.top-nav{padding:1rem}.main-content{padding:1rem;gap:1rem}.links-section{grid-template-columns:repeat(4,1fr);gap:.5rem}.service-card{flex-direction:column;padding:.5rem;gap:.25rem;justify-content:center}.card-icon{width:36px;height:36px}.card-icon svg{width:18px;height:18px}.card-details h3{font-size:.75rem;margin:0}.card-details span{display:none}.chat-container{min-height:0}}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border);color:var(--text-main);font-weight:600;flex-wrap:wrap;gap:.5rem}.status-badge{font-size:.7rem;font-weight:600;padding:.25rem .6rem;border-radius:999px;text-transform:uppercase;letter-spacing:.02em}.status-bot{background:var(--primary-light);color:var(--primary)}.status-waiting{background:#fef3c7;color:#b45309}.status-human{background:#dcfce7;color:#15803d}.status-shop-list_building{background:#fef3c7;color:#92400e}.status-shop-shopping{background:#d1fae5;color:#065f46}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;background:#fafafa}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-empty{color:var(--text-muted);text-align:center;margin-top:auto;margin-bottom:auto;font-size:.95rem}.message{max-width:85%;display:flex;flex-direction:column;gap:.25rem}.message-sender{font-size:.7rem;color:var(--text-muted);font-weight:600;margin-left:.25rem}.message p{padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.95rem;line-height:1.5;box-shadow:var(--shadow-sm);word-wrap:break-word}.message-customer{align-self:flex-end;align-items:flex-end}.message-customer p{background:var(--primary);color:#fff;border-bottom-right-radius:2px}.message-customer .message-sender{margin-right:.25rem;margin-left:0}.message-bot p,.message-operator p{background:var(--surface);color:var(--text-main);border-bottom-left-radius:2px}.chat-input-area{padding:1rem 1.5rem;background:var(--surface);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.75rem}.btn-human{align-self:center;background:none;border:1px solid var(--border);padding:.4rem 1rem;font-size:.8rem;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .2s}.btn-human:hover{background:var(--surface-alt);color:var(--text-main)}.chat-input-wrapper{display:flex;gap:.5rem;align-items:flex-end}.chat-input-wrapper textarea{flex:1;resize:none;padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);outline:none;font-family:inherit;font-size:.95rem;line-height:1.5;transition:border-color .2s;background:var(--surface-alt)}.chat-input-wrapper textarea:focus{border-color:var(--primary);background:var(--surface)}.chat-input-wrapper textarea:disabled{opacity:.7;background:#e2e8f0}.btn-mic,.btn-send{padding:.75rem 1.25rem;border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s;height:46px;display:flex;align-items:center;justify-content:center}.btn-mic{background:var(--surface-alt);color:var(--text-main);border:1px solid var(--border);padding:.75rem}.btn-mic:hover:not(:disabled){background:#e2e8f0}.btn-mic-active{background:#fee2e2;color:#dc2626;border-color:#fecaca;animation:pulse 1.5s infinite}.btn-send{background:var(--primary);color:#fff}.btn-send:hover:not(:disabled){background:var(--primary-dark)}.btn-send:disabled{background:var(--text-muted);cursor:not-allowed;opacity:.7}.suggestions-list{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem}.suggestion-btn{text-align:left;padding:.4rem .75rem;border:1px solid var(--primary);border-radius:6px;background:#fff;color:var(--primary);cursor:pointer;font-size:.9rem}.suggestion-btn:hover:not(:disabled){background:var(--primary);color:#fff}.suggestion-btn:disabled{opacity:.4;cursor:default}.suggestion-btn-custom{border-style:dashed;color:var(--text-muted);border-color:var(--text-muted)}.suggestion-btn-custom:hover:not(:disabled){background:var(--text-muted);color:#fff}.list-items,.shopping-items{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.3rem}.list-items li,.shopping-items li{display:flex;align-items:center;gap:.5rem;padding:.3rem .5rem;background:#f8fafc;border-radius:6px;font-size:.9rem}.list-items li span:first-child,.shopping-items li span:first-child{flex:1}.btn-remove{border:none;background:none;color:#dc2626;cursor:pointer;font-size:1rem;padding:0 .25rem}.btn-remove:hover{color:#991b1b}.remove-confirm{display:flex;gap:.3rem}.remove-confirm button{padding:.2rem .5rem;border-radius:4px;border:1px solid #cbd5e1;cursor:pointer;font-size:.85rem}.shopping-actions{display:flex;gap:.3rem}.shopping-actions button{padding:.2rem .5rem;border-radius:4px;border:1px solid #cbd5e1;background:#fff;cursor:pointer;font-size:.85rem}.shopping-actions button:first-child{border-color:#16a34a;color:#16a34a}.shopping-actions button:first-child:hover{background:#16a34a;color:#fff}.shopping-actions button:last-child{border-color:#dc2626;color:#dc2626}.shopping-actions button:last-child:hover{background:#dc2626;color:#fff}.shopping-tab{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.shopping-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border);font-weight:600;gap:.5rem;flex-shrink:0}.shopping-reply{padding:.6rem 1.5rem;font-size:.9rem;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--surface-alt);flex-shrink:0}.shopping-body{flex:1;overflow-y:auto;padding:1rem 1.5rem;display:flex;flex-direction:column;gap:.75rem;background:#fafafa}.shopping-body::-webkit-scrollbar{width:6px}.shopping-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.shopping-input-area{padding:1rem 1.5rem;background:var(--surface);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.catalog-import{padding:1.5rem;max-width:480px}.catalog-import h2{margin-bottom:1.2rem;font-size:1.1rem}.import-form{display:flex;flex-direction:column;gap:.8rem}.import-field{display:flex;flex-direction:column;gap:.25rem;font-size:.9rem;color:var(--text-muted)}.import-field input{padding:.45rem .7rem;border:1px solid var(--border);border-radius:6px;font-size:.95rem;background:var(--surface-alt)}.import-result{margin-top:1rem;padding:.6rem .9rem;border-radius:6px;font-size:.9rem}.import-ok{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.import-err{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.mode-commands{display:flex;gap:.4rem;flex-wrap:wrap}.mode-commands button{padding:.3rem .75rem;border-radius:999px;border:1px solid var(--border);background:var(--surface-alt);font-size:.82rem;cursor:pointer;color:var(--text-muted);transition:all .15s}.mode-commands button:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.available-lists{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.4rem}.available-list-row{display:flex;align-items:center;gap:.4rem}.available-list-btn{flex:1;text-align:left;padding:.4rem .75rem;border:1px solid var(--primary);border-radius:6px;background:#fff;color:var(--primary);cursor:pointer;font-size:.9rem}.available-list-btn:hover:not(:disabled){background:var(--primary);color:#fff}.available-list-btn:disabled{opacity:.4;cursor:default}.btn-archive-list{padding:.3rem .6rem;border:1px solid var(--border);border-radius:6px;background:#fff;color:var(--text-muted);cursor:pointer;font-size:1rem;line-height:1}.btn-archive-list:hover:not(:disabled){background:#fee2e2;color:#dc2626;border-color:#fca5a5}.btn-archive-list:disabled{opacity:.4;cursor:default}@keyframes pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.auth-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.auth-modal-content{background:var(--surface);border-radius:var(--radius-lg);padding:2rem;width:90%;max-width:400px;box-shadow:var(--shadow-lg);position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-muted)}.auth-modal-close:hover{color:var(--text-main)}.settings-panel{background:var(--surface-alt);border-bottom:1px solid var(--border);padding:1rem 1.5rem;display:flex;flex-wrap:wrap;gap:1rem}.settings-row{display:flex;flex-direction:column;font-size:.75rem;color:var(--text-muted);gap:.25rem;min-width:120px}.model-select{font-size:.8rem;padding:.3rem .6rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-alt);color:var(--text-main);cursor:pointer;outline:none}.btn-settings{background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:.25rem;border-radius:50%;transition:background .2s}.auth-box{width:100%}.auth-tabs{display:flex;margin-bottom:1.5rem;border-bottom:1px solid var(--border)}.auth-tabs button{flex:1;padding:.75rem;background:none;border:none;border-bottom:2px solid transparent;font-weight:500;cursor:pointer;color:var(--text-muted)}.auth-tabs button.active{color:var(--primary);border-bottom-color:var(--primary)}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form input{padding:.75rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:inherit}.auth-form button{padding:.75rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:500;cursor:pointer}.auth-error{color:#dc2626;font-size:.875rem}.auth-success{color:#15803d;font-size:.875rem}.tab-bar{display:flex;gap:0;background:var(--surface);border-bottom:1px solid var(--border);padding:0 2rem}.tab-btn{background:none;border:none;border-bottom:2px solid transparent;padding:.75rem 1.25rem;font-size:.95rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:color .2s,border-color .2s}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-btn:hover:not(.active){color:var(--text-main)}.ideas-section{flex:1;display:flex;flex-direction:column}.ideas-layout{display:flex;gap:0;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);flex:1;min-height:560px;max-height:750px;overflow:hidden}.ideas-sidebar{width:260px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface-alt)}.ideas-sidebar-top{display:flex;gap:.5rem;padding:.75rem;border-bottom:1px solid var(--border)}.ideas-search{flex:1;padding:.45rem .7rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;background:var(--surface);outline:none}.ideas-search:focus{border-color:var(--primary)}.ideas-new-btn{font-size:.8rem;padding:.45rem .75rem;white-space:nowrap}.ideas-list{list-style:none;overflow-y:auto;flex:1}.ideas-list-item{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}.ideas-list-item:hover{background:#f1f5f9}.ideas-list-item.active{background:var(--primary-light)}.ideas-list-title{font-size:.9rem;font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ideas-list-summary{font-size:.78rem;color:var(--text-muted);margin-top:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ideas-empty-state{padding:1.5rem 1rem;color:var(--text-muted);font-size:.85rem;text-align:center}.ideas-detail{flex:1;display:flex;flex-direction:column;overflow:hidden}.ideas-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.95rem}.ideas-title-row{display:flex;align-items:center;gap:.75rem;padding:.85rem 1.25rem;border-bottom:1px solid var(--border)}.ideas-title{flex:1;font-size:1.15rem;font-weight:700;cursor:pointer;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ideas-title:hover{color:var(--primary)}.ideas-title-input{flex:1;font-size:1.15rem;font-weight:700;border:1px solid var(--primary);border-radius:var(--radius-sm);padding:.2rem .5rem;outline:none}.ideas-delete-btn{font-size:.78rem;padding:.3rem .7rem;color:#dc2626;border-color:#fecaca}.ideas-delete-btn:hover{background:#fee2e2}.ideas-summary{width:100%;padding:.75rem 1.25rem;border:none;border-bottom:1px solid var(--border);resize:none;font-family:inherit;font-size:.9rem;color:var(--text-main);background:#fafafa;min-height:72px;outline:none;line-height:1.5}.ideas-summary:focus{background:var(--surface)}.ideas-summary-wrapper{position:relative}.ideas-summary{padding-right:3rem}.ideas-chat-input-wrapper{flex:1;position:relative;display:flex}.ideas-chat-input{padding-right:3rem}.ideas-field-mic{position:absolute;bottom:.4rem;right:.4rem;width:40px;height:40px;padding:0;font-size:1.15rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);opacity:.5;transition:opacity .2s}.ideas-summary-wrapper:hover .ideas-field-mic,.ideas-chat-input-wrapper:hover .ideas-field-mic,.ideas-field-mic.btn-mic-active{opacity:1}.ideas-links-row{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;padding:.6rem 1.25rem;border-bottom:1px solid var(--border);background:var(--surface-alt)}.ideas-links-label{font-size:.75rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.ideas-link-chip{display:inline-flex;align-items:center;background:var(--primary-light);border:1px solid #bfdbfe;border-radius:999px;padding:.2rem .5rem .2rem .75rem;gap:.3rem;font-size:.8rem}.ideas-link-chip-title{color:var(--primary);cursor:pointer;font-weight:500}.ideas-link-chip-title:hover{text-decoration:underline}.ideas-link-chip-remove{background:none;border:none;cursor:pointer;color:#93c5fd;font-size:1rem;line-height:1;padding:0}.ideas-link-chip-remove:hover{color:#dc2626}.ideas-link-add-wrapper{position:relative}.ideas-link-btn{font-size:.78rem;padding:.3rem .7rem}.ideas-link-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:50;min-width:220px}.ideas-link-search{width:100%;padding:.5rem .75rem;border:none;border-bottom:1px solid var(--border);font-size:.85rem;outline:none;border-radius:var(--radius-md) var(--radius-md) 0 0}.ideas-link-dropdown ul{list-style:none;max-height:200px;overflow-y:auto}.ideas-link-dropdown ul li{padding:.6rem .75rem;cursor:pointer;font-size:.875rem;border-bottom:1px solid var(--border)}.ideas-link-dropdown ul li:last-child{border-bottom:none}.ideas-link-dropdown ul li:hover{background:var(--primary-light)}.ideas-link-dropdown ul li.no-results{color:var(--text-muted);cursor:default}.ideas-link-dropdown ul li.no-results:hover{background:none}.ideas-chat{flex:1;display:flex;flex-direction:column;overflow:hidden}.ideas-chat-messages{flex:1;overflow-y:auto;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem;background:#fafafa}.ideas-chat-messages::-webkit-scrollbar{width:6px}.ideas-chat-messages::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.ideas-chat-empty{color:var(--text-muted);font-size:.875rem;text-align:center;margin:auto}.ideas-chat-msg{display:flex}.ideas-chat-msg--user{justify-content:flex-end}.ideas-chat-msg--ai{justify-content:flex-start}.ideas-chat-bubble{max-width:80%;padding:.65rem 1rem;border-radius:var(--radius-md);font-size:.9rem;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}.ideas-chat-msg--user .ideas-chat-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:2px}.ideas-chat-msg--ai .ideas-chat-bubble{background:var(--surface);border:1px solid var(--border);color:var(--text-main);border-bottom-left-radius:2px}.ideas-chat-thinking{color:var(--text-muted);font-style:italic}.ideas-chat-input-row{display:flex;gap:.5rem;align-items:flex-end;padding:.75rem 1.25rem;border-top:1px solid var(--border);background:var(--surface)}.ideas-chat-input{flex:1;resize:none;padding:.65rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);font-family:inherit;font-size:.9rem;outline:none;background:var(--surface-alt)}.ideas-chat-input:focus{border-color:var(--primary);background:var(--surface)}@media(max-width:768px){.tab-bar{padding:0 1rem}.ideas-layout{flex-direction:column;max-height:none;min-height:0;border-radius:0}.ideas-sidebar{width:100%;max-height:200px;border-right:none;border-bottom:1px solid var(--border)}.ideas-detail{min-height:400px}}
