/* LEE I.A. Web — site.css v3 */

/* ─── THEME: Consultant ───────────────────────────────────────── */
[data-theme="theme-consultant"], :root {
    --accent-primary: #D4AF37; --accent-highlight: #2A8B92;
    --bg-gradient: linear-gradient(135deg, #FEFDF8 0%, #FAF5E4 55%, #FFFFFF 100%);
    --btn-gradient: linear-gradient(90deg, #DFB744 0%, #AF8615 100%);
    --btn-gradient-hover: linear-gradient(90deg, #EAC458 0%, #99730D 100%);
    --highlight-gradient: linear-gradient(135deg, #439CA4 0%, #2A8B92 50%, #165B62 100%);
    --bg-gradient-menu: linear-gradient(135deg, #FCF6BA 0%, #BF953F 80%, #B38728 100%);
    --bg-gradient-menu-hover: linear-gradient(135deg, #FFF 0%, #D4A84D 70%, #C49835 100%);
    --text-primary: #2B261A; --text-secondary: #80755A; --text-tertiary: #BDB59D; --text-inverse: #FFF;
    --bg-secondary: #F8F6F0; --bg-tertiary: #F2EBD4; --bg-inverse: #FFF;
    --glass-bg: rgba(255,255,255,0.75); --glass-border: rgba(255,255,255,0.9); --glass-blur: 24px;
    --shadow-soft: 0 8px 32px rgba(212,175,55,0.15); --shadow-glow: 0 6px 20px rgba(212,175,55,0.4);
    --separator-color: rgba(212,175,55,0.15); --error-color: #FF6B6B; --success-color: #2DCE89;
}
/* ─── THEME: Integration ──────────────────────────────────────── */
[data-theme="theme-integration"] {
    --accent-primary: #7265c1; --accent-highlight: #D4AF37;
    --bg-gradient: linear-gradient(135deg, #F8F7FD 0%, #EEE9FA 55%, #FFFFFF 100%);
    --btn-gradient: linear-gradient(90deg, #b9addf 0%, #7265c1 100%);
    --btn-gradient-hover: linear-gradient(90deg, #C4B8E8 0%, #5D52A0 100%);
    --highlight-gradient: linear-gradient(135deg, #CFA655 0%, #F3E5AB 50%, #CFA655 100%);
    --bg-gradient-menu: linear-gradient(135deg, #E8E3F5 0%, #9B8FD0 80%, #7265c1 100%);
    --bg-gradient-menu-hover: linear-gradient(135deg, #FFF 0%, #B5A8E0 70%, #8B7DC8 100%);
    --text-primary: #1E1B2E; --text-secondary: #6B6680; --text-tertiary: #A5A1B5; --text-inverse: #FFF;
    --bg-secondary: #F4F4F5; --bg-tertiary: #E8E3F5; --bg-inverse: #FFF;
    --glass-bg: rgba(255,255,255,0.75); --glass-border: rgba(255,255,255,0.9); --glass-blur: 24px;
    --shadow-soft: 0 8px 32px rgba(114,101,193,0.10); --shadow-glow: 0 6px 20px rgba(114,101,193,0.4);
    --separator-color: rgba(114,101,193,0.15);
}

/* ─── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{height:100%;-webkit-text-size-adjust:100%}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',Arial,sans-serif;font-size:15px;line-height:1.5;color:var(--text-primary);background:var(--bg-gradient);height:100vh;height:100dvh;overflow:hidden;display:flex;flex-direction:column}
a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font:inherit}input,textarea,select{font:inherit}
[x-cloak]{display:none!important}.w-full{width:100%}

/* ═══ LAYOUT — unified single DOM (no duplicate content) ═══ */
.site-header{flex-shrink:0;z-index:30;border-bottom:1px solid var(--separator-color);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur))}

.app-layout{display:flex;flex:1;min-height:0;overflow:hidden;position:relative}

/* Sidebar — on desktop always visible, on mobile overlay drawer */
.app-sidebar{
    display:none;           /* hidden on mobile by default */
    flex-direction:column;
    width:350px;flex-shrink:0;min-height:0;overflow:hidden;
    border-right:1px solid var(--separator-color);
    background:var(--bg-secondary);
    z-index:25;
}
/* Mobile: show as overlay when toggled */
.app-sidebar.sidebar-open{
    display:flex;
    position:fixed;top:0;left:0;bottom:0;width:85%;max-width:320px;
    z-index:40;
    box-shadow:8px 0 32px rgba(0,0,0,.2);
    padding-top:53px; /* below header */
}
.sidebar-backdrop{
    display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:35;
}
.app-sidebar.sidebar-open ~ .sidebar-backdrop{display:block}

/* Main content — always takes remaining space */
.app-main {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    min-width: 0;
    overflow: hidden;    
}

/* Desktop: sidebar is inline grid column */
@media(min-width:768px){
    .app-layout{display:grid;grid-template-columns:350px 1fr}
    .app-sidebar{display:flex!important;position:static!important;width:auto!important;max-width:none!important;box-shadow:none!important;padding-top:0!important}
    .app-sidebar.sidebar-open{position:static!important}
    .sidebar-backdrop{display:none!important}
    .bottom-nav{display:none!important}
    .app-main{padding-bottom:0}
}

/* Bottom nav — mobile only */
/*.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:30;display:flex;border-top:1px solid var(--separator-color);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));padding-bottom:env(safe-area-inset-bottom,0)}
*/
.bottom-nav {
    width: 100%;
    flex-shrink: 0;
    z-index: 30;
    display: flex;
    border-top: 1px solid var(--separator-color);
    background: var(--glass-bg);
    backdrop-filter: blur(var(--glass-blur));
    padding-bottom: env(safe-area-inset-bottom, 0px); 
}


/* ═══ HEADER ═══ */
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;gap:12px}
.header-logo{display:flex;align-items:center;gap:6px}.logo-icon{font-size:18px;color:var(--accent-highlight)}.logo-text{font-weight:700;font-size:16px;color:var(--text-primary);letter-spacing:.5px}
.header-balance{display:flex;align-items:center;gap:8px;padding:5px 12px;border-radius:12px;border:1px solid var(--separator-color);background:var(--bg-inverse)}
.balance-label{font-size:12px;color:var(--text-secondary)}.balance-value{font-weight:700;font-size:14px;color:var(--accent-primary)}.balance-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-primary)}
.header-controls{display:flex;align-items:center;gap:8px}
.btn-creator-panel{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:12px;font-size:12px;font-weight:600;color:var(--text-inverse);background:var(--btn-gradient);white-space:nowrap;transition:all .2s}
.btn-creator-panel:hover{background:var(--btn-gradient-hover)}.chevron{transition:transform .2s}.chevron.rotate{transform:rotate(180deg)}
.btn-lang{display:flex;align-items:center;gap:4px;padding:6px 10px;border-radius:12px;font-size:12px;font-weight:600;color:var(--text-secondary);border:1px solid var(--separator-color);background:var(--bg-inverse)}

/* Dropdowns */
.dropdown-wrap{position:relative}
.dropdown-menu{position:absolute;right:0;top:100%;margin-top:4px;min-width:200px;background:var(--bg-inverse);border:1px solid var(--separator-color);border-radius:12px;box-shadow:var(--shadow-soft);overflow:hidden;z-index:50}
.dropdown-menu--lang{min-width:70px}
.dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:14px;font-weight:500;color:var(--text-primary);transition:background .15s;border-bottom:1px solid var(--separator-color)}
.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background:var(--bg-secondary)}.dropdown-item.active{color:var(--accent-primary);font-weight:700}
.dropdown-item--danger{color:var(--error-color)}.dropdown-icon{font-size:16px;width:20px;text-align:center}
[data-theme="theme-consultant"] .dropdown-item:hover,
:root .dropdown-item:hover {
    background: rgba(212, 175, 55, 0.08) !important;
    color: var(--accent-primary) !important;
}
[data-theme="theme-integration"] .dropdown-item:hover {
    background: rgba(114, 101, 193, 0.08) !important;
    color: var(--accent-primary) !important;
}

/* ═══ SIDEBAR ═══ */
.sidebar-inner{display:flex;flex-direction:column;height:100%;min-height:0;background:var(--bg-secondary)}

/* Product Switcher — compact grid, wraps for 3+ products */
.product-switcher{display:flex;flex-wrap:wrap;gap:6px;padding:10px;border-bottom:1px solid var(--separator-color);background: linear-gradient(180deg, var(--glass-bg) 0%, var(--bg-secondary) 100%);flex-shrink:0}
.product-pill{padding:7px 14px;font-size:13px;font-weight:600;border-radius:20px;white-space:nowrap;color:var(--text-secondary);background:var(--bg-inverse);border:1.5px solid var(--separator-color);transition:all .25s ease;flex:1;min-width:0;text-align:center}
.product-pill:hover{border-color:var(--accent-primary);color:var(--text-primary)}
.product-pill.active{background:var(--btn-gradient);color:var(--text-inverse);border-color:transparent;box-shadow:var(--shadow-glow)}
.product-pill:hover:not(.active) {
    background: var(--bg-tertiary) !important;
    border-color: var(--accent-primary) !important;
}

.section-nav{display:flex;flex-direction:column;gap:2px;padding:10px;border-bottom:1px solid var(--separator-color);background:var(--bg-secondary);flex-shrink:0}
.nav-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:10px;font-size:14px;font-weight:500;color:var(--text-primary);transition:all .15s;text-align:left;width:100%}
.nav-item:hover{background:rgba(255,255,255,.6)}.nav-item.active{background:var(--btn-gradient);color:var(--text-inverse);box-shadow:0 2px 8px rgba(0,0,0,.1)}
[data-theme="theme-consultant"] .nav-item:hover:not(.active),
:root .nav-item:hover:not(.active) {
    background: rgba(212, 175, 55, 0.10) !important;
    color: var(--accent-primary) !important;
}
[data-theme="theme-integration"] .nav-item:hover:not(.active) {
    background: rgba(114, 101, 193, 0.10) !important;
    color: var(--accent-primary) !important;
}


/* Session list */
.session-list-wrap{display:flex;flex-direction:column;flex:1;min-height:0;padding:10px 10px 0;overflow:hidden}
.btn-new-session{width:100%;padding:10px;border-radius:12px;font-size:14px;font-weight:600;color:var(--text-inverse);background:var(--btn-gradient);box-shadow:var(--shadow-glow);margin-bottom:8px;transition:all .2s;flex-shrink:0}
.btn-new-session:hover{background:var(--btn-gradient-hover)}.session-hint{font-size:12px;color:var(--text-tertiary);padding:0 4px 4px;flex-shrink:0}
.btn-new-session:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    box-shadow: none;
    background: var(--text-tertiary);
}

/* Elegant scrollbar */
.session-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:20px;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.08) transparent}
.session-list::-webkit-scrollbar{width:5px}
.session-list::-webkit-scrollbar-track{background:transparent}
.session-list::-webkit-scrollbar-thumb{background:rgba(0,0,0,.08);border-radius:10px}
.session-list::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.15)}

/* Session Card */
.session-card{margin-bottom:6px;padding:10px 12px;border-radius:12px;background:var(--glass-bg);border:2px solid transparent;cursor:pointer;transition:all .2s}
.session-card:hover{background:var(--bg-inverse);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.session-card--active{border-color:var(--accent-primary)!important;background:var(--bg-inverse);box-shadow:0 0 0 1px rgba(212,175,55,.2)}
[data-theme="theme-consultant"] .session-card:hover,
:root .session-card:hover {
    border-color: rgba(212, 175, 55, 0.4) !important;
    background: var(--bg-inverse) !important;
    box-shadow: 0 3px 10px rgba(212, 175, 55, 0.12) !important;
}
[data-theme="theme-integration"] .session-card:hover {
    border-color: rgba(114, 101, 193, 0.4) !important;
    background: var(--bg-inverse) !important;
    box-shadow: 0 3px 10px rgba(114, 101, 193, 0.12) !important;
}
.section-body h2{font-size:20px;font-weight:600;margin:0 0 12px;color:var(--text-primary)}
.section-body h3{font-size:16px;font-weight:600;margin:0 0 12px;color:var(--text-primary)}

.sc-row-title{display:flex;align-items:center;gap:8px}
.sc-status-icon{flex-shrink:0;width:18px;text-align:center;font-size:11px;line-height:1}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%}
.dot--current{background:var(--accent-primary);box-shadow:0 0 6px var(--accent-primary)}
.dot--active{background:var(--success-color)}
.dot--completed{background:var(--accent-highlight);width:auto;height:auto;font-size:11px;color:var(--accent-highlight)}
.dot--closed{background:none;width:auto;height:auto;font-size:11px;color:var(--text-tertiary)}
.dot--archive{background:none;width:auto;height:auto;font-size:11px;color:var(--separator-color)}
.sc-title{font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}

.sc-row-meta{display:flex;align-items:center;justify-content:space-between;margin-top:4px;padding-left:26px;gap:4px}
.sc-date{font-size:11px;color:var(--text-tertiary);white-space:nowrap}
.sc-actions{display:flex;align-items:center;gap:2px}
.sc-badge{font-size:12px;cursor:default}
.sc-btn{font-size:14px;padding:2px 4px;border-radius:6px;color:var(--text-secondary);transition:all .15s;line-height:1}
.sc-btn:hover{background:rgba(0,0,0,.06);transform:scale(1.1)}.sc-btn--danger{color:var(--text-tertiary)}.sc-btn--danger:hover{color:var(--error-color)}

/* ═══ MAIN CONTENT ═══ */
.section-container{display:flex;flex-direction:column;height:100%}
.section-header{padding:16px 20px;border-bottom:1px solid var(--separator-color);background:var(--glass-bg);flex-shrink:0}
.section-header h2{font-size:16px;font-weight:700;color:var(--text-primary)}.section-count{font-size:12px;color:var(--text-secondary);margin-top:2px}
.section-body{flex:1;overflow-y:auto;padding:16px 20px;-webkit-overflow-scrolling:touch}
.section-hint{font-size:14px;color:var(--text-secondary);margin-bottom:16px;line-height:1.6}

/* ═══ CHAT ═══ */
.chat-container{display:flex;flex-direction:column;height:100%;min-height:0}
.chat-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--separator-color);background:var(--glass-bg);flex-shrink:0;gap:10px}
.chat-title{font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.chat-header-actions{display:flex;gap:6px;flex-shrink:0}
.chat-no-tokens {
    padding: 16px;
    text-align: center;
    flex-shrink: 0;
    border-top: 1px solid var(--separator-color);
    background: var(--glass-bg);
}
.btn-chat-action{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:10px;font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--bg-inverse);border:1px solid var(--separator-color);transition:all .2s}
.btn-chat-action:hover{background:var(--bg-secondary)}.btn-chat-action:disabled{opacity:.5;cursor:not-allowed}
.btn-label-desktop{display:none}@media(min-width:768px){.btn-label-desktop{display:inline}}


.messages-area{flex:1;min-height:0;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:10px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.06) transparent}
.messages-area::-webkit-scrollbar{width:4px}.messages-area::-webkit-scrollbar-track{background:transparent}.messages-area::-webkit-scrollbar-thumb{background:rgba(0,0,0,.06);border-radius:4px}
.empty-chat{display:flex;align-items:center;justify-content:center;flex:1;color:var(--text-tertiary);font-size:14px}

.message{max-width:85%;display:flex;flex-direction:column}
.message-user{align-self:flex-end;background:var(--bg-tertiary);border-radius:16px 16px 4px 16px;box-shadow:0 4px 15px rgba(212,175,55,.15)}
.message-assistant{align-self:flex-start;background:var(--bg-inverse);border-radius:16px 16px 16px 4px;box-shadow:0 2px 10px rgba(0,0,0,.05)}
.message-content{padding:10px 14px;font-size:14px;line-height:1.6;color:var(--text-primary);word-break:break-word}
.message-content strong{font-weight:600}

.typing-indicator{display:flex;gap:4px;align-items:center}
.loader-dots{animation:blink 1.4s infinite both;font-size:10px;color:var(--accent-primary)}.loader-dots:nth-child(2){animation-delay:.2s}.loader-dots:nth-child(3){animation-delay:.4s}
@keyframes blink{0%{opacity:.2}20%{opacity:1}100%{opacity:.2}}

/* Inline Insight Card (integration) */
.insight-card-inline{margin:12px 0;padding:12px;background:var(--highlight-gradient);border:1px solid var(--accent-highlight);border-radius:16px;animation:slideUp .4s ease-out}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.insight-card-inline-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:var(--text-primary)}
.insight-card-inline-header .icon{font-size:20px;color:var(--accent-highlight)}
.insight-card-inline-header .title{font-size:16px;font-weight:600}
.insight-card-inline-header .subtitle{font-size:12px;opacity:.7}
.insight-inline-text{font-size:14px;color:var(--text-primary);line-height:1.6;white-space:pre-wrap}

.chat-input-bar{padding:12px 16px;border-top:1px solid var(--separator-color);background:var(--glass-bg);flex-shrink:0}
.input-wrap{display:flex;align-items:flex-end;gap:10px;padding:10px 14px;border-radius:20px;border:1px solid var(--accent-primary);background:var(--bg-inverse)}
.chat-input{flex:1;resize:none;border:none;outline:none;background:transparent;color:var(--text-primary);font-size:15px;line-height:1.4;min-height:24px;max-height:180px}
.chat-input::placeholder{color:var(--text-tertiary)}
.send-btn{width:40px;height:40px;border-radius:50%;background:var(--btn-gradient);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-glow);transition:transform .1s}
.send-btn:active{transform:scale(.95)}.send-btn:disabled{background:var(--text-tertiary);box-shadow:none}
.input-hint{font-size:11px;color:var(--text-tertiary);text-align:center;margin-top:6px}

/* ═══ BUTTONS ═══ */
.btn-primary{background:var(--btn-gradient);color:var(--text-inverse);padding:10px 16px;border:none;font-weight:600;border-radius:12px;box-shadow:var(--shadow-glow);transition:all .2s}
.btn-primary:hover{background:var(--btn-gradient-hover)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{background:var(--text-tertiary);cursor:not-allowed;box-shadow:none}
.btn-sm{padding:6px 12px;font-size:13px}
.btn-secondary{padding:10px 16px;background:rgba(255,255,255,.5);color:var(--accent-primary);border:1px solid var(--separator-color);border-radius:12px;font-weight:500;transition:all .2s}
.btn-secondary:hover{background:var(--bg-secondary)}
.btn-delete-confirm{background:var(--error-color)!important;box-shadow:none!important}
.btn-icon{background:none;border:none;font-size:16px;padding:4px;cursor:pointer;border-radius:6px;color:var(--text-secondary);transition:background .2s}.btn-icon:hover{background:rgba(0,0,0,.05)}
.btn-danger{color:var(--error-color)}.btn-link{font-size:12px;color:var(--accent-highlight);background:none;border:none;cursor:pointer}
[data-theme="theme-consultant"] .btn-primary:hover,
[data-theme="theme-consultant"] .btn-new-session:hover,
[data-theme="theme-consultant"] .btn-creator-panel:hover,
:root .btn-primary:hover,
:root .btn-new-session:hover,
:root .btn-creator-panel:hover {
    background: var(--btn-gradient-hover) !important;
    box-shadow: 0 8px 24px rgba(175, 134, 21, 0.45) !important;
    transform: translateY(-1px);
}
[data-theme="theme-integration"] .btn-primary:hover,
[data-theme="theme-integration"] .btn-new-session:hover,
[data-theme="theme-integration"] .btn-creator-panel:hover {
    background: var(--btn-gradient-hover) !important;
    box-shadow: 0 8px 24px rgba(93, 82, 160, 0.45) !important;
    transform: translateY(-1px);
}
/* Active (press) — reset transform */
.btn-new-session:active,
.btn-creator-panel:active {
    transform: scale(0.97);
}

/* ═══ FORMS ═══ */
.input-field{width:100%;background:var(--bg-inverse);border:1px solid var(--separator-color);border-radius:12px;padding:12px 16px;color:var(--text-primary);font-size:15px;outline:none;transition:border-color .2s}
.input-field::placeholder{color:var(--text-tertiary)}.input-field:focus{border-color:var(--accent-primary)}
.form-group{margin-bottom:12px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}
select.input-field{appearance:none;-webkit-appearance:none;cursor:pointer}

/* ═══ MODALS ═══ */
.modal-overlay{position:fixed;inset:0;background:rgba(26,43,66,.6);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:16px;z-index:1000}
.modal-content{background:var(--highlight-gradient);border-radius:16px;max-width:480px;width:100%;box-shadow:0 20px 40px rgba(0,0,0,.2);max-height:90vh;max-height:90dvh;display:flex;flex-direction:column}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--separator-color);border-radius:16px 16px 0 0;flex-shrink:0}
.modal-header--accent{}
.modal-header--accent h3{color:var(--text-inverse)}
.modal-title-row{display:flex;align-items:center;gap:8px}.modal-title-row h3{font-size:16px;font-weight:700}
.modal-close{font-size:24px;color:var(--text-tertiary);cursor:pointer;line-height:1;background:none;border:none}
.modal-body{padding:16px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:10px}
.modal-footer{display:flex;gap:8px;padding:16px;border-top:1px solid var(--separator-color)}.modal-footer>*{flex:1}
.post-int-text{font-size:14px;line-height:1.6;color:var(--text-primary)}
.modal-header--teal {
    
}
.modal-sm{max-width:380px; background:var(--bg-inverse)}
.modal-sm .modal-header {background:var(--bg-tertiary);}
.modal-header--teal h3 {
    color: var(--text-inverse);
}
/* Integration insights modal */
.modal-insight-integration {
    max-width: min(700px, 95vw);
    width: 100%;
}
/* Consultant summaries + insights modals */
.modal-summary-consultant,
.modal-insight-consultant {
    max-width: min(700px, 95vw);
    width: 100%;
}
.modal-insight-integration .btn-secondary,
.modal-summary-consultant .btn-secondary,
.modal-insight-consultant .btn-secondary,
.modal-insight-product .btn-secondary {
   color: var(--text-inverse);
}
.modal-insight-integration .btn-secondary:hover,
.modal-summary-consultant .btn-secondary:hover,
.modal-insight-consultant .btn-secondary:hover,
.modal-insight-product .btn-secondary:hover {
    color: var(--accent-primary);
}

/* Override base modal-content max-width for large modals */
.modal-insight-integration,
.modal-summary-consultant,
.modal-insight-consultant {
    max-height: 92vh;
    max-height: 92dvh;
}
.modal-header--product {
    
}
.modal-header--product h3 {
    color: var(--text-inverse);
}


/* ═══ INSIGHTS/SUMMARIES ═══ */
.insights-grid{display:grid;gap:12px;grid-template-columns:1fr}@media(min-width:640px){.insights-grid{grid-template-columns:1fr 1fr}}
.insight-card-web,.summary-card{border-radius:16px;padding:14px;border:1px solid var(--separator-color);background:var(--bg-inverse);box-shadow:0 2px 8px rgba(0,0,0,.04)}
.insight-card-top,.summary-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.insight-card-title{font-size:14px;font-weight:600;color:var(--text-primary)}
.insight-card-text,.summary-card-text{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-top:6px}
.insight-card-footer,.summary-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px}
.insight-date,.summary-date{font-size:12px;color:var(--accent-primary)}.summaries-list{display:flex;flex-direction:column;gap:12px}

/* ═══ EMPTY/LOADING ═══ */
.empty-state{text-align:center;padding:48px 16px}.empty-icon{font-size:48px;margin-bottom:12px}
.empty-label{font-size:14px;font-weight:600;color:var(--text-primary)}.empty-desc{font-size:13px;color:var(--text-secondary);margin-top:4px;max-width:280px;margin-inline:auto}
.empty-state-small{text-align:center;padding:24px 8px;color:var(--text-tertiary);font-size:13px}
.loading-indicator{display:flex;justify-content:center;padding:24px}
.spinner{width:24px;height:24px;border:2px solid var(--separator-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.error-message{color:var(--error-color);font-size:13px;margin-top:8px}.success-message{color:var(--success-color);font-size:13px;margin-top:8px}

/* ═══ BOTTOM NAV ═══ */
.bottom-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 0;gap:2px;font-size:11px;font-weight:500;color:var(--text-tertiary);transition:color .15s}
.bottom-nav-btn.active{color:var(--accent-primary)}.bottom-nav-btn svg{stroke:currentColor}
.mobile-sections-panel{padding:16px}.mobile-sections-title{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:8px}
.mobile-sections-nav{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}
.mobile-section-link{display:block;padding:10px 14px;border-radius:12px;font-size:14px;font-weight:500;color:var(--text-primary);transition:background .15s}
.mobile-section-link:hover{background:rgba(255,255,255,.6)}

/* ═══ SHARED COMPONENTS ═══ */
.menu-card{display:flex;align-items:center;gap:10px;background:var(--bg-gradient-menu);border-radius:16px;padding:14px 16px;transition:transform .2s;border-top:1px solid rgba(255,255,255,.8);border-bottom:1px solid rgba(138,100,20,.3);box-shadow:0 8px 20px rgba(179,135,40,.15);margin-bottom:10px}
.menu-card:hover{transform:scale(.98);background:var(--bg-gradient-menu-hover)}
.menu-card-icon{font-size:24px;flex-shrink:0;color:var(--accent-highlight)}
.menu-section{font-size:18px;font-weight:600;color:var(--text-primary)}
.menu-section-desc{font-size:16px;color:var(--text-secondary);margin-top:2px}
.arrow-glass{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--accent-primary);font-size:18px;font-weight:600;border:1px solid rgba(255,255,255,.8);margin-left:auto;flex-shrink:0}
.profile-card{padding:20px;background:var(--glass-bg);border-radius:16px;border:1px solid var(--glass-border);margin-bottom:20px;text-align:center}
.profile-role{font-size:18px;font-weight:700;color:var(--accent-highlight);margin-bottom:12px}
.profile-balance-box{margin-top:8px}.profile-balance-label{font-size:13px;color:var(--text-secondary)}.profile-balance-value{font-size:28px;font-weight:700;color:var(--accent-primary);display:block}
.password-section{margin-top:20px}.password-section h3{font-size:15px;font-weight:600;margin-bottom:12px;color:var(--text-primary)}
.passport-form{}
.packages-grid{display:flex;flex-direction:column;gap:0}

/* Cookie */
.cookie-banner{position:fixed;bottom:60px;left:16px;right:16px;z-index:100;background:var(--bg-inverse);border:1px solid var(--separator-color);border-radius:16px;padding:16px;box-shadow:var(--shadow-soft);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
@media(min-width:768px){.cookie-banner{bottom:16px;max-width:480px;left:auto;right:16px}}
.cookie-banner p{font-size:13px;color:var(--text-secondary);flex:1;min-width:180px}.cookie-actions{display:flex;gap:8px}

/* Admin */
.stat-card{background:var(--bg-inverse);border-radius:16px;padding:12px 16px;margin-bottom:30px;border:1px solid var(--glass-border);box-shadow:var(--shadow-soft)}
.stat-header{font-size:12px;color:var(--text-secondary);font-weight:600}.stat-value{font-size:20px;font-weight:700;color:var(--accent-primary);margin-top:4px}
.period-tabs{display:flex;gap:8px;margin-bottom:16px;overflow-x:auto}
.period-tab{padding:6px 10px;background:var(--bg-secondary);border-radius:10px;font-size:12px;color:var(--text-secondary);white-space:nowrap;border:1px solid transparent;cursor:pointer;transition:all .2s}
.period-tab.active{background:var(--accent-primary);color:var(--text-inverse)}

/* ═══ AUTH PAGES ═══ */
.auth-body {
    display: flex;
    flex-direction: column; 
    justify-content: flex-start;
    align-items: center; /
    min-height: 100vh;
    min-height: 100dvh;
    height: auto;
    padding: 24px 16px; 
    background: var(--bg-gradient);
    overflow-y: auto;
}
.auth-container {
    width: 100%;
    max-width: 550px;
    margin: auto; 
    display: flex;
    flex-direction: column;
    align-items: center; 
    gap: 16px;
}
.auth-card{width:100%;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:20px;padding:32px 24px;box-shadow:var(--shadow-soft)}
.auth-logo{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px}
.auth-title{font-size:20px;font-weight:700;text-align:center;margin-bottom:20px;color:var(--text-primary)}
.auth-hint{font-size:13px;color:var(--text-secondary);text-align:center;margin-bottom:16px}
.auth-link{display:block;text-align:center;margin-top:12px;font-size:13px;color:var(--accent-primary)}.auth-link-inline{color:var(--accent-primary);font-weight:600}
.auth-footer-text{text-align:center;font-size:13px;color:var(--text-secondary);margin-top:16px}
.auth-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--text-tertiary);font-size:12px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--separator-color)}
.btn-telegram{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:12px;font-weight:600;font-size:14px;background:#54A9EB;color:#FFF;transition:opacity .2s}.btn-telegram:hover{opacity:.9}
.terms-check{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text-secondary);margin-bottom:16px;line-height:1.4}.terms-check a{color:var(--accent-primary);text-decoration:underline}
.auth-lang-switch{display:flex;gap:12px}.auth-lang-switch a{font-size:13px;font-weight:600;color:var(--text-secondary)}.auth-lang-switch a.active{color:var(--accent-primary)}
.auth-legal{display:flex;gap:8px;font-size:12px;color:var(--text-tertiary)}.auth-legal a{color:var(--text-tertiary)}.auth-legal a:hover{color:var(--text-secondary)}

/* ═══ LANDING ═══ */
.landing-body{overflow:auto}.landing-container{max-width:800px;margin:0 auto;padding:40px 20px}
.landing-hero{text-align:center;padding:60px 0 40px}.landing-hero h1{font-size:32px;font-weight:800;color:var(--text-primary);margin-bottom:12px;line-height:1.2}
.landing-hero p{font-size:16px;color:var(--text-secondary);max-width:500px;margin:0 auto 24px;line-height:1.6}
.landing-features{display:grid;gap:16px;grid-template-columns:1fr;margin-bottom:40px}@media(min-width:640px){.landing-features{grid-template-columns:1fr 1fr 1fr}}
.landing-feature{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:16px;padding:24px 20px;text-align:center}
.landing-feature h3{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.landing-feature p{font-size:13px;color:var(--text-secondary);line-height:1.5}
.landing-cta{display:flex;justify-content:center;gap:12px;margin-bottom:40px;flex-wrap:wrap}
.landing-footer{display:flex;justify-content:center;gap:16px;padding:20px 0;border-top:1px solid var(--separator-color);font-size:12px;color:var(--text-tertiary)}.landing-footer a{color:var(--text-tertiary)}.landing-footer a:hover{color:var(--text-secondary)}

/* Global scrollbar */
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(0,0,0,.06);border-radius:4px}

.legal-body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    min-height: 100dvh;
    height: auto; 
    overflow-y: auto;     
    background: var(--bg-gradient);    
    background-attachment: fixed; 
    background-size: cover;     
}

/* ═══ CONTENT CENTERED (for text/form pages: insights, summaries, passport, etc.) ═══ */
.content-centered{max-width:800px;margin:0 auto;width:100%}

/* ═══ CARD LIST (insights, summaries) ═══ */
.card-list{display:flex;flex-direction:column;gap:10px}
.list-card{border-radius:14px;padding:14px 16px;border:1px solid var(--separator-color);background:var(--bg-inverse);box-shadow:0 2px 6px rgba(0,0,0,.03);cursor:pointer;transition:all .2s}
.list-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.07);border-color:var(--accent-primary)}
.list-card-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}
.list-card-text{font-size:13px;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.list-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px;gap:8px}
.list-card-date{font-size:11px;color:var(--accent-primary);white-space:nowrap}
.list-card-actions{display:flex;align-items:center;gap:2px}

/* Highlight status message in modal */
.hl-status{font-size:13px;padding:8px 12px;border-radius:8px;background:var(--bg-secondary);color:var(--text-secondary);margin-bottom:4px}

/* Insight banner (integration — completed sessions) */
.insight-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--highlight-gradient);cursor:pointer;flex-shrink:0;border-bottom:1px solid var(--separator-color);color:var(--text-primary);font-size:14px}
.insight-banner:hover{opacity:.9}

/* Char counter (passport fields) */
.char-counter{font-size:11px;color:var(--text-tertiary);text-align:right;margin-top:4px;transition:color .2s}
.char-warn{color:var(--error-color)!important;font-weight:600}

/* Stat cards details */
.stat-tkns{font-size:13px;color:var(--text-secondary)}

/* Admin details/summary */
.admin-details{background:var(--bg-inverse);border:1px solid var(--separator-color);border-radius:12px;margin-bottom:8px;overflow:hidden}
.admin-summary{padding:12px 16px;font-weight:600;font-size:14px;cursor:pointer;color:var(--text-primary);list-style:none}
.admin-summary::-webkit-details-marker{display:none}
.admin-summary::before{content:'▸ ';color:var(--accent-primary)}
details[open]>.admin-summary::before{content:'▾ '}
.admin-detail-body{padding:8px 16px 12px}
.priv-user-item{padding:6px 0;font-size:13px;color:var(--text-secondary);border-bottom:1px solid var(--separator-color)}
.priv-user-item:last-child{border-bottom:none}

/* User card (management) */
.user-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.user-card-name{font-weight:700;font-size:16px;color:var(--text-primary)}
.user-card-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;background:var(--bg-tertiary);color:var(--accent-primary)}
.user-card-info{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.info-row{display:flex;justify-content:space-between;font-size:13px;padding:2px 0}
.info-label{color:var(--text-secondary)}
.user-card-ops{border-top:1px solid var(--separator-color);padding-top:10px;margin-bottom:12px}
.op-row{display:flex;justify-content:space-between;font-size:12px;padding:2px 0;color:var(--text-secondary)}
.user-card-actions{display:flex;gap:8px;flex-wrap:wrap;border-top:1px solid var(--separator-color);padding-top:12px}

/* Transaction card */
.tx-card{background:var(--bg-inverse);border:1px solid var(--separator-color);border-radius:10px;padding:10px 12px;margin-bottom:16px;cursor:pointer;transition:all .15s;font-size:13px}
.tx-card:hover{border-color:var(--accent-primary);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.tx-amount{font-weight:700;color:var(--success-color);font-size:14px}
.tx-method{padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}
.tx-m-manual{background:#dbeafe;color:#2563eb}.tx-m-webhook{background:#d1fae5;color:#059669}
.tx-m-gift{background:#ede9fe;color:#7c3aed}.tx-m-other{background:var(--bg-secondary);color:var(--text-secondary)}

.btn-primary,
.btn-new-session,
.btn-creator-panel,
.product-pill,
.nav-item,
.dropdown-item,
.session-card,
.list-card {
    transition: all 0.2s ease !important;
}

.block-info-c {
margin-top: 20px; 
padding: 14px 16px; 
background: var(--bg-secondary);
border-radius: 14px; 
border: 1px solid var(--separator-color);
}
.block-info-c h3 {
font-size: 14px; 
font-weight: 700; 
color: var(--accent-primary); 
margin-bottom: 8px;
}
.block-info-c p {
font-size: 14px; 
line-height: 1.6; 
color: var(--text-secondary);
margin: 0 0 8px; 
}
.block-info-c a,
.block-info a {
  color: var(--accent-primary);
  font-weight: 600;
  text-decoration: underline;
}
.block-info-c a:hover,
.block-info a:hover {
  text-decoration: none;
}
.info-section {
  padding: 0 0 50px;   
}
.legal-info h2 {
  margin: 20px 0 8px; 
}
.legal-info p {
    line-height: 1.6;
    margin-bottom: 10px;
}
.legal-info ul,
.legal-info ol {   
    padding: 0 0 0 30px;
    margin: 0 0 15px;
}
.legal-info ul li,
.legal-info ol li {
    padding: 0;
    margin: 0 0 10px;
}
.block-info {
    font-size: 14px;
    background:var(--bg-inverse);
    border: 1px solid var(--accent-primary);
    border-radius: 10px;
    padding: 20px;
    margin: 0 0 20px;
}
.block-info p {
    line-height: 1.6;
    margin-bottom: 10px;
}
.block-info ul,
.block-info ol {   
    padding: 0 0 0 30px;
    margin: 0 0 15px;
}
.block-info ul li,
.block-info ol li {
    padding: 0;
    margin: 0 0 10px;
}
.block-info-title {
    color: #1a1a1a;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size:16px;
    margin: 0 0 10px;
}
.icon-header {
    color: var(--accent-primary);
    flex-shrink: 0;
}
.icon-token {
    fill: #7C3AED; 
    background: #7C3AED;
 }
.emotion-scale {
    background: #f9fafb;
    border-left: 2px solid var(--accent-primary);
    padding: 12px;
    line-height: 1.8;
}
.emotion-high { color: #10b981; font-weight: bold; }
.emotion-mid { color: #f59e0b; } 
.emotion-low { color: #ef4444; } 

.pwa-box {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    margin-top: 20px;
}
.pwa-icon-placeholder {
    width: 64px;
    height: 64px;
    background: #7C3AED;
    color: white;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 15px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

@media(max-width:500px) {
    .header-inner{padding:8px 12px;gap:8px}
    .logo-icon{font-size:16px;}
    .logo-text{font-size:14px;letter-spacing: 0;}
    .balance-label {display:none;}
}


/* 
   LANDING EXTRA — расширенный лендинг
*/

.landing-body { 
overflow-y: auto !important; 
height: auto !important; min-height: 100vh; 
display: block !important; 
background: var(--bg-gradient);    
background-attachment: fixed; 
background-size: cover;     
}
.landing-container { overflow-x: hidden; }
.lx-section { padding: 56px 0; border-top: 1px solid var(--separator-color); }
.lx-section-alt {
    background: var(--bg-tertiary);
    margin: 0 -20px;
    padding: 56px 20px;
    border-top: none;
    border-radius: 20px;
}

.lx-label { font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--accent-primary); margin-bottom: 10px; display: block; }
.lx-section h2 { font-size: 26px; font-weight: 800; color: var(--text-primary); margin-bottom: 16px; line-height: 1.25; }

.lx-features-detail { display: flex; flex-direction: column; gap: 20px; }

.lx-feature-card {
    display: flex; gap: 20px;
    background: var(--bg-inverse);
    border: 1px solid var(--bg-tertiary);
    border-radius: 20px; padding: 28px 24px;
    box-shadow: 0 2px 12px rgba(0,0,0,.06);
    min-width: 0; /* fix flex overflow */
}
.lx-feature-icon { font-size: 36px; flex-shrink: 0; line-height: 1; padding-top: 4px; }
.lx-feature-body { flex: 1; min-width: 0; } /* min-width:0 — иначе flex ребёнок не сжимается */
.lx-feature-body h3 { font-size: 16px; font-weight: 700; color: var(--text-primary); margin-bottom: 8px; line-height: 1.3; }
.lx-feature-body > p { font-size: 14px; color: var(--text-secondary); line-height: 1.6; margin-bottom: 12px; }
.lx-feature-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.lx-feature-list li { font-size: 13px; color: var(--text-secondary); line-height: 1.5; display: flex; gap: 8px; align-items: flex-start; }
.lx-check { color: var(--accent-primary); flex-shrink: 0; font-size: 12px; margin-top: 2px; }

.lx-video-bl-wrap { width: 100%; max-width: 100%; margin: 16px 0 0; }

.lx-hero-result { border: none; background: var(--bg-gradient); border-radius: 20px; padding: 56px 20px; }
.lx-hero-result-inner { text-align: center; max-width: 600px; margin: 0 auto; }
.lx-hero-result h2 { font-size: 30px; background: var(--btn-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; margin-bottom: 16px; }
.lx-result-text { font-size: 16px; color: var(--text-primary); line-height: 1.7; margin-bottom: 12px; }
.lx-tagline-bottom { font-size: 13px; color: var(--text-secondary); line-height: 1.6; font-style: italic; }

.lx-two-col { display: flex; gap: 40px; align-items: center; }
.lx-two-col-text { flex: 1; min-width: 0; }
.lx-two-col-text p { font-size: 15px; color: var(--text-secondary); line-height: 1.7; }
.lx-two-col-icon { flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.lx-big-icon { font-size: 72px; line-height: 1; opacity: .85; }
.lx-two-col-reverse { flex-direction: row-reverse; }

.lx-author-block { max-width: 700px; margin: 0 auto; }
.lx-author-desc { font-size: 15px; color: var(--text-secondary); line-height: 1.7; text-align: center; margin-bottom: 16px; }
.lx-author-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.lx-author-col h4 { font-size: 12px; font-weight: 700; color: var(--accent-primary); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 12px; }
.lx-list-plain { list-style: none; display: flex; flex-direction: column; gap: 7px; }
.lx-list-plain li { font-size: 13px; color: var(--text-secondary); line-height: 1.5; padding-left: 14px; position: relative; }
.lx-list-plain li::before { content: '·'; position: absolute; left: 0; color: var(--accent-primary); }

.lx-knowledge-block { max-width: 760px; margin: 0 auto; }
.lx-knowledge-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.lx-knowledge-card {
    background: var(--bg-inverse);
    border: 1px solid var(--bg-tertiary);
    box-shadow: 0 2px 8px rgba(0,0,0,.05);
    border-radius: 16px; padding: 24px 20px; text-align: center;
}
.lx-knowledge-icon { font-size: 32px; margin-bottom: 12px; }
.lx-knowledge-card h4 { font-size: 14px; font-weight: 700; color: var(--text-primary); margin-bottom: 8px; line-height: 1.3; }
.lx-knowledge-card p { font-size: 13px; color: var(--text-secondary); line-height: 1.5; }

.lx-video-section { max-width: 680px; margin: 0 auto; }
.lx-video-wrap {
    position: relative; width: 100%; padding-top: 56.25%;
    border-radius: 16px; overflow: hidden; background: #000; margin-bottom: 28px;
}
.lx-video-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.lx-explainer-content { display: flex; flex-direction: column; gap: 14px; margin-top: 4px; }
.lx-explainer-content p { font-size: 15px; color: var(--text-secondary); line-height: 1.7; }

.lx-tokens-block { max-width: 760px; margin: 0 auto; }
.lx-tokens-cards { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; align-items: stretch; }
.lx-token-card {
    background: var(--bg-inverse);
    border: 1px solid var(--bg-tertiary);
    box-shadow: 0 2px 8px rgba(0,0,0,.05);
    border-radius: 16px; padding: 24px 20px;
}
.lx-token-highlight { background: var(--bg-gradient-menu); border-color: transparent; text-align: center; box-shadow: var(--shadow-glow); }
.lx-token-num { font-size: 26px; font-weight: 800; color: var(--text-inverse); line-height: 1; margin-bottom: 6px; }
.lx-token-label { font-size: 13px; color: rgba(255,255,255,.9); margin-bottom: 8px; line-height: 1.4; }
.lx-token-hint { font-size: 12px; color: rgba(255,255,255,.7); line-height: 1.4; font-style: italic; }
.lx-token-icon { font-size: 28px; text-align: center; margin-bottom: 10px; }
.lx-token-card h4 { font-size: 14px; font-weight: 700; color: var(--text-primary); margin-bottom: 6px; }
.lx-token-card p { font-size: 13px; color: var(--text-secondary); line-height: 1.5; }

.lx-reviews-block { max-width: 800px; margin: 0 auto; }
.lx-reviews-outer { overflow: hidden; }
.lx-reviews-track {
    display: flex; gap: 16px;
    overflow-x: auto; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 4px 0 12px;
    scrollbar-width: none;
}
.lx-reviews-track::-webkit-scrollbar { display: none; }
.lx-review-slide {
    flex: 0 0 240px; scroll-snap-align: start; cursor: zoom-in;
    border-radius: 12px; overflow: hidden;
    border: 1px solid var(--bg-tertiary);
    box-shadow: 0 2px 10px rgba(0,0,0,.07);
    transition: transform .2s, box-shadow .2s;
    display: flex;
    align-items: center;
}
.lx-review-slide:hover { transform: translateY(-2px); box-shadow: var(--shadow-soft); }
.lx-review-slide img { width: 100%; display: block; object-fit: cover; max-height: 400px; }
.lx-reviews-nav { display: flex; justify-content: center; gap: 12px; margin-top: 16px; }
.lx-reviews-btn {
    width: 40px; height: 40px; border-radius: 50%;
    border: 1px solid var(--separator-color);
    background: var(--bg-inverse);
    color: var(--text-primary); font-size: 16px; cursor: pointer;
    transition: background .2s, border-color .2s;
    display: flex; align-items: center; justify-content: center;
}
.lx-reviews-btn:hover { background: var(--bg-tertiary); border-color: var(--accent-primary); }

.lx-lightbox { position: fixed; inset: 0; background: rgba(0,0,0,.88); z-index: 9999; display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: opacity .25s; }
.lx-lightbox--open { opacity: 1; pointer-events: auto; }
.lx-lightbox-inner { position: relative; max-width: 92vw; max-height: 92vh; }
.lx-lightbox-inner img { max-width: 92vw; max-height: 88vh; border-radius: 12px; object-fit: contain; display: block; }
.lx-lightbox-close { position: absolute; top: -14px; right: -14px; width: 32px; height: 32px; border-radius: 50%; border: none; background: rgba(255,255,255,.2); color: #fff; font-size: 14px; cursor: pointer; display: flex; align-items: center; justify-content: center; backdrop-filter: blur(8px); transition: background .2s; }
.lx-lightbox-close:hover { background: rgba(255,255,255,.35); }

.lx-faq-block { max-width: 640px; margin: 0 auto; }
.lx-faq-list { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.lx-faq-item {
    border: 1px solid var(--separator-color);
    border-radius: 12px; overflow: hidden;
    background: var(--bg-inverse);
}
.lx-faq-item summary { cursor: pointer; padding: 16px 20px; font-size: 14px; font-weight: 600; color: var(--text-primary); line-height: 1.4; list-style: none; display: flex; justify-content: space-between; align-items: center; user-select: none; -webkit-user-select: none; }
.lx-faq-item summary::-webkit-details-marker { display: none; }
.lx-faq-item summary::after { content: '＋'; font-size: 16px; color: var(--accent-primary); flex-shrink: 0; margin-left: 12px; transition: transform .2s; display: inline-block; }
.lx-faq-item[open] summary::after { transform: rotate(45deg); }
.lx-faq-item p { padding: 0 20px 16px; font-size: 14px; color: var(--text-secondary); line-height: 1.65; margin: 0; }

.lx-scroll-top {
    position: fixed; bottom: 24px; right: 20px;
    width: 44px; height: 44px; border-radius: 50%;
    border: 1px solid var(--separator-color);
    background: var(--bg-inverse);
    color: var(--accent-primary); font-size: 20px; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    box-shadow: var(--shadow-soft);
    opacity: 0; pointer-events: none;
    transition: opacity .3s, transform .3s; z-index: 100;
}
.lx-scroll-top--visible { opacity: 1; pointer-events: auto; }
.lx-scroll-top:hover { transform: translateY(-2px); }

@media (max-width: 640px) {
    .lx-section { padding: 36px 0; }
    .lx-section-alt { padding: 36px 20px; border-radius: 16px; }
    .lx-section h2 { font-size: 21px; }
    .lx-hero-result { padding: 40px 16px; }
    .lx-hero-result h2 { font-size: 23px; }

    .lx-feature-card { flex-direction: column; gap: 12px; padding: 20px 16px; }
    .lx-feature-icon { font-size: 28px; }

    .lx-two-col { flex-direction: column-reverse; }
    .lx-two-col-reverse {flex-direction: column; gap: 20px;}
    .lx-big-icon { font-size: 48px; }
    .lx-token-icon { text-align: center; }
    .lx-feature-icon { text-align: center; width: 100%; }

    .lx-author-grid { grid-template-columns: 1fr; gap: 16px; }

    .lx-knowledge-cards { grid-template-columns: 1fr; }

    .lx-tokens-cards { grid-template-columns: 1fr; }

    .lx-review-slide { flex: 0 0 200px; }
}

@media (max-width: 480px) {
    .lx-faq-item summary { font-size: 13px; padding: 14px 16px; }
    .lx-faq-item p { padding: 0 16px 14px; }
    .lx-scroll-top { bottom: 16px; right: 16px; width: 40px; height: 40px; font-size: 18px; }
}
