:root{
    --fd-bg:#f3f7ff;
    --fd-bg-soft:#eef4ff;
    --fd-card:#ffffff;
    --fd-card-2:#f8fbff;
    --fd-card-3:#f4f8ff;
    --fd-line:#dbe7ff;
    --fd-line-soft:#e9f0ff;
    --fd-text:#081226;
    --fd-text-2:#12213f;
    --fd-muted:#667694;

    --fd-blue:#155dfc;
    --fd-blue-2:#2563eb;
    --fd-blue-3:#0f3fbf;
    --fd-blue-soft:#e9f1ff;

    --fd-green:#16a34a;
    --fd-green-2:#22c55e;
    --fd-green-soft:#ecfdf3;

    --fd-red:#dc2626;
    --fd-red-soft:#fef2f2;

    --fd-orange:#f59e0b;
    --fd-orange-soft:#fff7ed;

    --fd-gold:#eab308;
    --fd-white:#ffffff;

    --fd-shadow:0 16px 42px rgba(17,39,84,.10);
    --fd-shadow-soft:0 10px 28px rgba(17,39,84,.08);
    --fd-shadow-card:0 8px 20px rgba(17,39,84,.05);

    --fd-radius-xl:28px;
    --fd-radius-lg:22px;
    --fd-radius-md:18px;
    --fd-radius-sm:16px;
}

*{
    box-sizing:border-box;
}

html{
    -webkit-text-size-adjust:100%;
}

html,
body{
    margin:0;
    padding:0;
    min-height:100%;
    background:
        radial-gradient(circle at top left, rgba(37,99,235,.08), transparent 28%),
        radial-gradient(circle at top right, rgba(34,197,94,.06), transparent 22%),
        linear-gradient(180deg,#f7faff 0%,#eef4ff 100%);
    color:var(--fd-text);
    font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
}

body,
button,
input,
select,
textarea{
    font-weight:600;
}

h1,
h2,
h3,
h4,
h5,
strong,
b{
    font-weight:800 !important;
    letter-spacing:-.02em;
    color:var(--fd-text);
}

p,
span,
small,
div,
a{
    color:inherit;
}

body{
    padding-bottom:110px;
}

.bot-shell{
    max-width:520px;
    margin:0 auto;
    min-height:100vh;
    padding:18px 16px 16px;
}

.bot-topbar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-bottom:18px;
}

.icon-btn{
    width:46px;
    height:46px;
    border:none;
    border-radius:16px;
    background:rgba(255,255,255,.92);
    color:var(--fd-blue-2);
    box-shadow:var(--fd-shadow-soft);
    display:flex;
    align-items:center;
    justify-content:center;
    backdrop-filter:blur(14px);
    cursor:pointer;
    transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}

.icon-btn:hover{
    transform:translateY(-1px);
    box-shadow:0 14px 28px rgba(17,39,84,.12);
}

.icon-btn span{
    font-size:1.25rem;
    font-weight:900;
    line-height:1;
}

.topbar-copy{
    text-align:center;
    flex:1;
    min-width:0;
}

.topbar-copy h1{
    margin:0;
    font-size:1.22rem;
}

.topbar-copy p{
    margin:6px 0 0;
    color:var(--fd-muted);
    font-size:.88rem;
    font-weight:700;
}

/* ===== SISTEMA VISUAL UNIFICADO ===== */

.hero-panel,
.section-block,
.chat-state-card,
.summary-card,
.criteria-card,
.live-position-card,
.order-card,
.activity-live-item,
.info-card,
.hero-stat-card,
.agent-card,
.control-meta-item,
.chat-shell{
    border:1px solid var(--fd-line-soft);
    background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
    box-shadow:var(--fd-shadow-card);
    backdrop-filter:blur(16px);
}

.hero-panel{
    position:relative;
    overflow:hidden;
    padding:20px;
    border-radius:30px;
    margin-bottom:16px;
    background:
        radial-gradient(circle at top right, rgba(34,197,94,.10), transparent 24%),
        radial-gradient(circle at bottom left, rgba(21,93,252,.12), transparent 30%),
        linear-gradient(180deg,#ffffff 0%,#f6faff 100%);
    box-shadow:var(--fd-shadow);
}

.hero-glow{
    position:absolute;
    inset:auto -70px -90px auto;
    width:210px;
    height:210px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(21,93,252,.14) 0%, rgba(21,93,252,0) 68%);
    pointer-events:none;
}

.hero-head{
    position:relative;
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:14px;
    margin-bottom:16px;
}

.hero-copy h2{
    margin:10px 0 0;
    font-size:1.46rem;
    line-height:1.03;
    max-width:280px;
}

.hero-copy p{
    margin:10px 0 0;
    color:var(--fd-muted);
    font-size:.94rem;
    line-height:1.48;
    font-weight:700;
}

.hero-badge,
.order-status,
.activity-badge,
.criteria-pill,
.section-pill,
.mini-reason-badge,
.mini-pill,
.pos-side{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:6px;
    border-radius:999px;
    font-size:.72rem;
    font-weight:900;
    letter-spacing:.04em;
    text-transform:uppercase;
    white-space:nowrap;
}

.hero-badge{
    padding:10px 14px;
    box-shadow:0 8px 20px rgba(17,39,84,.06);
}

.hero-badge-paper{
    color:#166534;
    background:var(--fd-green-soft);
    border:1px solid #bbf7d0;
}

.hero-badge-real{
    color:#7f1d1d;
    background:#fef2f2;
    border:1px solid #fecaca;
}

.hero-badge-neutral{
    color:var(--fd-blue-3);
    background:var(--fd-blue-soft);
    border:1px solid #cfe0ff;
}

.live-dot{
    width:8px;
    height:8px;
    border-radius:50%;
    background:currentColor;
    display:inline-block;
    box-shadow:0 0 0 6px rgba(34,197,94,.10);
}

.hero-confidence{
    min-width:112px;
    border-radius:22px;
    padding:14px;
    background:linear-gradient(180deg,#ffffff 0%,#f4f8ff 100%);
    border:1px solid var(--fd-line-soft);
    box-shadow:var(--fd-shadow-card);
    text-align:right;
}

.hero-confidence-label{
    display:block;
    color:var(--fd-muted);
    font-size:.74rem;
    font-weight:800;
    margin-bottom:8px;
}

.hero-confidence strong{
    display:block;
    font-size:1.45rem;
    line-height:1;
}

.hero-confidence small{
    display:block;
    margin-top:8px;
    color:var(--fd-muted);
    font-size:.77rem;
    font-weight:700;
}

.hero-confidence.good strong,
.hero-confidence.good{
    color:var(--fd-green);
}

.hero-confidence.warn strong,
.hero-confidence.warn{
    color:#d97706;
}

.hero-confidence.bad strong,
.hero-confidence.bad{
    color:var(--fd-red);
}

.hero-stats,
.status-grid,
.criteria-grid,
.live-summary-grid,
.control-grid,
.agents-grid,
.live-positions-grid,
.orders-list,
.activity-list-live{
    display:grid;
    gap:12px;
}

.hero-stats,
.status-grid,
.live-summary-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
}

.hero-stat-card,
.info-card,
.summary-card{
    padding:16px;
    border-radius:20px;
    background:linear-gradient(180deg,#ffffff 0%,#f4f8ff 100%);
    border:1px solid var(--fd-line-soft);
    box-shadow:var(--fd-shadow-card);
}

.hero-stat-card span,
.card-label,
.summary-card span,
.criteria-card span{
    display:block;
    color:var(--fd-muted);
    font-size:.76rem;
    margin-bottom:8px;
    font-weight:800;
}

.hero-stat-card strong,
.card-value,
.summary-card strong,
.criteria-value{
    display:block;
    font-size:1.05rem;
    line-height:1.15;
    color:var(--fd-text);
}

.hero-stat-card small,
.card-note,
.summary-card small{
    display:block;
    margin-top:8px;
    color:var(--fd-muted);
    font-size:.78rem;
    font-weight:700;
    line-height:1.42;
}

.section-block{
    padding:18px;
    border-radius:28px;
    margin-bottom:16px;
    background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
}

.section-block.compact{
    padding:18px;
}

.section-title-row{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    margin-bottom:14px;
}

.section-title-row h3{
    margin:0;
    font-size:1.08rem;
}

.section-title-row p{
    margin:6px 0 0;
    color:var(--fd-muted);
    font-size:.88rem;
    font-weight:700;
    line-height:1.45;
}

.section-pill{
    padding:8px 12px;
    border:1px solid #cfe0ff;
    color:var(--fd-blue-3);
    background:var(--fd-blue-soft);
}

.section-pill.success{
    color:#166534;
    background:var(--fd-green-soft);
    border-color:#bbf7d0;
}

.section-pill.ai{
    color:var(--fd-blue-3);
    background:var(--fd-blue-soft);
    border-color:#cfe0ff;
}

.section-pill.neutral{
    color:#475569;
    background:#eef2ff;
    border-color:#dbe4ff;
}

.section-pill.warning{
    color:#c2410c;
    background:#fff7ed;
    border-color:#fed7aa;
}

.criteria-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
}

.criteria-card{
    position:relative;
    overflow:hidden;
    padding:16px;
    border-radius:22px;
    background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%);
    border:1px solid var(--fd-line-soft);
    box-shadow:var(--fd-shadow-card);
}

.criteria-card::after{
    content:'';
    position:absolute;
    inset:auto -18px -18px auto;
    width:58px;
    height:58px;
    border-radius:50%;
    background:rgba(21,93,252,.06);
}

.criteria-top{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:10px;
}

.criteria-value{
    font-size:1.1rem;
}

.criteria-note{
    margin-top:8px;
    color:var(--fd-muted);
    font-size:.79rem;
    line-height:1.5;
    font-weight:700;
}

.criteria-pill{
    padding:6px 10px;
}

.criteria-pill.good,
.activity-badge.good,
.order-status.filled,
.order-status.executed,
.order-status.open{
    background:var(--fd-green-soft);
    color:#166534;
    border:1px solid #bbf7d0;
}

.criteria-pill.warn,
.activity-badge.warn,
.order-status.pending,
.order-status.partially_filled{
    background:#fff7ed;
    color:#c2410c;
    border:1px solid #fed7aa;
}

.criteria-pill.bad,
.activity-badge.bad,
.order-status.rejected,
.order-status.error,
.order-status.failed{
    background:#fef2f2;
    color:#b91c1c;
    border:1px solid #fecaca;
}

.criteria-pill.info,
.activity-badge.info,
.order-status.closed,
.order-status.completed,
.order-status.canceled{
    background:var(--fd-blue-soft);
    color:var(--fd-blue-3);
    border:1px solid #cfe0ff;
}

.agents-grid{
    grid-template-columns:1fr;
}

.agent-card{
    position:relative;
    padding:16px;
    padding-left:18px;
    border-radius:24px;
    border:1px solid var(--fd-line-soft);
    background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%);
    box-shadow:var(--fd-shadow-card);
}

.agent-card::before{
    content:'';
    position:absolute;
    left:0;
    top:14px;
    bottom:14px;
    width:4px;
    border-radius:999px;
    background:var(--fd-blue);
    opacity:.95;
}

.agent-card.nexa::before{
    background:var(--fd-blue);
}

.agent-card.penny::before{
    background:var(--fd-green);
}

.agent-card.orbit::before{
    background:#38bdf8;
}

.agent-card.sentry::before{
    background:var(--fd-orange);
}

.agent-card.kael::before{
    background:#8b5cf6;
}

.agent-head,
.live-pos-header,
.order-top,
.activity-live-top,
.chat-state-row{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:10px;
}

.agent-brand{
    display:flex;
    align-items:center;
    gap:12px;
    min-width:0;
}

.agent-avatar{
    width:48px;
    height:48px;
    border-radius:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg,var(--fd-blue),#4f8cff);
    color:#fff;
    font-size:1.02rem;
    font-weight:900;
    box-shadow:0 14px 28px rgba(21,93,252,.18);
    flex:0 0 48px;
}

.agent-card.penny .agent-avatar{
    background:linear-gradient(135deg,var(--fd-green),var(--fd-green-2));
    box-shadow:0 14px 28px rgba(22,163,74,.18);
}

.agent-card.orbit .agent-avatar{
    background:linear-gradient(135deg,#38bdf8,#0ea5e9);
    box-shadow:0 14px 28px rgba(14,165,233,.18);
}

.agent-card.sentry .agent-avatar{
    background:linear-gradient(135deg,#f59e0b,#f97316);
    box-shadow:0 14px 28px rgba(245,158,11,.18);
}

.agent-card.kael .agent-avatar{
    background:linear-gradient(135deg,#8b5cf6,#7c3aed);
    box-shadow:0 14px 28px rgba(124,58,237,.18);
}

.agent-brand h4{
    margin:0;
    font-size:1rem;
}

.agent-brand span,
.agent-confidence small,
.agent-advice,
.agent-market-reading,
.section-subhint{
    color:var(--fd-muted);
    font-weight:700;
}

.agent-brand span{
    display:block;
    margin-top:4px;
    font-size:.78rem;
}

.agent-confidence{
    text-align:right;
}

.agent-confidence strong{
    display:block;
    font-size:1.02rem;
    line-height:1;
}

.agent-confidence small{
    display:block;
    margin-top:6px;
    font-size:.74rem;
}

.agent-status-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    flex-wrap:wrap;
    margin:12px 0 10px;
}

.mini-pill{
    padding:7px 11px;
    border:1px solid #cfe0ff;
    color:var(--fd-blue-3);
    background:var(--fd-blue-soft);
}

.mini-pill.active{
    color:#166534;
    background:var(--fd-green-soft);
    border-color:#bbf7d0;
}

.mini-pill.warning,
.mini-pill.waiting{
    color:#c2410c;
    background:#fff7ed;
    border-color:#fed7aa;
}

.mini-pill.blocked{
    color:#b91c1c;
    background:#fef2f2;
    border-color:#fecaca;
}

.mini-pill.defending{
    color:var(--fd-blue-3);
    background:var(--fd-blue-soft);
    border-color:#cfe0ff;
}

.agent-market-reading.dynamic-good{
    color:var(--fd-green);
}

.agent-market-reading.dynamic-warn{
    color:#d97706;
}

.agent-market-reading.dynamic-bad{
    color:var(--fd-red);
}

.agent-market-reading.dynamic-neutral{
    color:#64748b;
}

.agent-advice{
    margin:0;
    font-size:.88rem;
    line-height:1.5;
}

.summary-card.reason-highlight{
    border-color:#cfe0ff;
    background:linear-gradient(180deg,#ffffff 0%,#f3f8ff 100%);
}

.reason-text{
    min-height:28px;
    line-height:1.45;
}

.dual-layout{
    display:grid;
    grid-template-columns:1fr;
    gap:16px;
    margin-bottom:16px;
}

.control-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
}

.action-btn{
    border:none;
    border-radius:18px;
    padding:14px 14px;
    min-height:58px;
    font-weight:900;
    font-size:.92rem;
    cursor:pointer;
    transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}

.action-btn:hover{
    transform:translateY(-1px);
}

.action-primary{
    background:linear-gradient(135deg,var(--fd-blue),var(--fd-blue-3));
    color:#fff;
    box-shadow:0 14px 28px rgba(21,93,252,.22);
}

.action-dark{
    background:linear-gradient(135deg,#0f172a,#1e293b);
    color:#fff;
    box-shadow:0 16px 30px rgba(15,23,42,.18);
}

.action-soft{
    background:linear-gradient(180deg,#eef5ff 0%,#e4efff 100%);
    color:var(--fd-blue-3);
    box-shadow:0 10px 18px rgba(37,99,235,.08);
}

.action-outline{
    background:linear-gradient(135deg, #b000f9, #c2188b);
    border:1px solid var(--fd-line);
    color: #ffffff;
    box-shadow:var(--fd-shadow-soft);
}

.control-meta{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
    margin-top:14px;
}

.control-meta-item{
    border-radius:18px;
    padding:14px;
    background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%);
    border:1px solid var(--fd-line-soft);
}

.control-meta-item span{
    display:block;
    color:var(--fd-muted);
    font-size:.74rem;
    margin-bottom:6px;
    font-weight:800;
}

.control-meta-item strong{
    display:block;
    font-size:.98rem;
    line-height:1.3;
}

.chat-state-card{
    padding:14px;
    border-radius:20px;
    background:linear-gradient(180deg,#ffffff 0%,#f4f8ff 100%);
    border:1px solid var(--fd-line-soft);
    box-shadow:var(--fd-shadow-card);
    margin-bottom:12px;
}

.chat-state-row strong{
    font-size:1rem;
}

.chat-state-row small{
    display:block;
    color:var(--fd-muted);
    font-size:.75rem;
    font-weight:800;
}

.mini-reason-badge{
    padding:7px 11px;
    color:var(--fd-blue-3);
    background:var(--fd-blue-soft);
    border:1px solid #cfe0ff;
}

.chat-shell{
    border-radius:24px;
    overflow:hidden;
    border:1px solid var(--fd-line-soft);
    background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
    box-shadow:var(--fd-shadow-card);
}

.chat-messages{
    display:grid;
    gap:10px;
    padding:16px;
    max-height:340px;
    overflow:auto;
    background:linear-gradient(180deg,#fbfdff 0%,#f5f9ff 100%);
}

.chat-message{
    display:flex;
}

.chat-message.ai{
    justify-content:flex-start;
}

.chat-message.user{
    justify-content:flex-end;
}

.chat-bubble{
    max-width:86%;
    padding:13px 14px;
    border-radius:18px;
    font-size:.9rem;
    line-height:1.5;
    font-weight:700;
    box-shadow:0 8px 18px rgba(17,39,84,.05);
    word-break:break-word;
}

.chat-message.ai .chat-bubble{
    background:#fff;
    border:1px solid var(--fd-line-soft);
    color:var(--fd-text-2);
}

.chat-message.user .chat-bubble{
    background:linear-gradient(135deg,var(--fd-blue),var(--fd-blue-3));
    color:#fff;
}

.chat-input-wrap{
    display:flex;
    gap:10px;
    padding:14px;
    border-top:1px solid var(--fd-line-soft);
    background:#fff;
}

.chat-input{
    flex:1;
    border:1px solid var(--fd-line);
    border-radius:16px;
    padding:14px 16px;
    background:#f8fbff;
    color:var(--fd-text);
    font-size:.92rem;
    outline:none;
}

.chat-input:focus{
    border-color:#bfd4ff;
    box-shadow:0 0 0 4px rgba(21,93,252,.08);
}

.chat-send-btn{
    border:none;
    border-radius:16px;
    width:96px;
    min-width:96px;
    max-width:96px;
    height:52px;
    flex:0 0 96px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg,var(--fd-green),var(--fd-green-2));
    color:#fff;
    font-weight:900;
    box-shadow:0 12px 24px rgba(22,163,74,.18);
    cursor:pointer;
}

.live-position-card,
.order-card,
.activity-live-item{
    padding:16px;
    border-radius:22px;
    background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
    border:1px solid var(--fd-line-soft);
    box-shadow:var(--fd-shadow-card);
}

.position-outline-profit{
    border-color:#bbf7d0;
    box-shadow:0 0 0 1px rgba(22,163,74,.04) inset, 0 10px 22px rgba(17,39,84,.05);
}

.position-outline-loss{
    border-color:#fecaca;
    box-shadow:0 0 0 1px rgba(220,38,38,.04) inset, 0 10px 22px rgba(17,39,84,.05);
}

.live-pos-title strong{
    font-size:1rem;
}

.live-pos-body,
.order-body{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
    font-size:.84rem;
    line-height:1.45;
    color:var(--fd-text-2);
}

.live-pos-body strong,
.order-body strong,
.order-extra strong{
    color:var(--fd-text);
}

.pos-side{
    min-width:68px;
    padding:7px 12px;
    font-size:.7rem;
}

.pos-side.buy{
    background:var(--fd-green-soft);
    color:#166534;
    border:1px solid #bbf7d0;
}

.pos-side.sell{
    background:#fef2f2;
    color:#b91c1c;
    border:1px solid #fecaca;
}

.pnl-positive{
    color:var(--fd-green) !important;
    font-weight:800;
}

.pnl-negative{
    color:var(--fd-red) !important;
    font-weight:800;
}

.pnl-neutral{
    color:#475569 !important;
    font-weight:800;
}

.position-future-box{
    margin-top:12px;
    padding:12px;
    border-radius:16px;
    background:#f7fbff;
    border:1px solid var(--fd-line-soft);
}

.position-future-line{
    margin:0 0 8px;
    font-size:.8rem;
    line-height:1.5;
    color:var(--fd-text-2);
}

.position-future-line:last-child{
    margin-bottom:0;
}

.future-good{
    color:var(--fd-green);
    font-weight:800;
}

.future-bad{
    color:var(--fd-red);
    font-weight:800;
}

.future-info{
    color:var(--fd-blue-2);
    font-weight:800;
}

.future-neutral{
    color:#475569;
    font-weight:800;
}

.close-position-btn{
    margin-top:12px;
    width:100%;
    border:none;
    border-radius:16px;
    padding:13px 14px;
    background:linear-gradient(135deg,#ef4444,#dc2626);
    color:#fff;
    font-weight:900;
    box-shadow:0 14px 24px rgba(220,38,38,.18);
    cursor:pointer;
}

.order-extra{
    margin-top:10px;
    display:grid;
    gap:6px;
    font-size:.8rem;
    color:var(--fd-muted);
}

.order-error,
.activity-live-item p{
    margin:6px 0 0;
    font-size:.86rem;
    color:var(--fd-muted);
    line-height:1.5;
    font-weight:700;
}

.activity-meta{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    margin-top:10px;
}

.activity-live-top strong,
.order-top strong{
    display:block;
    font-size:.98rem;
}

.activity-live-top span,
.order-top span{
    color:var(--fd-muted);
    font-size:.78rem;
    font-weight:800;
}

.empty-state{
    padding:18px;
    text-align:center;
    border:1px dashed var(--fd-line);
    border-radius:20px;
    background:#f8fbff;
    color:var(--fd-muted);
    font-weight:800;
}

.section-subhint{
    margin-top:8px;
    font-size:.79rem;
    line-height:1.5;
}

.status-note-strong{
    font-weight:800;
}

/* ===== RESPONSIVE ===== */

@media (max-width:420px){
    .bot-shell{
        padding-left:14px;
        padding-right:14px;
    }
}

@media (max-width:360px){
    .hero-head,
    .section-title-row,
    .agent-head,
    .agent-status-row,
    .chat-state-row{
        flex-direction:column;
        align-items:flex-start;
    }

    .hero-confidence{
        min-width:100%;
        width:100%;
        text-align:left;
    }
}

@media (max-width:680px){
    .hero-stats,
    .status-grid,
    .live-summary-grid,
    .criteria-grid,
    .control-grid,
    .live-pos-body,
    .order-body{
        grid-template-columns:1fr;
    }
}
/* ===== IGUALAR ANCHO DE LAS 2 CARDS DEL BLOQUE DUAL ===== */

.dual-layout{
    display:grid;
    grid-template-columns:1fr;
    gap:16px;
    margin-bottom:16px;
    width:100%;
}

.dual-layout > .section-block{
    width:100%;
    max-width:100%;
    min-width:0;
    margin:0;
}

.dual-layout > .section-block.compact{
    width:100%;
    max-width:100%;
    min-width:0;
    margin:0;
    padding:18px;
}

.dual-layout .chat-shell,
.dual-layout .chat-state-card,
.dual-layout .control-grid,
.dual-layout .control-meta,
.dual-layout .chat-input-wrap{
    width:100%;
    max-width:100%;
    min-width:0;
}

.dual-layout .chat-input{
    min-width:0;
    width:100%;
}

.dual-layout .chat-send-btn{
    flex:0 0 96px;
}

.dual-layout .action-btn{
    width:100%;
    min-width:0;
}
/* ===== CONTROL PRO (ALINEADO CON FORTUDUX UI) ===== */

.control-pro-panel {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.control-pro-block {
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    border: 1px solid var(--fd-line-soft);
    box-shadow: var(--fd-shadow-card);
    padding: 16px;
    border-radius: 20px;
}

.control-pro-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.control-pro-head span {
    font-size: .85rem;
    color: var(--fd-muted);
    font-weight: 800;
}

.control-pro-row {
    display: flex;
    justify-content: space-between;
    margin-top: 10px;
    font-size: .9rem;
    font-weight: 800;
}

.control-pro-row span {
    color: var(--fd-muted);
}

.control-pro-row strong {
    color: var(--fd-text);
}

/* BOTONES PRO */
.control-pro-actions {
    display: grid;
    gap: 10px;
}

/* SWITCH PROFESIONAL */
.switch {
    position: relative;
    display: inline-block;
    width: 48px;
    height: 26px;
}

.switch input {
    display: none;
}

.slider {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background: #e5edff;
    border-radius: 999px;
    transition: .25s ease;
}

.slider:before {
    content: "";
    position: absolute;
    height: 18px;
    width: 18px;
    left: 4px;
    bottom: 4px;
    background: #ffffff;
    border-radius: 50%;
    box-shadow: 0 4px 10px rgba(0,0,0,.08);
    transition: .25s ease;
}

.switch input:checked + .slider {
    background: linear-gradient(135deg, var(--fd-green), var(--fd-green-2));
}

.switch input:checked + .slider:before {
    transform: translateX(22px);
}
.switch,
.switch .slider,
.switch .slider:before {
    box-sizing: border-box;
}

.switch .slider {
    display: block;
}

.switch .slider:before {
    pointer-events: none;
}
/* ===== FIX SWITCH BOT: evita círculo heredado de mobile.css ===== */

.bot-shell .switch::before,
.bot-shell .switch::after {
    content: none !important;
    display: none !important;
}

.bot-shell .switch {
    position: relative !important;
    display: inline-block !important;
    width: 48px !important;
    height: 26px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
}

.bot-shell .switch input {
    display: none !important;
}

.bot-shell .switch .slider {
    position: absolute !important;
    inset: 0 !important;
    display: block !important;
    width: 48px !important;
    height: 26px !important;
    background: #e5edff !important;
    border-radius: 999px !important;
    border: 1px solid var(--fd-line-soft) !important;
    box-shadow: inset 0 1px 2px rgba(17,39,84,.08) !important;
}

.bot-shell .switch .slider::before {
    content: "" !important;
    position: absolute !important;
    width: 18px !important;
    height: 18px !important;
    left: 4px !important;
    top: 3px !important;
    bottom: auto !important;
    border-radius: 50% !important;
    background: #ffffff !important;
    box-shadow: 0 4px 10px rgba(17,39,84,.14) !important;
    transition: transform .25s ease !important;
}

.bot-shell .switch input:checked + .slider {
    background: linear-gradient(135deg, var(--fd-green), var(--fd-green-2)) !important;
}

.bot-shell .switch input:checked + .slider::before {
    transform: translateX(22px) !important;
}