@import"https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@400;500;700&family=Sora:wght@500;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@400;500;700&family=Rubik:wght@500;700&display=swap";.app-header{background:#ffffffdb;border-bottom:1px solid var(--border);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header-left,.header-right{display:flex;align-items:center;gap:12px}.logo{display:flex;align-items:center;gap:10px}.logo-link{color:inherit;text-decoration:none}.logo-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:8px}.logo-icon{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#0f766e,#0b5c55 65%,#d97706 120%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-family:var(--font-display)}.logo-text{font-weight:600;font-size:15px}.header-divider{width:1px;height:24px;background:var(--border)}.module-name{font-weight:500;color:var(--text-secondary);font-size:14px}.tenant-pill{padding:6px 10px;background:var(--surface-alt);border:1px solid var(--border);border-radius:999px;font-size:12px}.tenant-select{min-width:180px;padding:6px 30px 6px 12px;font-size:12px;font-family:var(--font);border-radius:999px;border:1px solid var(--border);background:var(--surface-alt);color:var(--text);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%237b8794' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.tenant-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #0f766e1f}.user-info{display:flex;align-items:center;gap:10px;padding:6px 12px;background:var(--surface-alt);border-radius:999px;border:1px solid var(--border);cursor:pointer;transition:all .15s ease;font-family:var(--font)}.user-info:hover{background:var(--surface);border-color:var(--border-strong)}.user-avatar{width:30px;height:30px;border-radius:50%;background:conic-gradient(from 90deg at 50% 50%,#0f766e,#0ea5e9,#d97706,#0f766e);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:11px;text-transform:uppercase}.user-name{font-size:13px;font-weight:500}.user-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:110;display:flex;align-items:flex-start;justify-content:flex-end}.user-menu-panel{margin:72px 24px 24px;width:min(320px,calc(100% - 32px));background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;animation:slideDown .2s ease-out}.user-menu-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);font-weight:600}.user-menu-panel-body{padding:8px}.user-menu-profile{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius);background:var(--surface-alt);margin-bottom:8px}.user-menu-profile-main{min-width:0;flex:1}.user-menu-profile-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.user-menu-profile-name{font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-profile-email{font-size:12px;color:var(--text-muted)}.user-menu-inline-settings{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-muted);padding:0;cursor:pointer;transition:all .15s ease;flex-shrink:0}.user-menu-inline-settings:hover{border-color:var(--border-strong);color:var(--text)}.user-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:var(--radius);font-size:13px;font-family:var(--font);color:var(--text);cursor:pointer;transition:all .15s ease;border:1px solid transparent}.user-menu-item:hover{background:var(--surface-alt);border-color:var(--border)}.user-menu-item svg{color:var(--text-muted)}.apps-toggle{padding:8px}.apps-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:110;display:flex;align-items:flex-start;justify-content:flex-end;animation:fadeIn .15s ease-out}.apps-panel{margin:72px 24px 24px;width:min(360px,calc(100% - 32px));background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;animation:slideDown .2s ease-out}.apps-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);font-weight:600}.apps-panel-body{padding:8px}.apps-empty{padding:16px;color:var(--text-muted);font-size:13px;text-align:center}.apps-list{display:flex;flex-direction:column;gap:8px}.apps-item{display:flex;gap:12px;align-items:center;padding:10px 12px;border-radius:var(--radius);text-decoration:none;color:var(--text);border:1px solid transparent;background:var(--surface);transition:all .15s ease}.apps-item:hover{background:var(--surface-alt);border-color:var(--border)}.apps-item-icon{width:32px;height:32px;border-radius:8px;background:var(--accent-soft);color:var(--accent-strong);display:flex;align-items:center;justify-content:center;flex-shrink:0}.apps-item-info{flex:1;min-width:0}.apps-item-name{font-weight:600;font-size:13px}.apps-item-url{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:transparent;border:none;border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.mobile-menu-btn:hover{background:var(--surface-alt);color:var(--text)}.mobile-menu{display:none;position:fixed;right:0;bottom:0;left:0;top:60px;background:#0f172a66;z-index:100;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.mobile-menu.open{opacity:1;visibility:visible}.mobile-menu-content{position:absolute;top:0;right:0;width:280px;max-width:calc(100vw - 40px);background:var(--surface);border-left:1px solid var(--border);box-shadow:var(--shadow-md);padding:8px;transform:translate(100%);transition:transform .25s ease}.mobile-menu.open .mobile-menu-content{transform:translate(0)}.mobile-menu-item{display:flex;align-items:center;gap:12px;padding:12px;background:transparent;border-radius:var(--radius);font-size:14px;color:var(--text);text-decoration:none;transition:background .15s ease}.mobile-menu-item:hover{background:var(--surface-alt)}.mobile-menu-divider{height:1px;background:var(--border);margin:8px 0}.mobile-tenant-select{display:none;padding:0 4px 8px}.mobile-tenant-select label{display:block;font-size:11px;color:var(--text-muted);margin:8px 0 6px}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){.mobile-menu-btn{display:flex}.mobile-menu{display:block}.app-header{padding:0 12px}.logo-text,.header-divider,.user-info,.tenant-pill,.tenant-select,.apps-toggle{display:none}.apps-panel,.user-menu-panel{margin:64px 12px 12px;width:calc(100% - 24px)}.mobile-tenant-select{display:block}.mobile-tenant-select .tenant-select{display:block;width:100%}}.shared-date-input{display:grid;gap:4px;min-width:0}.shared-date-input-label{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#7b8794}.shared-date-input-control{border:1px solid rgba(31,42,48,.16);border-radius:10px;background:#fff;color:#1f2a30;font-size:12px;line-height:1.2;padding:6px 10px;min-width:140px;font-family:inherit}.shared-date-input-control:focus{outline:none;border-color:#0f766e;box-shadow:0 0 0 3px #0f766e26}.shared-date-input.is-compact .shared-date-input-control{border-radius:999px;min-height:36px;padding:6px 12px}.shared-date-range{display:grid;gap:4px;min-width:0}.shared-date-range-label{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#7b8794}.shared-date-range-fields{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:8px}.shared-date-range-separator{color:#7b8794;font-size:12px;line-height:1}.shared-date-range-input{border:1px solid rgba(31,42,48,.16);border-radius:10px;background:#fff;color:#1f2a30;font-size:12px;line-height:1.2;padding:6px 10px;min-width:0;width:100%;font-family:inherit}.shared-date-range-input:focus{outline:none;border-color:#0f766e;box-shadow:0 0 0 3px #0f766e26}.shared-date-range.is-compact .shared-date-range-input{border-radius:999px;min-height:36px;padding:6px 12px}.shared-date-range.is-compact .shared-date-range-fields{gap:6px}@media (max-width: 640px){.shared-date-range-fields{grid-template-columns:1fr;gap:6px}.shared-date-range-separator{display:none}}@media (max-width: 900px){.shared-date-range.is-compact .shared-date-range-fields{grid-template-columns:1fr;gap:6px}.shared-date-range.is-compact .shared-date-range-separator{display:none}}.tooltip{position:relative;display:inline-flex;align-items:center}.tooltip-trigger{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--surface-alt);color:var(--text-muted);font-size:10px;font-weight:600;cursor:help;margin-left:6px;border:1px solid var(--border)}.tooltip-bubble{position:fixed;left:var(--tooltip-left, 0);top:var(--tooltip-top, 0);background:var(--text);color:#fff;padding:8px 12px;border-radius:var(--radius);font-size:12px;line-height:1.5;max-width:240px;white-space:pre-line;opacity:0;pointer-events:none;transition:opacity .15s ease;z-index:1000;box-shadow:var(--shadow-md)}.tooltip-bubble.is-open{opacity:1;pointer-events:auto}.tooltip-bubble:after{content:"";position:absolute;left:var(--tooltip-arrow-left, 50%);bottom:-6px;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--text)}.tooltip-bubble[data-side=bottom]:after{top:-6px;bottom:auto;border-top-color:transparent;border-bottom-color:var(--text)}.ai-chat-root{--font: "Zen Kaku Gothic New", "Noto Sans", sans-serif;--font-display: "Sora", "Zen Kaku Gothic New", sans-serif;--bg: #f5f2eb;--surface: #ffffff;--surface-alt: #fdf7ee;--border: #e5e0d4;--border-strong: #d6cfc2;--text: #1f2a30;--text-secondary: #44515c;--text-muted: #7b8794;--accent: #0f766e;--accent-strong: #0b5c55;--accent-soft: #d7f3ee;--warn: #d97706;--warn-soft: #fef3c7;--danger: #dc2626;--danger-soft: #fee2e2;--shadow-sm: 0 2px 6px rgba(15, 23, 42, .06);--shadow-md: 0 12px 24px rgba(15, 23, 42, .08);--radius: 12px;--radius-lg: 18px;--composer-offset: 8px;font-family:var(--font);color:var(--text);--scrollbar-offset: 8px;width:100%;height:100%;display:flex;flex-direction:column;position:relative;min-height:0;min-width:0}.ai-chat-root.is-full-height{height:var(--app-height, 100vh);min-height:var(--app-height, 100vh)}.ai-chat-root,.ai-chat-root *{box-sizing:border-box}.ai-chat-root .btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;border-radius:999px;border:none;cursor:pointer;transition:all .2s ease;font-family:var(--font);white-space:nowrap}.ai-chat-root .btn:disabled{opacity:.5;cursor:not-allowed}.ai-chat-root .btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.ai-chat-root .btn-secondary:hover:not(:disabled){background:var(--surface-alt);border-color:var(--border-strong)}.ai-chat-root .btn-danger{background:var(--danger-soft);color:#7a1f1f;border:1px solid rgba(220,38,38,.35)}.ai-chat-root .btn-danger:hover:not(:disabled){background:#fecaca}.ai-chat-root .btn-ghost{background:transparent;color:var(--text-secondary)}.ai-chat-root .btn-ghost:hover:not(:disabled){background:#0f766e14}.ai-chat-root .btn-xs{padding:4px 8px;font-size:11px}.ai-chat-root .alert{padding:12px 16px;border-radius:var(--radius);font-size:13px;border:1px solid transparent}.ai-chat-root .alert-error{background:var(--danger-soft);color:#7a1f1f;border-color:#dc262659}.ai-chat-root .alert-warning{background:var(--warn-soft);color:#6b4a10;border-color:#d9770659}.ai-chat-root .alert.is-dismissible{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.ai-chat-root .alert-close{border:none;background:transparent;color:inherit;font-size:16px;line-height:1;padding:0 2px;cursor:pointer;opacity:.75}.ai-chat-root .alert-close:hover{opacity:1}.ai-chat-root .loading{display:flex;align-items:center;justify-content:center;padding:40px}.ai-chat-root .loading-spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:ai-chat-spin .8s linear infinite}.ai-chat-root .select{width:100%;padding:10px 36px 10px 12px;font-size:14px;font-family:inherit;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237b8794' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.ai-chat-root .chat-shell{display:grid;grid-template-columns:260px minmax(0,1fr);gap:20px;border:none;border-radius:0;overflow:visible;background:transparent;flex:1;height:100%;min-height:0;min-width:0}.ai-chat-root .chat-sidebar,.ai-chat-root .chat-main{background:transparent;border:none;border-radius:0;box-shadow:none}.ai-chat-root .chat-sidebar{padding:16px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);display:flex;flex-direction:column;gap:14px;min-height:0;min-width:0}.ai-chat-root .mobile-sidebar-overlay{display:none}.ai-chat-root .sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.ai-chat-root .sidebar-title{display:inline-flex;align-items:center;gap:6px;font-weight:700}.ai-chat-root .sidebar-sub{font-size:12px;color:var(--text-muted)}.ai-chat-root .tenant-select-inline{display:flex;align-items:center;width:100%;padding:4px 6px;border:1px solid var(--border-light);border-radius:999px;background:var(--surface-hover)}.ai-chat-root .tenant-select-inline:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #0f766e1f}.ai-chat-root .tenant-select-inline .select{width:100%;padding:4px 24px 4px 8px;font-size:11px;border-radius:999px;background-position:right 10px center;background-color:transparent;border:none;box-shadow:none}.ai-chat-root .tenant-select-inline .select:focus{outline:none}.ai-chat-root .chat-list{display:flex;flex-direction:column;gap:10px;overflow-y:auto;flex:1;min-height:0;box-sizing:content-box;width:100%;padding-right:var(--scrollbar-offset);margin-right:calc(-1 * var(--scrollbar-offset));scrollbar-gutter:stable}.ai-chat-root .chat-list,.ai-chat-root .chat-messages{scrollbar-width:thin;scrollbar-color:rgba(31,42,48,.25) transparent}.ai-chat-root .chat-list::-webkit-scrollbar,.ai-chat-root .chat-messages::-webkit-scrollbar{width:6px}.ai-chat-root .chat-list::-webkit-scrollbar-track,.ai-chat-root .chat-messages::-webkit-scrollbar-track{background:transparent}.ai-chat-root .chat-list::-webkit-scrollbar-thumb,.ai-chat-root .chat-messages::-webkit-scrollbar-thumb{background-color:#1f2a3033;border-radius:999px}.ai-chat-root .chat-list::-webkit-scrollbar-thumb:hover,.ai-chat-root .chat-messages::-webkit-scrollbar-thumb:hover{background-color:#1f2a3059}.ai-chat-root .chat-list::-webkit-scrollbar-button,.ai-chat-root .chat-messages::-webkit-scrollbar-button{display:none;width:0;height:0}.ai-chat-root .chat-list-item{text-align:left;padding:10px 12px;border-radius:var(--radius);border:1px solid transparent;background:var(--surface-alt);cursor:pointer;transition:all .2s ease}.ai-chat-root .chat-list-item:hover{border-color:var(--border-strong)}.ai-chat-root .chat-list-item.active{border-color:var(--accent-strong);background:var(--accent-soft);color:var(--accent-strong);box-shadow:0 0 0 2px #0f766e1f}.ai-chat-root .chat-list-item.active .chat-list-title,.ai-chat-root .chat-list-item.active .chat-list-meta{color:var(--accent-strong)}.ai-chat-root .chat-list-title{font-weight:600;margin-bottom:4px}.ai-chat-root .chat-list-meta{font-size:11px;color:var(--text-muted);display:flex;justify-content:space-between;gap:8px}.ai-chat-root .chat-list-loading{padding:12px;text-align:center;font-size:12px;color:var(--text-muted)}.ai-chat-root .chat-list-loadmore{margin-top:6px;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--surface);font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.ai-chat-root .chat-list-loadmore:hover:not(:disabled){background:var(--surface-alt);border-color:var(--border-strong);color:var(--text)}.ai-chat-root .chat-list-loadmore:disabled{opacity:.6;cursor:not-allowed}.ai-chat-root .empty-state{font-size:12px;color:var(--text-muted);padding:12px;text-align:center}.ai-chat-root .empty-state-sub{font-size:12px;opacity:.8}.ai-chat-root .chat-main{display:grid;grid-template-rows:minmax(0,1fr) auto;min-height:0;min-width:0;background:transparent;flex:1;border:none;border-radius:0;overflow:visible;position:relative;padding-bottom:var(--composer-offset, 8px)}.ai-chat-root .chat-main.is-file-drag-active{background:#0f766e0a;border-radius:16px}.ai-chat-root .chat-drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:8;pointer-events:none;display:flex;align-items:center;justify-content:center;padding:22px;border:2px dashed rgba(15,118,110,.4);border-radius:16px;background:#0f766e14;color:var(--accent-strong)}.ai-chat-root .chat-drop-overlay.is-disabled{border-color:#d9770673;background:#d977061a;color:#8a4b08}.ai-chat-root .chat-drop-overlay span{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:999px;border:1px solid currentColor;background:#ffffffd1;font-size:13px;font-weight:700}.ai-chat-root .chat-messages{flex:1;overflow-y:auto;padding:16px 0;scroll-padding-bottom:16px;background:transparent;display:flex;flex-direction:column;gap:20px;min-height:0;box-sizing:content-box;width:100%;padding-right:var(--scrollbar-offset);margin-right:calc(-1 * var(--scrollbar-offset));scrollbar-gutter:stable}.ai-chat-root .chat-loading{display:flex;justify-content:center;align-items:center;padding:28px 0}.ai-chat-root .loading-dots,.ai-chat-root .chat-thinking{display:inline-flex;align-items:center;gap:6px}.ai-chat-root .chat-thinking{min-height:18px;color:var(--text-muted)}.ai-chat-root .chat-thinking-label{font-size:12px;color:var(--text-muted);margin-left:4px}.ai-chat-root .loading-dot{width:7px;height:7px;border-radius:999px;background:var(--text-muted);opacity:.45;animation:chat-dot-bounce 1.2s infinite ease-in-out}.ai-chat-root .loading-dot:nth-child(2){animation-delay:.2s}.ai-chat-root .loading-dot:nth-child(3){animation-delay:.4s}@keyframes chat-dot-bounce{0%,80%,to{transform:translateY(0);opacity:.35}40%{transform:translateY(-6px);opacity:1}}.ai-chat-root .chat-empty{max-width:520px;margin:40px auto 0;padding:32px;border-radius:var(--radius-lg);border:1px dashed var(--border);background:var(--surface-alt);text-align:center;color:var(--text-muted);display:flex;flex-direction:column;gap:12px}.ai-chat-root .chat-message-row{display:flex;padding:0;width:100%}.ai-chat-root .chat-message-row.is-user{justify-content:flex-end}.ai-chat-root .chat-message-row.is-assistant{justify-content:flex-start}.ai-chat-root .chat-message{padding:10px 0;border-radius:16px;background:transparent;border:none;max-width:100%;width:100%}.ai-chat-root .chat-message.is-user{max-width:720px;width:fit-content;background:var(--accent-soft);border:1px solid rgba(15,118,110,.2);padding:12px 14px}.ai-chat-root .chat-message.is-assistant{background:transparent;padding-left:8px}.ai-chat-root .chat-message-meta{font-size:11px;color:var(--text-muted);display:flex;gap:8px;margin-bottom:8px}.ai-chat-root .chat-role{font-weight:600;color:var(--text-secondary)}.ai-chat-root .chat-response-duration{color:color-mix(in srgb,var(--text-muted) 85%,transparent);font-variant-numeric:tabular-nums}.ai-chat-root .chat-message-content{font-size:14px;line-height:1.65;white-space:pre-wrap}.ai-chat-root .chat-message-status{margin-top:8px;padding:4px 2px;border-radius:0;background:transparent;border:0;color:color-mix(in srgb,var(--text-muted) 78%,transparent);font-size:11px;line-height:1.35;letter-spacing:.01em;white-space:pre-wrap}.ai-chat-root .chat-message-content.markdown{white-space:normal}.ai-chat-root .chat-message-content.markdown>*:first-child{margin-top:0}.ai-chat-root .chat-message-content.markdown>*:last-child{margin-bottom:0}.ai-chat-root .chat-message-content.markdown p{margin:0 0 10px}.ai-chat-root .chat-message-content.markdown ul,.ai-chat-root .chat-message-content.markdown ol{margin:0 0 10px 18px;padding:0}.ai-chat-root .chat-message-content.markdown li{margin:2px 0}.ai-chat-root .chat-message-content.markdown a{color:var(--accent-strong);text-decoration:underline}.ai-chat-root .chat-message-content.markdown code{font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:12px;padding:2px 6px;border-radius:6px;background:#0f766e1a;color:var(--accent-strong)}.ai-chat-root .chat-message-content.markdown pre{margin:0;padding:0;border:none;border-radius:0;background:transparent;color:inherit;box-shadow:none;overflow-x:auto}.ai-chat-root .chat-message-content.markdown pre code{padding:0;background:transparent;color:inherit}.ai-chat-root .chat-message-content.markdown .code-block{border-radius:12px;overflow:hidden;border:1px solid rgba(15,118,110,.2);margin:0 8px 12px;background:#0f172a;color:#e2e8f0}.ai-chat-root .chat-message-content.markdown .code-block-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;font-size:11px;background:#0f766e14;color:var(--text-secondary)}.ai-chat-root .chat-message-content.markdown .code-block.theme-light .code-block-header{background:#f8fafc;color:var(--text-muted)}.ai-chat-root .chat-message-content.markdown .code-block-header .code-block-lang{text-transform:uppercase;letter-spacing:.4px}.ai-chat-root .chat-message-content.markdown .code-copy-button{border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);border-radius:999px;padding:2px 8px;font-size:10px;cursor:pointer}.ai-chat-root .chat-message-content.markdown .code-copy-button:hover{border-color:var(--border-strong);color:var(--text)}.ai-chat-root .chat-message-content.markdown .code-copy-button.is-copied{border-color:#16a34a66;background:#dcfce7;color:#166534}.ai-chat-root .chat-message-content.markdown .code-block pre{margin:0;padding:10px 12px 12px}.ai-chat-root .chat-message-content.markdown .code-block.theme-light pre,.ai-chat-root .chat-message-content.markdown .code-block.theme-light{background:#f8fafc;color:#0f172a}.ai-chat-root .chat-message-content.markdown .hljs{color:inherit}.ai-chat-root .chat-message-content.markdown .hljs-keyword,.ai-chat-root .chat-message-content.markdown .hljs-selector-tag,.ai-chat-root .chat-message-content.markdown .hljs-literal{color:#38bdf8}.ai-chat-root .chat-message-content.markdown .hljs-string,.ai-chat-root .chat-message-content.markdown .hljs-attr,.ai-chat-root .chat-message-content.markdown .hljs-number{color:#fbbf24}.ai-chat-root .chat-message-content.markdown .hljs-title,.ai-chat-root .chat-message-content.markdown .hljs-section{color:#a5b4fc}.ai-chat-root .chat-message-content.markdown .hljs-comment,.ai-chat-root .chat-message-content.markdown .hljs-quote{color:#94a3b8;font-style:italic}.ai-chat-root .chat-message-content.markdown blockquote{margin:0 0 12px;padding:6px 12px;border-left:3px solid var(--accent);background:#0f766e14;color:var(--text-secondary)}.ai-chat-root .chat-message-content.markdown hr{border:none;border-top:1px solid var(--border);margin:12px 0}.ai-chat-root .chat-message-content.markdown table{width:100%;border-collapse:collapse;margin:0 0 12px;font-size:12px}.ai-chat-root .chat-message-content.markdown th,.ai-chat-root .chat-message-content.markdown td{border:1px solid var(--border);padding:6px 8px;text-align:left}.ai-chat-root .chat-message-content.markdown th{background:var(--surface-alt)}.ai-chat-root .chat-attachments,.ai-chat-root .chat-outputs,.ai-chat-root .chat-files{display:flex;flex-direction:column;gap:6px;margin-top:8px}.ai-chat-root .chat-files{flex-direction:row;flex-wrap:wrap;gap:8px}.ai-chat-root .chat-attachments-title,.ai-chat-root .chat-outputs-title{font-size:11px;color:var(--text-muted);font-weight:600}.ai-chat-root .chat-attachment,.ai-chat-root .chat-output{padding:4px 10px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:11px;color:var(--text-muted);text-decoration:none;display:inline-flex;align-items:center;width:fit-content}.ai-chat-root .chat-attachment:hover,.ai-chat-root .chat-output:hover{border-color:var(--border-strong);color:var(--text)}.ai-chat-root .chat-citations{margin-top:10px;display:flex;flex-direction:column;gap:4px}.ai-chat-root .chat-citations-title{font-size:11px;color:var(--text-muted);font-weight:600}.ai-chat-root .chat-citation{font-size:12px;color:var(--accent-strong);text-decoration:none}.ai-chat-root .chat-citation:hover{text-decoration:underline}.ai-chat-root .chat-file{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;border:1px solid var(--border);background:var(--surface);font-size:12px;min-width:0}.ai-chat-root .chat-file>span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-chat-root .chat-file-tag{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border-radius:999px;border:1px solid rgba(15,118,110,.28);background:var(--accent-soft);color:var(--accent-strong);font-size:10px;font-weight:600;letter-spacing:.02em}.ai-chat-root .chat-composer{padding:0;border-top:none;background:transparent;display:flex;flex-direction:column;gap:12px;position:relative;margin-top:auto;z-index:2}.ai-chat-root .voice-error-toast{position:absolute;left:50%;bottom:calc(100% + 6px);transform:translate(-50%);max-width:min(92%,420px);border-radius:999px;padding:6px 10px;font-size:11px;line-height:1.2;color:#7a1f1f;background:#fee2e2f5;border:1px solid rgba(220,38,38,.35);box-shadow:0 8px 18px #0f172a1f;z-index:5;pointer-events:none;animation:ai-chat-voice-toast-in .12s ease-out}.ai-chat-root .chat-input{border:1px solid var(--border);border-radius:16px;padding:8px 12px;background:var(--surface);display:flex;flex-direction:column;gap:10px;box-shadow:none}.ai-chat-root .chat-textarea-wrap{position:relative}.ai-chat-root .chat-textarea-wrap.has-status{min-height:48px}.ai-chat-root .chat-input .textarea{width:100%;border:none;padding:0;font-family:var(--font);font-size:14px;resize:none;background:transparent;color:var(--text);min-height:28px;line-height:1.5;max-height:320px;overflow-y:hidden}.ai-chat-root .chat-input .textarea.has-inline-status{padding-bottom:26px}.ai-chat-root .chat-input .textarea::placeholder{font-size:12px;color:var(--text-muted)}.ai-chat-root .chat-input .textarea:focus{outline:none}.ai-chat-root .chat-input-status{position:absolute;left:0;bottom:2px;display:inline-flex;align-items:center;gap:7px;width:fit-content;max-width:100%;padding:4px 8px;border-radius:999px;font-size:11px;line-height:1;background:#f5f7faf0;border:1px solid var(--border);color:var(--text-secondary);pointer-events:none}.ai-chat-root .chat-input-status.is-recording{background:#fee2e2f2;border-color:#dc262659;color:#991b1b}.ai-chat-root .chat-input-status.is-processing{background:#d7f3eef2;border-color:#0f766e57;color:#0f5c56}.ai-chat-root .chat-input-status-dot{width:8px;height:8px;border-radius:999px;background:currentColor;box-shadow:0 0 0 0 currentColor;animation:ai-chat-status-pulse-recording 1.4s ease-out infinite}.ai-chat-root .chat-input-status.is-processing .chat-input-status-dot{animation-name:ai-chat-status-pulse-processing}.ai-chat-root .chat-input-status-waves{display:inline-flex;align-items:flex-end;gap:2px;height:10px;opacity:.55}.ai-chat-root .chat-input-status-waves span{width:2px;height:6px;border-radius:999px;background:currentColor;opacity:.72;animation:ai-chat-status-wave 1s ease-in-out infinite}.ai-chat-root .chat-input-status-waves.is-live{opacity:.92}.ai-chat-root .chat-input-status-waves span:nth-child(2){animation-delay:.12s}.ai-chat-root .chat-input-status-waves span:nth-child(3){animation-delay:.24s}.ai-chat-root .chat-input-status-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:min(60vw,320px)}.ai-chat-root .chat-input-level{position:relative;width:62px;height:8px;border-radius:999px;overflow:hidden;border:1px solid rgba(15,23,42,.18);background:#ffffff94}.ai-chat-root .chat-input-level-fill{position:absolute;top:0;right:0;bottom:0;left:0;transform-origin:left center;background:linear-gradient(90deg,#22c55e,#f59e0b 65%,#ef4444);border-radius:inherit;transition:transform 85ms linear}.ai-chat-root .chat-input-level-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.65) 45%,transparent 100%);animation:ai-chat-level-sheen 1.2s linear infinite}.ai-chat-root .chat-input-status-value{min-width:22px;text-align:center;font-weight:700;letter-spacing:.03em}.ai-chat-root .chat-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:nowrap}.ai-chat-root .chat-actions-right{display:flex;align-items:center;gap:8px}.ai-chat-root .chat-actions-left{display:flex;align-items:center;gap:6px;flex-wrap:nowrap}.ai-chat-root .chat-actions input[type=file]{display:none}.ai-chat-root .icon-button{display:inline-flex;align-items:center;gap:6px;padding:6px 8px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .15s ease;min-width:32px;min-height:32px}.ai-chat-root .icon-button.has-status-indicator{position:relative}.ai-chat-root .icon-button.is-busy{border-color:#0f766e73}.ai-chat-root .icon-button svg{width:16px;height:16px}.ai-chat-root .icon-status-dot{position:absolute;top:4px;right:4px;width:6px;height:6px;border-radius:999px;background:currentColor;opacity:.85;animation:ai-chat-icon-busy-dot 1s ease-in-out infinite}.ai-chat-root .icon-button:hover{border-color:var(--border-strong);color:var(--text)}.ai-chat-root .icon-button:disabled{opacity:.5;cursor:not-allowed}.ai-chat-root .icon-button.active{background:var(--accent);border-color:var(--accent);color:#fff}.ai-chat-root .icon-button.is-recording{border-color:#ef4444;color:#b91c1c;background:#fee2e2}.ai-chat-root .icon-button.is-recording:hover:not(:disabled){border-color:#dc2626;background:#fecaca}.ai-chat-root .icon-button.is-processing{border-color:#0f766e66}.ai-chat-root .icon-button-primary{background:var(--accent);border-color:var(--accent);color:#fff}.ai-chat-root .icon-button-primary:hover:not(:disabled){background:var(--accent-strong);border-color:var(--accent-strong)}.ai-chat-root .icon-button-send:hover:not(:disabled){background:var(--accent);border-color:var(--accent);color:#fff}.ai-chat-root .icon-button-danger{background:#b91c1c;border-color:#b91c1c;color:#fff}.ai-chat-root .icon-button-danger:hover:not(:disabled){background:#991b1b;border-color:#991b1b}.ai-chat-root .icon-label{display:none;font-size:11px}.ai-chat-root .icon-menu{position:relative}.ai-chat-root .icon-popover{position:absolute;bottom:calc(100% + 8px);left:0;min-width:200px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-md);padding:8px;z-index:5;max-height:280px;overflow-y:auto}.ai-chat-root .model-settings-popover{min-width:260px;max-height:360px}.ai-chat-root .model-popover{width:280px;min-width:260px;max-width:320px}.ai-chat-root .history-popover{left:auto;right:0;width:min(420px,calc(100vw - 28px));min-width:min(320px,calc(100vw - 28px));max-width:420px;max-height:260px}.ai-chat-root .history-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}.ai-chat-root .history-filter-row{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px}.ai-chat-root .history-filter-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.ai-chat-root .history-filter-select{max-width:320px;padding:8px 10px;font-size:12px}.ai-chat-root .history-item{display:flex;flex-direction:column;gap:8px;padding:8px;border-radius:10px;border:1px solid var(--border);background:var(--surface-alt)}.ai-chat-root .history-item.is-selected{border-color:var(--accent-strong);background:var(--accent-soft)}.ai-chat-root .history-item-main{display:flex;flex-direction:column;gap:2px;min-width:0}.ai-chat-root .history-item-name{font-size:12px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px;min-width:0}.ai-chat-root .history-item-name>span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-chat-root .history-app-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:1px 6px;font-size:10px;font-weight:600;background:var(--surface-hover);border:1px solid var(--border);color:var(--text-secondary);flex-shrink:0}.ai-chat-root .history-kind-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:1px 6px;font-size:10px;font-weight:600;letter-spacing:.01em;flex-shrink:0}.ai-chat-root .history-kind-badge.kind-attachment{background:#e8f2ff;border:1px solid #bfd6fb;color:#1d4ed8}.ai-chat-root .history-kind-badge.kind-output{background:#e8f7ee;border:1px solid #b8e3cb;color:#166534}.ai-chat-root .history-item-meta{font-size:11px;color:var(--text-muted)}.ai-chat-root .history-item-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.ai-chat-root .history-loadmore{width:100%;margin-top:8px}.ai-chat-root .model-settings-section{display:flex;flex-direction:column;gap:6px;margin-top:8px}.ai-chat-root .model-settings-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.ai-chat-root .model-settings-hint{font-size:11px;color:var(--text-muted);margin-bottom:6px}.ai-chat-root .model-chip-list{display:flex;flex-wrap:wrap;gap:6px}.ai-chat-root .model-chip{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:999px;padding:4px 8px;font-size:11px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:all .15s ease}.ai-chat-root .model-chip:disabled{opacity:.6;cursor:not-allowed}.ai-chat-root .model-chip:hover:not(:disabled){border-color:var(--border-strong);background:var(--surface-alt)}.ai-chat-root .model-chip.active{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent-strong);box-shadow:0 0 0 2px #0f766e1f}.ai-chat-root .model-chip[data-tone=allow].active{background:var(--success-light, #dcfce7);color:#15803d;border-color:#15803d59}.ai-chat-root .model-chip[data-tone=block].active{background:var(--danger-soft);color:#b91c1c;border-color:#b91c1c59}.ai-chat-root .model-chip-label{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-chat-root .model-chip-icon{font-size:10px}.ai-chat-root .model-settings-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:8px}.ai-chat-root .icon-popover-title{font-size:11px;color:var(--text-muted);margin-bottom:6px}.ai-chat-root .icon-popover-title-with-tooltip{display:inline-flex;align-items:center;gap:6px}.ai-chat-root .icon-option{width:100%;display:grid;grid-template-columns:minmax(0,1fr) 16px;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;border:1px solid transparent;background:transparent;font-size:12px;color:var(--text);cursor:pointer}.ai-chat-root .icon-popover .icon-option+.icon-option{margin-top:4px}.ai-chat-root .icon-option-label{display:inline-flex;align-items:center;gap:6px;min-width:0;flex:1 1 auto}.ai-chat-root .icon-option-label>span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-chat-root .icon-option:hover{background:var(--surface-alt)}.ai-chat-root .icon-option.active{background:var(--accent-soft);border-color:var(--accent-strong);color:var(--accent-strong);box-shadow:0 0 0 2px #0f766e1f}.ai-chat-root .model-option{display:grid;grid-template-columns:minmax(0,1fr) 16px;align-items:center;gap:6px;padding:2px 4px;min-width:0}.ai-chat-root .model-option.has-favorite{grid-template-columns:minmax(0,1fr) 20px 16px}.ai-chat-root .model-option-main{width:100%;text-align:left;border:1px solid transparent;background:transparent;border-radius:8px;padding:6px 8px;font-size:12px;color:var(--text);cursor:pointer;transition:background .15s ease,border-color .15s ease;min-width:0;overflow:hidden}.ai-chat-root .model-option-main .icon-option-label{width:100%}.ai-chat-root .model-option-main .icon-option-label>span:first-child{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-chat-root .model-option:hover .model-option-main{background:var(--surface-alt)}.ai-chat-root .model-option.active .model-option-main{background:var(--accent-soft);border-color:var(--accent-strong);color:var(--accent-strong);box-shadow:0 0 0 2px #0f766e1f}.ai-chat-root .model-option-favorite{width:20px;height:20px;border-radius:999px;border:none;background:transparent;color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;transition:all .15s ease}.ai-chat-root .model-option-favorite:hover:not(:disabled){color:var(--accent);border-color:transparent;background:transparent}.ai-chat-root .model-option-favorite.active{color:#f59e0b;background:transparent;border-color:transparent;box-shadow:none}.ai-chat-root .model-option-favorite:disabled{opacity:.5;cursor:not-allowed}.ai-chat-root .icon-check{display:inline-block;width:8px;height:8px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 2px #0f766e26;flex-shrink:0;justify-self:end}.ai-chat-root .icon-option.active .icon-check,.ai-chat-root .model-option.active .icon-check{background:var(--accent);box-shadow:0 0 0 2px #0f766e40}.ai-chat-root .icon-note{font-size:11px;color:var(--text-muted);padding:4px 6px}.ai-chat-root .icon-error{font-size:11px;color:#7a1f1f;background:var(--danger-soft);border:1px solid rgba(220,38,38,.35);padding:6px 8px;border-radius:8px}.ai-chat-root .composer-note{font-size:11px;color:var(--text-muted)}.ai-chat-root .voice-note.is-recording{color:#b91c1c}@keyframes ai-chat-status-pulse-recording{0%{transform:scale(.95);box-shadow:0 0 #dc262659}70%{transform:scale(1);box-shadow:0 0 0 8px #dc262600}to{transform:scale(.95);box-shadow:0 0 #dc262600}}@keyframes ai-chat-status-pulse-processing{0%{transform:scale(.95);box-shadow:0 0 #0f766e52}70%{transform:scale(1);box-shadow:0 0 0 8px #0f766e00}to{transform:scale(.95);box-shadow:0 0 #0f766e00}}@keyframes ai-chat-status-wave{0%,to{transform:scaleY(.6)}50%{transform:scaleY(1.15)}}@keyframes ai-chat-level-sheen{0%{transform:translate(-120%)}to{transform:translate(120%)}}@keyframes ai-chat-voice-toast-in{0%{opacity:0;transform:translate(-50%,4px)}to{opacity:1;transform:translate(-50%)}}.ai-chat-root .settings-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a4d;display:flex;align-items:center;justify-content:center;padding:12px;z-index:30;overflow:hidden}.ai-chat-root .settings-modal{width:min(560px,100%);max-height:100%;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:16px;padding:16px}.ai-chat-root .settings-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.ai-chat-root .settings-title{display:inline-flex;align-items:center;gap:6px;font-size:16px;font-weight:600;color:var(--text)}.ai-chat-root .settings-body{display:flex;flex-direction:column;gap:16px;overflow-y:auto;padding-right:4px}.ai-chat-root .history-modal{width:min(860px,100%)}.ai-chat-root .history-modal-body{gap:8px}.ai-chat-root .history-modal-body .history-list{margin-top:0}.ai-chat-root .settings-section{display:flex;flex-direction:column;gap:8px}.ai-chat-root .settings-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.ai-chat-root .settings-label-with-tooltip{display:inline-flex;align-items:center;gap:6px;width:fit-content}.ai-chat-root .settings-textarea{border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-size:13px;font-family:var(--font);min-height:96px;resize:vertical;background:#fff;color:var(--text)}.ai-chat-root .settings-textarea.is-readonly{background:var(--surface-alt);color:var(--text-secondary)}.ai-chat-root .settings-textarea:focus{outline:none;border-color:#0f766e66;box-shadow:0 0 0 3px #0f766e1f}.ai-chat-root .settings-hint{font-size:11px;color:var(--text-muted)}.ai-chat-root .settings-fixed-block{display:grid;gap:8px;padding:10px;border-radius:var(--radius);border:1px dashed var(--border);background:var(--surface-alt)}.ai-chat-root .settings-fixed-item{display:grid;gap:6px}.ai-chat-root .settings-fixed-title{font-size:12px;font-weight:600;color:var(--text)}.ai-chat-root .settings-hint-inline{margin-right:auto}.ai-chat-root .settings-error{font-size:11px;color:#7a1f1f;background:var(--danger-soft);border:1px solid rgba(220,38,38,.35);padding:6px 8px;border-radius:8px}.ai-chat-root .settings-presets,.ai-chat-root .settings-chip-list{display:flex;flex-wrap:wrap;gap:8px}.ai-chat-root .settings-chip{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:999px;padding:6px 12px;font-size:12px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:all .15s ease}.ai-chat-root .settings-chip span{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-chat-root .settings-chip .settings-chip-badge{max-width:none;overflow:visible;text-overflow:clip;white-space:nowrap}.ai-chat-root .settings-chip.settings-chip-ghost{border-style:dashed;color:var(--text-muted);background:transparent}.ai-chat-root .settings-chip:hover{border-color:var(--border-strong);background:var(--surface-alt)}.ai-chat-root .settings-chip.active{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent-strong);box-shadow:0 0 0 2px #0f766e1f}.ai-chat-root .settings-chip.is-applied{border-style:solid}.ai-chat-root .settings-chip-badge{font-size:10px;padding:2px 6px;border-radius:999px;background:#0f766e1f;color:var(--accent-strong)}.ai-chat-root .settings-input{border:1px solid var(--border);border-radius:12px;padding:8px 12px;font-size:12px;font-family:var(--font);background:#fff;color:var(--text)}.ai-chat-root .settings-input.is-readonly{background:var(--surface-alt);color:var(--text-secondary)}.ai-chat-root .settings-input:focus{outline:none;border-color:#0f766e66;box-shadow:0 0 0 3px #0f766e1f}.ai-chat-root .settings-inline-actions{display:flex;align-items:center;gap:8px}.ai-chat-root .settings-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}.ai-chat-root .mobile-toggles{display:none;gap:8px;position:absolute;top:12px;left:12px;z-index:6}.ai-chat-root .mobile-toggle{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.ai-chat-root .mobile-toggle:hover{border-color:var(--border-strong);color:var(--text)}.ai-chat-root .mobile-toggle.active{background:var(--accent-soft);border-color:var(--accent-strong);color:var(--accent-strong);box-shadow:0 0 0 2px #0f766e1f}.ai-chat-root .chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;min-height:300px}.ai-chat-root .chat-empty-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;background:var(--accent-soft);border-radius:50%;margin-bottom:16px;color:var(--accent)}.ai-chat-root .chat-empty-title{font-size:18px;font-weight:600;color:var(--text);margin-bottom:8px}.ai-chat-root .chat-empty-sub{font-size:13px;color:var(--text-muted);max-width:320px;margin-bottom:20px}.ai-chat-root .chat-empty-required{display:grid;gap:8px;width:min(420px,100%);margin-bottom:16px}.ai-chat-root .chat-empty-required-label{font-size:11px;color:var(--text-muted);font-weight:600}.ai-chat-root .chat-empty-required-items{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.ai-chat-root .chat-empty-required-item{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;border:1px solid rgba(31,42,48,.14);background:#fff;font-size:11px;color:var(--text-secondary)}.ai-chat-root .chat-empty-required-item.is-ready{border-color:#22c55e59;background:#f0fdf4;color:#166534}.ai-chat-root .chat-empty-required-item.is-missing{border-color:#f59e0b61;background:#fffbeb;color:#b45309}.ai-chat-root .chat-empty-hints{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.ai-chat-root .chat-empty-hint{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:999px;font-size:12px;color:var(--text-secondary)}.ai-chat-root .chat-empty-hint svg{color:var(--accent)}.ai-chat-root .chat-list-preview{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}.ai-chat-root .chat-list-time{flex-shrink:0;font-size:10px;color:var(--text-muted)}.ai-chat-root .chat-conversation-actions{position:absolute;top:10px;right:10px;z-index:6}.ai-chat-root .chat-conversation-delete{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);border-radius:8px;padding:0;width:30px;min-width:30px;height:30px;cursor:pointer;transition:all .15s ease}.ai-chat-root .chat-conversation-delete svg{width:14px;height:14px}.ai-chat-root .chat-conversation-delete.is-loading svg{animation:ai-chat-spin .8s linear infinite}.ai-chat-root .chat-conversation-delete:hover:not(:disabled){border-color:#fecaca;background:#fff1f2;color:#b91c1c}.ai-chat-root .chat-conversation-delete:disabled{opacity:.6;cursor:not-allowed}@keyframes ai-chat-spin{to{transform:rotate(360deg)}}@keyframes ai-chat-icon-busy-dot{0%,to{transform:scale(.7);opacity:.45}50%{transform:scale(1.1);opacity:1}}.ai-chat-root.is-compact-layout .mobile-sidebar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:20;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s ease,visibility .2s ease;display:block}.ai-chat-root.is-compact-layout .mobile-sidebar-overlay.open{opacity:1;visibility:visible;pointer-events:auto}.ai-chat-root.is-compact-layout .mobile-toggles{display:flex}.ai-chat-root.is-compact-layout .chat-shell{grid-template-columns:1fr;min-height:0;gap:0;position:relative;overflow:hidden}.ai-chat-root.is-compact-layout .chat-list,.ai-chat-root.is-compact-layout .chat-messages{margin-right:0;padding-right:0}.ai-chat-root.is-compact-layout .chat-sidebar{position:absolute;top:12px;left:12px;bottom:12px;width:min(320px,calc(100% - 24px));border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transform:translate(-120%);transition:transform .2s ease;z-index:25;background:var(--surface)}.ai-chat-root.is-compact-layout .chat-sidebar.mobile-open{transform:translate(0)}.ai-chat-root.is-compact-layout .chat-main{order:1;min-height:0}.ai-chat-root.is-compact-viewport .chat-composer{margin-top:auto}.ai-chat-root.is-compact-viewport .chat-main{min-height:0;border-radius:var(--radius-lg)}.ai-chat-root.is-compact-viewport{--composer-offset: 10px}.ai-chat-root.is-compact-viewport .chat-messages{overflow-y:scroll}.ai-chat-root.is-compact-viewport .chat-empty{padding:24px 12px;min-height:200px}.ai-chat-root.is-compact-viewport .chat-empty-icon{width:60px;height:60px}.ai-chat-root.is-compact-viewport .chat-empty-icon svg{width:32px;height:32px}.ai-chat-root.is-compact-viewport .chat-empty-title{font-size:16px}.ai-chat-root.is-compact-viewport .chat-empty-hints{gap:6px}.ai-chat-root.is-compact-viewport .chat-empty-hint{padding:4px 10px;font-size:11px}.ai-chat-root.is-compact-viewport .chat-message{padding:10px 12px;max-width:100%}.ai-chat-root.is-compact-viewport .chat-input .textarea{font-size:16px}.ai-chat-root.is-compact-viewport .chat-message-row{padding:0}.ai-chat-root.is-compact-viewport.is-full-height .chat-composer{position:fixed;left:12px;right:12px;bottom:calc(env(safe-area-inset-bottom) + 8px);padding:10px 0 14px;padding-bottom:calc(14px + env(safe-area-inset-bottom))}.file-preview-portal-root.ai-chat-root{position:fixed;top:0;right:0;bottom:0;left:0;width:0;height:0;min-height:0;overflow:visible;z-index:2147483000}.ai-chat-root .file-preview-card{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:14px;border:1px solid var(--border);background:var(--surface);text-align:left;transition:all .18s ease;cursor:pointer;width:100%;max-width:320px;min-width:0;align-self:flex-start;overflow:hidden}.ai-chat-root .file-preview-card.is-clickable:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.ai-chat-root .file-preview-card.is-disabled{cursor:default;opacity:.6}.ai-chat-root .file-preview-thumb{width:44px;height:44px;border-radius:12px;border:1px solid var(--border);background:var(--surface-alt);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.ai-chat-root .file-preview-thumb.is-image{border-color:#0f766e40;background:#fff}.ai-chat-root .file-preview-thumb img{width:100%;height:100%;object-fit:cover;display:block}.ai-chat-root .file-preview-ext{font-size:10px;font-weight:700;color:var(--text-secondary);letter-spacing:.04em}.ai-chat-root .file-preview-meta{display:flex;flex-direction:column;gap:2px;min-width:0;max-width:100%;flex:1 1 auto}.ai-chat-root .file-preview-name{display:flex;align-items:baseline;gap:2px;min-width:0;max-width:100%;font-size:12px;font-weight:600;color:var(--text)}.ai-chat-root .file-preview-name-main{min-width:0;flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-chat-root .file-preview-name-ext{flex-shrink:0}.ai-chat-root .file-preview-sub{font-size:11px;color:var(--text-muted);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-chat-root .file-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;display:flex;align-items:center;justify-content:center;padding:0;z-index:2147483001;animation:file-preview-fade .18s ease}.ai-chat-root .file-preview-modal{width:100%;height:100%;max-width:none;max-height:none;background:var(--surface);border:1px solid var(--border);border-radius:0;box-shadow:none;display:flex;flex-direction:column;gap:12px;padding:18px;animation:file-preview-pop .18s ease;min-height:0}.ai-chat-root .file-preview-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.ai-chat-root .file-preview-title{font-size:15px;font-weight:600;color:var(--text)}.ai-chat-root .file-preview-body{flex:1;min-height:240px;min-width:0;border-radius:14px;border:1px solid var(--border);background:var(--surface-alt);overflow:hidden;display:flex;align-items:center;justify-content:center;touch-action:pan-x pan-y pinch-zoom;overscroll-behavior:contain}.ai-chat-root .file-preview-body.is-pdf{align-items:stretch;justify-content:stretch;overflow:auto;touch-action:pan-x pan-y pinch-zoom;overscroll-behavior:contain}.ai-chat-root .file-preview-body.is-document{align-items:stretch;justify-content:flex-start;padding:12px;background:var(--surface);min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y pinch-zoom;overscroll-behavior:contain}.ai-chat-root .file-preview-body iframe,.ai-chat-root .file-preview-body object,.ai-chat-root .file-preview-body video{width:100%;height:100%;border:none;background:#fff;display:block}.ai-chat-root .file-preview-body video{object-fit:contain}.ai-chat-root .file-preview-pdf-stage{width:100%;height:100%;overflow:auto;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y pinch-zoom;overscroll-behavior:contain}.ai-chat-root .file-preview-pdf-object{width:100%;height:100%;border:none;display:block;min-height:clamp(200px,50vh,520px);touch-action:pan-x pan-y pinch-zoom}.ai-chat-root .file-preview-image-stage{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#fff;touch-action:pan-x pan-y pinch-zoom;-webkit-user-select:none;user-select:none;cursor:zoom-in;overscroll-behavior:contain}.ai-chat-root .file-preview-image-stage.is-zoomed{cursor:grab}.ai-chat-root .file-preview-image-stage.is-dragging{cursor:grabbing}.ai-chat-root .file-preview-image-stage img{width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;display:block;transform-origin:center center;will-change:transform;transition:transform .08s ease}.ai-chat-root .file-preview-body iframe,.ai-chat-root .file-preview-body object{min-height:clamp(200px,50vh,520px)}.ai-chat-root .file-preview-body audio{width:100%}.ai-chat-root .file-preview-office{position:relative;width:100%;height:100%;overflow:auto;display:flex;flex-direction:column;gap:12px;min-height:0;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y pinch-zoom}.ai-chat-root .file-preview-docx,.ai-chat-root .file-preview-pptx{width:100%}.ai-chat-root .file-preview-spreadsheet{display:flex;flex-direction:column;gap:10px;width:100%;min-height:0}.ai-chat-root .file-preview-sheet-tabs{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.ai-chat-root .file-preview-sheet-tab{border:1px solid var(--border);background:var(--surface-alt);color:var(--text-secondary);border-radius:999px;padding:4px 10px;font-size:12px;line-height:1.4}.ai-chat-root .file-preview-sheet-tab.is-active{border-color:var(--border-strong);background:var(--surface);color:var(--text)}.ai-chat-root .file-preview-docx .docx-wrapper{padding:16px 0;background:var(--surface)}.ai-chat-root .file-preview-docx .docx-wrapper>section,.ai-chat-root .file-preview-docx .docx{margin:0 auto 16px;box-shadow:var(--shadow-sm)}.ai-chat-root .file-preview-pptx .pptx-wrapper{width:100%;transform-origin:top left}.ai-chat-root .file-preview-pptx{display:flex;flex-direction:column;gap:16px;width:100%}.ai-chat-root .file-preview-slide{display:flex;flex-direction:column;gap:12px;padding:16px;border:1px solid var(--border);border-radius:14px;background:#fff}.ai-chat-root .file-preview-slide-meta{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.ai-chat-root .file-preview-slide-title{font-size:15px;font-weight:600;color:var(--text)}.ai-chat-root .file-preview-slide-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.ai-chat-root .file-preview-slide-images img{width:100%;max-height:240px;object-fit:contain;display:block;border:1px solid var(--border);border-radius:10px;background:var(--surface-alt)}.ai-chat-root .file-preview-slide-texts{display:flex;flex-direction:column;gap:8px}.ai-chat-root .file-preview-slide-texts p{margin:0;font-size:13px;line-height:1.6;color:var(--text-secondary)}.ai-chat-root .file-preview-loading{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:120px;color:var(--text-muted)}.ai-chat-root .file-preview-body>.file-preview-loading{margin:auto}.ai-chat-root .file-preview-text-wrap{display:flex;flex-direction:column;gap:8px;width:100%;overflow:visible;min-height:0;touch-action:pan-x pan-y pinch-zoom}.ai-chat-root .file-preview-text{font-size:12px;line-height:1.6;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;margin:0}.ai-chat-root .file-preview-table-wrap{display:flex;flex-direction:column;gap:8px;width:100%;overflow:auto;min-height:0;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y pinch-zoom}.ai-chat-root .file-preview-table{width:max-content;min-width:100%;border-collapse:collapse;font-size:12px;color:var(--text-secondary)}.ai-chat-root .file-preview-table th,.ai-chat-root .file-preview-table td{border:1px solid var(--border);padding:6px 8px;text-align:left;vertical-align:top}.ai-chat-root .file-preview-table th{background:var(--surface-alt);font-weight:600;color:var(--text)}.ai-chat-root .file-preview-note{font-size:11px;color:var(--text-muted)}.ai-chat-root .file-preview-fallback{font-size:12px;color:var(--text-muted);padding:18px;text-align:center}.ai-chat-root .file-preview-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px}.ai-chat-root.file-preview-embedded{border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:10px;gap:8px;height:100%;min-height:0}.ai-chat-root.file-preview-embedded .file-preview-embedded-header{display:flex;flex-direction:column;gap:2px}.ai-chat-root.file-preview-embedded .file-preview-body{flex:1;min-height:0}.ai-chat-root.file-preview-embedded .file-preview-body iframe,.ai-chat-root.file-preview-embedded .file-preview-body object{min-height:0}.ai-chat-root.file-preview-embedded .file-preview-embedded-actions{padding-top:0}.ai-chat-root .file-preview-zoom-controls{display:inline-flex;align-items:center;gap:6px;margin-right:auto}.ai-chat-root .file-preview-zoom-label{min-width:48px;text-align:center;font-size:12px;font-weight:600;color:var(--text-secondary)}@keyframes file-preview-fade{0%{opacity:0}to{opacity:1}}@keyframes file-preview-pop{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.ai-chat-root .history-item-actions .file-preview-card.history-file-preview{width:172px;max-width:172px;min-width:0;padding:6px 8px;border-radius:10px;gap:8px}.ai-chat-root .history-item-actions .file-preview-card.history-file-preview .file-preview-thumb{width:28px;height:28px;border-radius:8px}.ai-chat-root .history-item-actions .file-preview-card.history-file-preview .file-preview-name{font-size:11px}.ai-chat-root .history-item-actions .file-preview-card.history-file-preview .file-preview-sub{font-size:10px}.pdf-data-shell{--pdf-data-surface: var(--surface, #ffffff);--pdf-data-surface-alt: var(--surface-alt, #f8fafc);--pdf-data-border: var(--border, #d8dee8);--pdf-data-text: var(--text, #1f2937);--pdf-data-text-muted: var(--text-muted, #64748b);--pdf-data-danger: var(--danger, #dc2626);--pdf-data-danger-soft: var(--danger-soft, #fef2f2);--pdf-data-warning: var(--warning, #b45309);--pdf-data-warning-soft: var(--warning-soft, #fef3c7);--pdf-data-accent: var(--primary, #0f766e);--pdf-data-radius: var(--radius, 12px);--pdf-data-radius-lg: var(--radius-lg, 16px);--pdf-data-shadow: var(--shadow-md, 0 18px 42px rgba(2, 6, 23, .18));position:relative;display:flex;flex:1;flex-direction:column;min-height:0;height:100%;overflow:hidden;color:var(--pdf-data-text)}.pdf-data-shell.is-inactive{display:none}.pdf-data-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;padding:0;background:#0f172a38;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .2s ease}.pdf-data-overlay.is-open{opacity:1;pointer-events:auto}.pdf-data-ai-panel{width:100%;height:100%;background:var(--pdf-data-surface);border:none;border-radius:inherit;box-shadow:none;padding:0;display:flex;flex-direction:column;gap:0;min-height:0;overflow:hidden}.pdf-data-ai-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--pdf-data-border);background:var(--pdf-data-surface)}.pdf-data-ai-panel-title{font-size:16px;font-weight:700}.pdf-data-ai-panel-sub{margin-top:4px;font-size:12px;color:var(--pdf-data-text-muted)}.pdf-data-ai-panel-body{flex:1;display:flex;min-height:0;overflow:hidden;border:none;border-radius:0;background:var(--pdf-data-surface-alt)}.pdf-data-ai-panel-body .ai-chat-root{flex:1;width:100%;height:100%;min-height:0;min-width:0}.pdf-data-ai-panel-body .ai-chat-root .chat-shell{height:100%;min-height:0;min-width:0;gap:12px}.pdf-data-ai-panel-body .ai-chat-root .chat-main{min-height:0;min-width:0;overflow:hidden}.pdf-data-ai-panel-body .ai-chat-root .chat-messages{min-height:0;padding:12px 0}.pdf-data-panel{border:1px solid var(--pdf-data-border);border-radius:var(--pdf-data-radius);background:var(--pdf-data-surface);display:none;flex-direction:column;gap:8px;min-height:0;overflow:hidden;flex:1}.pdf-data-panel.is-visible{display:flex}.pdf-data-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 12px 0}.pdf-data-panel-actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.pdf-data-panel .panel-section-title{font-size:13px;font-weight:700;line-height:1.2}.pdf-data-panel .hint{font-size:11px;color:var(--pdf-data-text-muted)}.pdf-data-textarea{flex:1;min-height:0;resize:none}.pdf-data-panel .config-error{margin:0 12px 8px;font-size:12px;color:var(--pdf-data-danger)}.pdf-data-export{border-top:1px solid var(--pdf-data-border);padding:12px;display:flex;flex-direction:column;gap:8px}.pdf-data-export-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.pdf-data-export-status{display:flex;align-items:center;gap:8px}.pdf-data-export-list{display:flex;flex-direction:column;gap:6px;max-height:180px;overflow:auto;padding-right:4px}.pdf-data-export-row{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.pdf-data-export-actions{display:inline-flex;align-items:center;gap:8px;flex-shrink:0}.pdf-data-export-link{color:var(--pdf-data-accent);text-decoration:none;font-size:13px;background:none;border:none;padding:0;cursor:pointer;text-align:left}.pdf-data-export-link:hover{text-decoration:underline}.pdf-data-export-link.is-active{font-weight:700}.pdf-data-export-bulk{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pdf-data-export-error{flex-basis:100%}.pdf-data-panel .chip{display:inline-flex;align-items:center;border-radius:999px;font-size:11px;font-weight:600;padding:4px 10px}.pdf-data-panel .chip-warning{background:var(--pdf-data-warning-soft);color:var(--pdf-data-warning)}.pdf-data-shell .alert{padding:12px 14px;border-radius:var(--pdf-data-radius);font-size:13px}.pdf-data-shell .alert-error{background:var(--pdf-data-danger-soft);color:#b91c1c;border:1px solid rgba(220,38,38,.2)}@media (max-width: 900px){.pdf-data-overlay{padding:0}.pdf-data-ai-panel{width:100%;height:100%;padding:0}.pdf-data-panel-header{flex-direction:column;align-items:stretch}}*,*:before,*:after{box-sizing:border-box}:root{--font: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Noto Sans JP", sans-serif;--font-display: "Rubik", "Zen Kaku Gothic New", sans-serif;--bg: #f6f2ea;--surface: #ffffff;--surface-alt: #fdf7ee;--border: #e7e0d3;--border-strong: #d9d0c0;--text: #1f2a30;--text-secondary: #42515c;--text-muted: #7b8794;--accent: #1c6b6f;--accent-strong: #125558;--accent-soft: #d8f2f3;--accent-2: #e07a3f;--accent-2-soft: #fde5d3;--success: #16a34a;--success-soft: #dcfce7;--warning: #d97706;--warning-soft: #fef3c7;--danger: #dc2626;--danger-soft: #fee2e2;--info: #0ea5e9;--info-soft: #e0f2fe;--shadow-sm: 0 2px 8px rgba(15, 23, 42, .08);--shadow-md: 0 16px 32px rgba(15, 23, 42, .12);--radius: 12px;--radius-lg: 18px}html{font-size:14px}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}.app-layout{min-height:100vh;height:100vh;display:flex;flex-direction:column;overflow:hidden}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;border-radius:999px;border:none;cursor:pointer;transition:all .2s ease;font-family:var(--font)}.btn:disabled{opacity:.5;cursor:not-allowed}.icon-button{width:32px;height:32px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:16px;line-height:1}.icon-button svg{width:16px;height:16px}.icon-button:hover:not(:disabled){border-color:var(--accent);color:var(--accent-strong);background:#1c6b6f14}.icon-button:disabled{opacity:.5;cursor:not-allowed}.icon-button-primary{border-color:var(--accent);color:var(--accent-strong);background:var(--accent-soft)}.icon-button-danger{border-color:#dc262633;color:var(--danger);background:var(--danger-soft)}.icon-button-flat{width:30px;min-width:30px;height:30px;padding:0;border-radius:8px;border-color:var(--border);background:var(--surface);color:var(--text-muted)}.icon-button-flat:hover:not(:disabled){border-color:var(--border-strong);color:var(--text);background:var(--surface-alt)}.icon-button-primary.icon-button-flat{border-color:var(--border);background:var(--surface);color:var(--text-muted)}.icon-button-primary.icon-button-flat:hover:not(:disabled){border-color:#0f766e5c;background:#ecfdf5d9;color:var(--accent-strong)}.icon-button-flat svg{width:14px;height:14px}.icon-button-flat svg.is-spinning{animation:spin .8s linear infinite}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 18px #1c6b6f3d}.btn-primary:hover:not(:disabled){background:var(--accent-strong);transform:translateY(-1px)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-alt);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:#1c6b6f14}.btn-danger{color:var(--danger)}.main-content{flex:1;padding:0;max-width:none;margin:0;width:100%;display:flex;flex-direction:column;min-height:0;overflow:hidden}.page-header{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;flex-wrap:wrap;margin-bottom:22px}.eyebrow{font-family:var(--font-display);font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--accent-strong);margin:0 0 6px}.page-title{margin:0 0 6px;font-size:28px;font-weight:700}.page-description{margin:0;color:var(--text-secondary);font-size:14px}.page-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border)}.card-header-compact{justify-content:space-between;padding:10px 14px}.card-header-left{display:flex;align-items:center;gap:10px}.view-toggle{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:999px;background:var(--surface);padding:2px;gap:2px}.view-toggle-button{border:none;background:transparent;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;color:var(--text-secondary);cursor:pointer}.view-toggle-button.is-active{background:var(--accent-soft);color:var(--accent-strong)}.card-title{margin:0;font-size:16px;font-weight:700}.card-subtitle{margin:4px 0 0;color:var(--text-muted);font-size:12px}.card-actions{display:flex;gap:8px;flex-wrap:wrap}.card-body{padding:16px}.select,.input,.textarea{width:100%;padding:10px 12px;font-size:14px;font-family:inherit;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237b8794' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.select-compact{width:auto;min-width:180px;padding:6px 28px 6px 10px;font-size:12px;border-radius:999px;background-position:right 10px center}.textarea{resize:vertical}.code-textarea{font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,Menlo,Noto Sans Mono CJK JP,Noto Sans JP,Yu Gothic UI,Meiryo,MS Gothic,monospace;font-size:12px;background:#111827;color:#f9fafb;border-color:#0f172a}.template-layout{position:relative;display:grid;grid-template-columns:minmax(0,1fr);gap:20px;--drawer-width: min(340px, 85vw)}.template-list-shell{position:absolute;inset:0 auto 0 0;width:var(--drawer-width);transform:translate(calc(-100% - 8px));opacity:0;pointer-events:none;transition:transform .25s ease,opacity .2s ease;z-index:3;display:flex}.template-list-shell.is-open{transform:translate(0);opacity:1;pointer-events:auto}.template-list-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a29;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:2}.template-list-card{width:100%;height:100%;display:flex;flex-direction:column}.template-list-card .card-body{overflow:auto}.template-editor-card{position:relative;z-index:1;flex:1;min-height:0;display:flex;flex-direction:column;background:transparent;border:none;box-shadow:none}.template-editor-card .card-header{border-bottom:none;padding-bottom:6px}.template-editor-card .card-body{padding-top:8px}.template-editor-body{flex:1;min-height:0;display:flex;flex-direction:column;gap:12px;overflow:hidden;position:relative}.template-settings-panel{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-alt);padding:10px;display:grid;gap:10px}.template-settings-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a38;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:6}.template-settings-overlay .template-settings-panel{width:min(720px,92vw);max-height:min(80vh,720px);overflow:auto;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:16px 16px 18px}.ai-overlay{z-index:8;opacity:0;pointer-events:none;transition:opacity .2s ease}.ai-overlay.is-open{opacity:1;pointer-events:auto}.ai-panel{width:min(1200px,96vw);height:min(86vh,900px);background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:16px;display:flex;flex-direction:column;gap:12px}.ai-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.ai-panel-title{font-weight:700;font-size:16px}.ai-panel-sub{font-size:12px;color:var(--text-muted);margin-top:4px}.ai-panel-body{flex:1;min-height:0;border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;display:flex;background:var(--surface-alt)}.template-settings-panel-header{display:flex;justify-content:flex-end;margin-bottom:6px}.template-settings-panel .form-grid{gap:10px;margin-bottom:0}.template-settings-panel .form-field{font-size:11px;gap:4px}.template-settings-panel .input,.template-settings-panel .select{padding:8px 10px;font-size:12px;border-radius:10px}.template-settings-panel .form-toggle{gap:6px}.template-settings-meta-section{margin-top:4px}.template-settings-meta-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.template-settings-meta-main{grid-template-columns:repeat(2,minmax(0,1fr))}.template-settings-meta-meta{grid-template-columns:minmax(0,1fr) auto}.template-settings-meta-required{flex-direction:row;align-items:center;gap:6px;margin:0;font-size:12px;color:var(--text)}.template-settings-meta-required input{width:14px;height:14px}.template-list{display:flex;flex-direction:column;gap:10px}.template-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-alt);cursor:pointer;text-align:left;transition:all .2s ease}.template-item.active,.template-item:hover{border-color:var(--accent);background:#1c6b6f14}.template-name{font-weight:600}.template-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}.form-field{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--text-muted)}.form-field span{font-weight:600;color:var(--text)}.form-field-wide{grid-column:1 / -1}.form-toggle{flex-direction:row;align-items:center;gap:8px;font-size:13px}.form-toggle input{width:16px;height:16px}.form-field-header{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px}.json-section{gap:8px}.json-toggle{align-self:flex-start;border-radius:999px;border:1px solid var(--border);background:var(--surface);padding:4px 10px;font-size:11px;font-weight:600;color:var(--text-secondary);cursor:pointer}.json-toggle.is-open{border-color:var(--accent);color:var(--accent-strong);background:var(--accent-soft)}.btn-xs{padding:4px 10px;font-size:11px}.btn-icon{padding:4px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center}.btn-icon svg{display:block}.input-small,.select-small{padding:6px 8px;font-size:12px;min-width:110px}.template-config-visual{border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface-alt);padding:12px;display:flex;flex-direction:column;gap:12px}.template-editor-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1.1fr);grid-template-areas:"preview side";gap:14px;align-items:start;flex:1;min-height:0;height:100%;overflow:hidden}.template-editor-side{grid-area:side;display:flex;flex-direction:column;gap:12px;min-height:0;height:100%;overflow:hidden}.template-editor-workspace{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:12px;align-items:start;min-height:0;height:100%}.template-editor-workspace.is-hidden{display:none}.layout-canvas{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-alt);padding:12px;display:flex;flex-direction:column;gap:12px;min-height:0;overflow:hidden;height:100%}.layout-canvas-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.layout-canvas-title{font-weight:700}.layout-canvas-sub{font-size:11px;color:var(--text-muted)}.layout-section-list{display:flex;flex-direction:column;gap:12px;flex:1;min-height:0;overflow:auto;padding-right:4px}.layout-section{position:relative;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:10px;display:flex;flex-direction:column;gap:10px;transition:border-color .2s ease,box-shadow .2s ease}.layout-section.is-active{border-color:var(--accent);box-shadow:0 0 0 1px #1c6b6f33}.layout-section.is-section-drop-before:before,.layout-section.is-section-drop-after:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none}.layout-section.is-section-drop-before:before{background:linear-gradient(to bottom,rgba(28,107,111,.14) 0%,rgba(28,107,111,.14) 50%,transparent 50%,transparent 100%)}.layout-section.is-section-drop-after:before{background:linear-gradient(to bottom,transparent 0%,transparent 50%,rgba(28,107,111,.14) 50%,rgba(28,107,111,.14) 100%)}.layout-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.layout-section-title-row{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.layout-section-title-row .input{flex:1;min-width:0}.layout-section-handle{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:8px;border:1px solid var(--border);background:var(--surface-alt);color:var(--text-muted);cursor:grab;font-weight:700;line-height:1;padding:0}.layout-section-handle:hover{border-color:var(--accent);color:var(--accent-strong)}.layout-section-handle:active{cursor:grabbing}.layout-section-actions{display:flex;align-items:center;gap:8px}.layout-block-list{display:flex;flex-direction:column;gap:8px}.layout-block{position:relative;border:1px solid var(--border);border-radius:var(--radius);background:#fff;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:grab;transition:border-color .2s ease,transform .2s ease}.layout-block:active{cursor:grabbing}.layout-block.is-active{border-color:var(--accent);background:var(--accent-soft)}.layout-block.is-drop-target{border-style:dashed;border-color:var(--accent-strong)}.layout-block.is-drop-before:before,.layout-block.is-drop-after:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none}.layout-block.is-drop-before:before{background:linear-gradient(to bottom,rgba(28,107,111,.16) 0%,rgba(28,107,111,.16) 50%,transparent 50%,transparent 100%)}.layout-block.is-drop-after:before{background:linear-gradient(to bottom,transparent 0%,transparent 50%,rgba(28,107,111,.16) 50%,rgba(28,107,111,.16) 100%)}.layout-block-info{display:flex;flex-direction:column;gap:2px}.layout-block-label{font-weight:600}.layout-block-meta{font-size:11px;color:var(--text-muted)}.layout-block-actions{display:flex;align-items:center;gap:6px}.layout-block-empty{font-size:12px;color:var(--text-muted);padding:10px;border-radius:var(--radius);border:1px dashed var(--border);background:#fff9}.layout-drop-hint{font-size:11px;color:var(--accent-strong);padding:6px 8px;border-radius:999px;border:1px dashed var(--accent-strong);align-self:flex-start}.layout-panel{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:12px;display:flex;flex-direction:column;gap:10px;min-height:0;overflow:auto;height:100%}.layout-panel-header{display:flex;align-items:center;justify-content:space-between}.layout-panel-title{font-weight:700;font-size:14px}.layout-panel-sub{font-size:11px;color:var(--text-muted)}.panel-section{display:flex;flex-direction:column;gap:8px;padding-top:6px;border-top:1px dashed var(--border)}.panel-section:first-of-type{border-top:none;padding-top:0}.panel-section-title{font-size:12px;font-weight:600;color:var(--text)}.hint-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-left:6px;border-radius:999px;border:1px solid var(--border);color:var(--text-muted);font-size:10px;line-height:1;cursor:help;-webkit-user-select:none;user-select:none;background:var(--surface-alt)}.panel-field{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--text-muted)}.color-field{display:grid;grid-template-columns:36px minmax(0,1fr);gap:8px;align-items:center}.color-input{width:36px;height:36px;padding:0;border:1px solid var(--border);border-radius:10px;background:transparent;cursor:pointer}.color-input::-webkit-color-swatch-wrapper{padding:2px}.color-input::-webkit-color-swatch{border:none;border-radius:8px}.panel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.panel-subgrid{display:flex;flex-direction:column;gap:8px}.panel-inline-row{display:flex;flex-direction:column;gap:8px;padding:10px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-alt)}.panel-inline-main{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.panel-inline-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr)) auto;gap:8px;align-items:center}.panel-inline-meta .btn{justify-self:end}.panel-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;background:var(--accent-soft);color:var(--accent-strong);width:fit-content}.template-editor-config{display:flex;flex-direction:column;gap:12px}.template-preview-panel{grid-area:preview;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:0;display:flex;flex-direction:column;gap:12px;min-height:500px;overflow:hidden;height:100%}.template-json-panel,.template-test-panel{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:0;display:none;flex-direction:column;gap:8px;max-height:38%;min-height:0;overflow:auto}.template-json-panel.is-visible,.template-test-panel.is-visible{display:flex;flex:1;max-height:none}.test-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 12px 0}.test-panel-actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.test-panel-export{border-top:1px solid var(--border);padding:12px;display:flex;flex-direction:column;gap:8px}.test-panel-export-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.test-panel-export-status{display:flex;align-items:center;gap:8px}.test-panel-export-list{display:flex;flex-direction:column;gap:6px;max-height:180px;overflow:auto;padding-right:4px}.test-panel-export-link{color:var(--primary);text-decoration:none;font-size:13px;background:none;border:none;padding:0;cursor:pointer;text-align:left;font-family:var(--font)}.test-panel-export-link:hover{text-decoration:underline}.test-panel-export-link.is-active{font-weight:700}.test-panel-export-row{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.test-panel-export-actions{display:inline-flex;align-items:center;gap:8px;flex-shrink:0}.test-panel-export-bulk{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.test-panel-export-error{flex-basis:100%}.json-editor-textarea{flex:1;min-height:0;resize:none}.preview-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.preview-title{font-weight:700;font-size:14px}.preview-sub{font-size:11px;color:var(--text-muted)}.preview-frame{position:relative;border-radius:var(--radius);border:1px solid var(--border);background:#fff;overflow:hidden;display:flex;align-items:center;justify-content:center;flex:1;min-height:0}.preview-status{position:absolute;top:10px;right:10px;z-index:1}.preview-iframe{width:100%;height:100%;min-height:0;border:none}.preview-placeholder,.preview-error{font-size:12px;color:var(--text-muted);padding:16px;text-align:center}.preview-error{color:var(--danger)}.visual-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.visual-section{display:flex;flex-direction:column;gap:12px}.visual-section-header{display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:600;color:var(--text)}.visual-toggle-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.visual-toggle{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.visual-toggle input{width:16px;height:16px}.visual-list{display:flex;flex-direction:column;gap:10px}.visual-row{display:grid;grid-template-columns:minmax(140px,2fr) minmax(140px,2fr) minmax(120px,1.2fr) minmax(120px,1.2fr) minmax(90px,.9fr) auto;gap:8px;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px}.visual-row.is-summary{grid-template-columns:minmax(150px,2fr) minmax(150px,2fr) minmax(120px,1.2fr) auto}.visual-row-actions{display:inline-flex;align-items:center;gap:6px;justify-content:flex-end}.config-empty{font-size:12px;color:var(--text-muted);padding:12px;border-radius:var(--radius);border:1px dashed var(--border);background:#fff9}.config-error{margin-top:8px;font-size:12px;color:var(--danger)}.hint{font-size:11px;color:var(--text-muted)}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:12px;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;background:var(--accent-soft);color:var(--accent-strong)}.chip-success{background:var(--success-soft);color:var(--success)}.chip-warning{background:var(--warning-soft);color:var(--warning)}.alert{padding:12px 14px;border-radius:var(--radius);margin-bottom:16px;font-size:13px}.alert-error{background:var(--danger-soft);color:#b91c1c;border:1px solid rgba(220,38,38,.2)}.alert-info{background:var(--info-soft);color:#0369a1;border:1px solid #bae6fd}.status-toast{position:fixed;top:12px;left:50%;transform:translate(-50%);z-index:30;margin-bottom:0;box-shadow:var(--shadow-sm);max-width:min(520px,calc(100% - 32px));text-align:center;pointer-events:none}.loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--text-muted)}.loading-spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.empty-state{text-align:center;padding:24px 16px;color:var(--text-muted);display:flex;flex-direction:column;gap:12px;align-items:center}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 960px){.app-layout{height:auto;overflow:visible}.main-content{overflow:visible}.template-editor-card{flex:none}.template-layout{grid-template-columns:1fr}.template-editor-grid{grid-template-columns:1fr;grid-template-areas:"preview" "side";flex:none;min-height:auto}.template-editor-side{height:auto;overflow:visible}.template-json-panel{max-height:none}.template-editor-workspace,.visual-grid{grid-template-columns:1fr}.visual-row,.visual-row.is-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.visual-row-actions{grid-column:1 / -1;justify-content:flex-end}.panel-grid,.panel-inline-main,.panel-inline-meta,.template-settings-meta-main,.template-settings-meta-meta{grid-template-columns:1fr}.panel-inline-meta .btn{justify-self:start}}@media (max-width: 640px){.main-content{padding:0}.template-settings-overlay{padding:16px;align-items:flex-start}.template-settings-overlay .template-settings-panel{max-height:calc(100% - 32px)}.ai-panel{width:100%;height:calc(100% - 32px);padding:12px}.form-grid,.visual-row,.visual-row.is-summary{grid-template-columns:1fr}.visual-row-actions{justify-content:flex-start}}
