/* ============================================================
   DataForgeAI · stylesheet lifted verbatim from the reference
   (DataForge_AI_App (1).html). Bridge styles at the bottom
   re-implement the legacy classes the Flask JS depends on
   (timeline, hidden, file-drop, status, warmup-banner …).
   ============================================================ */

:root{
    /* Google four-color system */
    --blue:#1A73E8; --blue-d:#1557B0; --red:#EA4335; --yellow:#FBBC04; --green:#34A853;
    --blue-soft:#E8F0FE; --red-soft:#FCE8E6; --yellow-soft:#FEF7E0; --green-soft:#E6F4EA;
    --purple:#9334E6; --purple-soft:#F3E8FD; --cyan:#12B5CB; --cyan-soft:#E4F7FB;
    /* surfaces */
    --bg:#FFFFFF; --bg2:#F8F9FE; --bg3:#F1F3F4; --panel:#FFFFFF;
    --line:#E8EAED; --line2:#DADCE0;
    --ink:#202124; --ink2:#3C4043; --mute:#5F6368; --faint:#80868B;
    --r:16px; --rs:12px; --rl:28px;
    --shadow:0 1px 2px rgba(60,64,67,.10),0 1px 3px 1px rgba(60,64,67,.06);
    --shadow-h:0 2px 6px 2px rgba(60,64,67,.10),0 1px 3px rgba(60,64,67,.10);
    --shadow-lg:0 4px 8px 3px rgba(60,64,67,.10),0 1px 3px rgba(60,64,67,.10);
    --sans:"Google Sans","Product Sans","Google Sans Text",-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
    --body:"Google Sans Text",Roboto,-apple-system,"Segoe UI",Arial,sans-serif;
    --mono:"Roboto Mono",ui-monospace,"SF Mono",Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased;line-height:1.55;font-size:15px}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
svg{display:block}
::selection{background:var(--blue-soft)}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

.wrap{max-width:1180px;margin:0 auto;padding:0 24px}

/* ---- nav ---- */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;gap:30px;height:64px}
.brand{display:flex;align-items:center;gap:11px;cursor:pointer}
.brand .mark{width:34px;height:34px;flex:none}
.brand b{font-family:var(--sans);font-weight:500;font-size:20px;letter-spacing:-.3px;color:var(--ink)}
.brand b span{color:var(--blue)}
nav.links{display:flex;gap:2px;margin-left:auto}
nav.links a,nav.links button{background:none;border:0;color:var(--ink2);font-family:var(--sans);font-size:14px;font-weight:500;padding:8px 16px;border-radius:999px;cursor:pointer;transition:.18s;text-decoration:none;line-height:1.6}
nav.links a:hover,nav.links button:hover{background:var(--bg3);text-decoration:none}
nav.links a.active,nav.links button.active{color:var(--blue);background:var(--blue-soft)}
.navtoggle{display:none}

/* ---- type ---- */
.eyebrow{font-family:var(--sans);font-size:13px;letter-spacing:.3px;font-weight:600;color:var(--blue)}
.eyebrow.r{color:var(--red)} .eyebrow.g{color:var(--green)} .eyebrow.y{color:#F09300} .eyebrow.p{color:var(--purple)}
.disp{font-family:var(--sans);font-weight:500;letter-spacing:-1px;line-height:1.12;margin:0;color:var(--ink)}
.lead{color:var(--mute);font-size:18px;max-width:60ch;line-height:1.6}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);transition:box-shadow .2s,transform .2s}
.card.hover:hover{box-shadow:var(--shadow-h);transform:translateY(-2px)}
.btn{display:inline-flex;align-items:center;gap:9px;border:0;cursor:pointer;font-family:var(--sans);font-weight:500;padding:12px 24px;border-radius:999px;transition:.18s;font-size:15px;text-decoration:none}
.btn:hover{text-decoration:none}
.btn.primary{background:var(--blue);color:#fff;box-shadow:0 1px 2px rgba(26,115,232,.3)}
.btn.primary:hover{background:var(--blue-d);box-shadow:var(--shadow-h)}
.btn.primary:disabled{background:#C4D7F3;cursor:not-allowed;box-shadow:none}
.btn.ghost{background:#fff;color:var(--blue);box-shadow:inset 0 0 0 1px var(--line2)}
.btn.ghost:hover{background:var(--blue-soft);box-shadow:inset 0 0 0 1px var(--blue-soft)}
.sec{padding:72px 0}
.grid{display:grid;gap:20px}
.ico{border-radius:50%;display:grid;place-items:center;flex:none}
.chiprow{display:flex;gap:8px;flex-wrap:wrap}
.gchip{display:inline-flex;align-items:center;gap:7px;padding:7px 15px;border-radius:999px;background:#fff;border:1px solid var(--line2);font-size:13px;font-weight:500;color:var(--ink2)}
.gchip i{width:8px;height:8px;border-radius:50%;display:block}

footer.foot{border-top:1px solid var(--line);margin-top:24px;background:var(--bg2)}
.foot-in{display:flex;flex-wrap:wrap;gap:16px;align-items:center;padding:28px 0;color:var(--mute);font-size:13px}

/* ---- hero ---- */
.hero{padding:72px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.hero .disp{font-size:56px}
.dots4{display:inline-flex;gap:5px;vertical-align:middle;margin-left:4px}
.dots4 span{width:13px;height:13px;border-radius:50%;display:block}
.hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero-art{width:100%;height:auto}

/* ---- features ---- */
.feats{grid-template-columns:repeat(3,1fr)}
.feat{padding:28px}
.feat h3{font-family:var(--sans);font-size:19px;margin:18px 0 8px;font-weight:500;color:var(--ink)}
.feat p{color:var(--mute);font-size:14px;margin:0}
.feat .tag{margin-top:14px;font-size:13px;font-weight:600;font-family:var(--sans)}

.band{background:var(--bg2)}
.steps{grid-template-columns:repeat(4,1fr)}
.step{padding:24px;position:relative}
.step .n{font-family:var(--sans);font-size:14px;font-weight:600;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:#fff}
.step h4{font-family:var(--sans);margin:14px 0 7px;font-size:17px;font-weight:500}
.step p{margin:0;color:var(--mute);font-size:14px}

.statrow{grid-template-columns:repeat(4,1fr)}
.stat{padding:26px;text-align:center}
.stat .big{font-family:var(--sans);font-size:46px;font-weight:500;line-height:1;letter-spacing:-1px}
.stat .lab{color:var(--mute);font-size:13.5px;margin-top:10px}

/* ---- page head with art ---- */
.pagehead{padding:52px 0 12px}
.ph-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}
.ph-art{width:100%;height:auto;max-width:420px;margin-left:auto}

/* ---- inventory ---- */
.invtop{display:flex;gap:18px;flex-wrap:wrap;margin:30px 0}
.kpi{flex:1;min-width:180px;padding:22px}
.kpi .v{font-family:var(--sans);font-size:34px;font-weight:500;line-height:1;letter-spacing:-1px}
.kpi .l{color:var(--mute);font-size:13px;margin-top:8px}
.barwrap{height:6px;border-radius:6px;background:var(--bg3);overflow:hidden;margin-top:14px}
.barwrap>span{display:block;height:100%;border-radius:6px}
.srcgrid{grid-template-columns:repeat(2,1fr)}
.src{padding:22px;display:flex;gap:16px;align-items:flex-start}
.src .meta{flex:1;min-width:0}
.src h4{font-family:var(--sans);margin:0 0 4px;font-size:16.5px;font-weight:500;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.src .desc{color:var(--mute);font-size:13.5px;margin:0 0 12px}
.src .row{display:flex;gap:18px;font-size:12.5px;color:var(--faint);margin-bottom:11px;flex-wrap:wrap}
.src .row b{color:var(--ink2);font-weight:600}
.fmt{display:inline-block;font-family:var(--mono);font-size:11px;color:var(--mute);background:var(--bg3);border-radius:6px;padding:3px 8px;margin:0 5px 5px 0}
.toggle{position:relative;width:42px;height:24px;border-radius:999px;border:0;cursor:pointer;flex:none;transition:.2s;background:var(--line2);padding:0}
.toggle.on{background:var(--blue)}
.toggle span{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.2s;box-shadow:var(--shadow)}
.toggle.on span{left:21px}
.status{font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;font-family:var(--sans)}
.dotpulse{width:8px;height:8px;border-radius:50%;display:inline-block}
.conn-on{color:var(--green)} .conn-off{color:var(--faint)}

/* ---- search ---- */
.searchbar{display:flex;gap:12px;margin:8px 0;flex-wrap:wrap}
.searchbar .field{flex:1;min-width:260px;display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line2);border-radius:999px;padding:0 22px;min-height:56px;box-shadow:var(--shadow);transition:.18s}
.searchbar .field:focus-within{box-shadow:var(--shadow-h);border-color:transparent}
.searchbar input,.searchbar textarea{flex:1;background:none;border:0;color:var(--ink);font-family:var(--body);font-size:16px;outline:none;resize:none;padding:14px 0;line-height:1.5;min-width:0}
.searchbar input::placeholder,.searchbar textarea::placeholder{color:var(--faint)}
.suggest{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 0;align-items:center}
.suggest button{background:#fff;border:1px solid var(--line2);color:var(--ink2);font-family:var(--sans);font-size:13px;font-weight:500;padding:8px 15px;border-radius:999px;cursor:pointer;transition:.15s}
.suggest button:hover{background:var(--blue-soft);border-color:var(--blue-soft);color:var(--blue)}

.empty{padding:64px 24px;text-align:center}
.empty .ic{margin:0 auto 22px;width:120px;height:120px}
.empty h3{font-family:var(--sans);font-weight:500;font-size:20px;color:var(--ink2);margin:0 0 8px}
.empty p{color:var(--faint);font-size:14px;margin:0}

/* ---- platform shapes (used on Inventory for "three data shapes") ---- */
.shapes{grid-template-columns:repeat(3,1fr)}
.shape{padding:24px}
.shape .top{display:flex;align-items:center;gap:13px;margin-bottom:15px}
.shape h3{font-family:var(--sans);margin:0;font-size:17px;font-weight:500}
.shape .kind{font-family:var(--mono);font-size:11px;color:var(--faint);letter-spacing:.4px;margin-top:2px}
.shape p{color:var(--mute);font-size:13.5px;margin:0 0 14px}
.doc{font-family:var(--mono);font-size:11.5px;color:var(--ink2);background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:14px;line-height:1.7;white-space:pre;overflow-x:auto;margin:0}
.doc .k{color:var(--blue)} .doc .s{color:var(--green)} .doc .n{color:#B06000} .doc .c{color:var(--faint)} .doc .v{color:var(--purple)}

.note{font-size:12.5px;color:var(--mute);background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:15px 17px;margin-top:20px}
.threecol{grid-template-columns:repeat(3,1fr)} .fourcol{grid-template-columns:repeat(4,1fr)}

@media (max-width:920px){
    .hero-grid,.ph-grid{grid-template-columns:1fr}
    .ph-art{display:none}
    .feats,.steps,.statrow,.srcgrid,.threecol,.fourcol,.shapes{grid-template-columns:1fr 1fr}
    .hero .disp{font-size:42px}
}
@media (max-width:640px){
    .feats,.steps,.statrow,.srcgrid,.threecol,.fourcol,.shapes{grid-template-columns:1fr}
    nav.links{display:none}
    nav.links.open{display:flex;position:absolute;top:64px;left:0;right:0;flex-direction:column;background:#fff;border-bottom:1px solid var(--line);padding:12px 24px;box-shadow:var(--shadow-lg)}
    .navtoggle{display:grid;margin-left:auto;place-items:center;width:40px;height:40px;border-radius:50%;background:#fff;border:1px solid var(--line2);color:var(--ink2);cursor:pointer}
    .hero .disp{font-size:36px}
    .hero{padding:48px 0 24px}
    .hero-art{max-width:340px;margin:0 auto}
}


/* ============================================================
   ── Legacy bridges (do not remove — required by main.js / search.js) ──
   ============================================================ */

.hidden{display:none !important}

/* ── File-drop (Inventory upload) ── */
.upload-form{display:grid;gap:14px;margin-top:18px}
.file-drop{
    display:flex;align-items:center;justify-content:center;flex-direction:column;
    gap:8px;padding:40px 20px;text-align:center;cursor:pointer;
    border:2px dashed var(--line2);border-radius:var(--r);
    background:var(--bg2);color:var(--mute);font-family:var(--sans);font-size:14.5px;
    transition:.18s;
}
.file-drop::before{content:"↥";font-size:24px;color:var(--blue);line-height:1}
.file-drop:hover,.file-drop.dragover{
    border-color:var(--blue);background:var(--blue-soft);color:var(--blue-d);
}

/* ── Status pills ── */
.status:not(.conn-on):not(.conn-off){
    padding:12px 16px;border-radius:var(--rs);font-size:13.5px;
    border:1px solid var(--line);background:var(--bg2);color:var(--ink2);
    margin:14px 0;font-weight:500;display:block;
}
.status.info{background:var(--blue-soft);color:var(--blue-d);border-color:rgba(26,115,232,.2)}
.status.success{background:var(--green-soft);color:var(--green);border-color:rgba(52,168,83,.2)}
.status.error{background:var(--red-soft);color:var(--red);border-color:rgba(234,67,53,.2)}
.status.warn{background:var(--yellow-soft);color:#8A6100;border-color:rgba(251,188,4,.3)}

/* ── Result panel (Inventory) ── */
.result{
    margin-top:18px;background:#fff;border:1px solid var(--line);
    border-radius:var(--rs);padding:18px;
}
.result.hidden{display:none}
.result h3{font-family:var(--sans);font-size:15px;font-weight:500;margin:0 0 14px;color:var(--ink)}

/* entrance animation when the panel is revealed */
.result:not(.hidden){animation:result-in .42s cubic-bezier(.16,.84,.36,1)}
@keyframes result-in{
    from{opacity:0;transform:translateY(8px)}
    to  {opacity:1;transform:translateY(0)}
}

/* file header */
.result__file{
    display:flex;align-items:center;gap:12px;padding:12px 14px;
    background:var(--bg2);border:1px solid var(--line);border-radius:10px;
    margin-bottom:14px;
}
.result__file-icon{
    width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;
    background:var(--blue-soft);color:var(--blue-d);flex-shrink:0;
}
.result__file-meta{flex:1;min-width:0}
.result__file-name{
    font-family:var(--sans);font-size:14px;font-weight:500;color:var(--ink);
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.result__file-sub{
    font-size:12px;color:var(--mute);margin-top:2px;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.result__time{
    display:inline-flex;align-items:center;gap:5px;
    font-family:var(--sans);font-size:11px;font-weight:500;
    color:var(--blue-d);background:var(--blue-soft);
    padding:3px 8px;border-radius:999px;flex-shrink:0;
}
.result__time[hidden]{display:none}
.result__badge{
    font-size:11px;font-weight:500;letter-spacing:.02em;text-transform:uppercase;
    padding:3px 8px;border-radius:999px;background:var(--green-soft);color:var(--green);
    flex-shrink:0;
}
.result__badge.is-error{background:var(--red-soft);color:var(--red)}
.result__badge.is-warn{background:var(--yellow-soft);color:#a16207}

/* group title */
.result__group-title{
    font-family:var(--sans);font-size:11px;font-weight:500;text-transform:uppercase;
    letter-spacing:.06em;color:var(--mute);margin:14px 0 8px;
}

/* KPI cards */
.result__kpis{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;
}
.kpi{
    background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 14px;
    display:flex;align-items:flex-start;gap:10px;
    transition:transform .15s ease, box-shadow .15s ease;
}
.kpi:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(60,64,67,.08)}
.kpi__icon{
    width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;
    background:var(--bg2);color:var(--mute);flex-shrink:0;
}
.kpi__body{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}
.kpi__label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--mute)}
.kpi__value{font-family:var(--sans);font-size:22px;font-weight:500;color:var(--ink);line-height:1.1;font-variant-numeric:tabular-nums}
.kpi__delta{
    font-size:11px;font-weight:500;color:var(--green);
    display:inline-flex;align-items:center;gap:3px;
}
.kpi__delta[hidden]{display:none}

/* variants */
.kpi--good .kpi__icon{background:var(--green-soft);color:var(--green)}
.kpi--good .kpi__value{color:var(--green)}
.kpi--warn .kpi__icon{background:var(--yellow-soft);color:#a16207}
.kpi--warn .kpi__value{color:#a16207}
.kpi--mute .kpi__value{color:var(--mute)}
/* errors KPI loses the amber tint when value is 0 */
.kpi--warn[data-zero="1"] .kpi__icon{background:var(--bg2);color:var(--mute)}
.kpi--warn[data-zero="1"] .kpi__value{color:var(--mute)}

/* raw JSON disclosure */
.result__raw{margin-top:16px;border-top:1px solid var(--line);padding-top:12px}
.result__raw summary{
    font-size:12px;color:var(--mute);cursor:pointer;user-select:none;
    font-family:var(--sans);padding:4px 0;
}
.result__raw summary:hover{color:var(--ink2)}
.result__raw pre{
    margin:8px 0 0;background:var(--bg2);border:1px solid var(--line);border-radius:8px;
    padding:12px;font-family:var(--mono);font-size:12px;color:var(--ink2);
    overflow:auto;max-height:300px;
}

/* ── Timeline (both pages) ── */
.timeline{
    background:#fff;border:1px solid var(--line);border-radius:var(--r);
    padding:22px 24px;box-shadow:var(--shadow);margin-top:20px;
}
.timeline__head{
    display:flex;align-items:center;gap:10px;margin:0 0 14px;
}
.timeline__title{
    font-family:var(--sans);font-size:15px;font-weight:500;margin:0;color:var(--ink);
    flex:1;min-width:0;
}
.cortex-elapsed{
    display:inline-flex;align-items:center;gap:5px;
    font-family:var(--sans);font-size:11.5px;font-weight:500;
    color:var(--blue-d);background:var(--blue-soft);
    padding:3px 9px;border-radius:999px;font-variant-numeric:tabular-nums;
}
.cortex-elapsed.hidden{display:none}
.cortex-elapsed.is-done{background:var(--green-soft);color:var(--green)}
.cortex-toggle{
    background:transparent;border:1px solid var(--line);border-radius:6px;
    padding:3px 10px;font-family:var(--sans);font-size:11.5px;color:var(--mute);
    cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease;
}
.cortex-toggle:hover{background:var(--bg2);color:var(--ink2);border-color:var(--line2)}
.cortex-toggle.hidden{display:none}
.timeline--collapsed .timeline__list{display:none}
.timeline__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.timeline__row{
    display:grid;grid-template-columns:24px 1fr auto;gap:12px;align-items:flex-start;
    padding:10px 0;border-bottom:1px solid var(--bg3);transition:background .15s ease;
}
.timeline__row:last-child{border-bottom:none}
.timeline__row--sub{padding-left:28px}
.timeline__row--sub .timeline__name{font-size:13.5px;color:var(--mute)}

.timeline__icon{
    width:18px;height:18px;border-radius:50%;
    background:var(--bg3);border:2px solid var(--line2);
    margin-top:4px;flex-shrink:0;position:relative;
    transition:background .15s ease,border-color .15s ease;
}
.timeline__body{min-width:0}
.timeline__name{font-family:var(--sans);font-weight:500;color:var(--ink);font-size:14.5px}
.timeline__msg{font-size:12.5px;color:var(--mute);margin-top:2px;word-break:break-word}
.timeline__duration{
    font-family:var(--mono);font-size:11.5px;color:var(--faint);
    margin-left:8px;white-space:nowrap;
}

.timeline__row.is-running .timeline__icon{
    background:#fff;border-color:var(--blue);
    box-shadow:0 0 0 4px rgba(26,115,232,.15);
    animation:tl-pulse 1.2s ease-in-out infinite;
}
.timeline__row.is-done .timeline__icon{background:var(--green);border-color:var(--green)}
.timeline__row.is-done .timeline__icon::after{
    content:"";position:absolute;left:3px;top:0px;width:5px;height:9px;
    border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);
}
.timeline__row.is-error .timeline__icon{background:var(--red);border-color:var(--red)}
.timeline__row.is-error .timeline__icon::after{
    content:"!";position:absolute;inset:0;color:#fff;font-size:11px;font-weight:700;
    text-align:center;line-height:14px;
}
.timeline__row.is-warn .timeline__icon{background:var(--yellow);border-color:var(--yellow)}

@keyframes tl-pulse{
    0%,100%{box-shadow:0 0 0 4px rgba(26,115,232,.15)}
    50%    {box-shadow:0 0 0 7px rgba(26,115,232,.06)}
}

/* ── Warmup banner (Customer Search) ── */
.warmup-banner{
    background:linear-gradient(180deg,#fff 0%,var(--blue-soft) 100%);
    border:1px solid rgba(26,115,232,.25);border-radius:var(--rs);
    padding:18px 20px;margin:18px 0;box-shadow:var(--shadow);
}
.warmup-banner.hidden{display:none}
.warmup-banner-header{
    display:flex;align-items:center;gap:10px;color:var(--blue-d);
    font-family:var(--sans);font-weight:500;font-size:14.5px;
}
.warmup-elapsed{
    margin-left:auto;color:var(--mute);font-family:var(--mono);font-size:12px;
}
.warmup-spinner{
    display:inline-block;width:16px;height:16px;
    border:2px solid rgba(26,115,232,.25);border-top-color:var(--blue);
    border-radius:50%;animation:tl-spin .9s linear infinite;
}
@keyframes tl-spin{to{transform:rotate(360deg)}}
.warmup-steps{
    list-style:none;padding:0;margin:12px 0 6px;
    display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:6px;
}
.warmup-steps li{
    display:flex;align-items:center;gap:8px;
    font-size:13px;color:var(--mute);padding:4px 0;
}
.warmup-steps li .icon{
    width:14px;height:14px;border-radius:50%;
    background:var(--bg3);display:inline-block;
}
.warmup-steps li.done    .icon{background:var(--green)}
.warmup-steps li.running .icon{background:var(--blue);animation:tl-spin .9s linear infinite}
.warmup-hint{color:var(--mute);font-size:12.5px;margin:6px 0 0}

/* ── Search-answer card ── */
.prompt-response{
    background:#fff;border:1px solid var(--line);border-radius:var(--r);
    padding:24px;box-shadow:var(--shadow);margin-top:20px;
    animation:rise .45s ease both;
}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.prompt-response.hidden{display:none}
.prompt-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}
.prompt-role{font-family:var(--sans);font-weight:500;color:var(--ink)}
.meta-pill{
    display:inline-flex;align-items:center;gap:6px;
    background:var(--bg3);color:var(--mute);border-radius:999px;
    padding:3px 12px;font-size:12px;font-family:var(--mono);
}
.meta-pill--intent{background:var(--blue-soft);color:var(--blue-d)}
.meta-pill--count {background:var(--green-soft);color:var(--green)}
.meta-pill--count #meta-count-num{font-variant-numeric:tabular-nums}
.meta-pill--conf  {background:var(--purple-soft);color:var(--purple);gap:8px}
.meta-pill--conf .conf-label{font-family:var(--mono);font-size:12px;opacity:.85}
.meta-pill--conf .conf-bar{
    position:relative;width:54px;height:6px;border-radius:3px;
    background:rgba(147,52,230,.18);overflow:hidden;
}
.meta-pill--conf .conf-bar__fill{
    position:absolute;left:0;top:0;height:100%;width:0;
    background:var(--purple);border-radius:3px;
    transition:width .55s cubic-bezier(.16,.84,.36,1);
}
.meta-pill--conf #meta-confidence-pct{
    font-family:var(--mono);font-size:12px;font-variant-numeric:tabular-nums;min-width:28px;text-align:right;
}
.meta-pill.hidden {display:none}

.prompt-answer-text{font-size:15px;color:var(--ink);line-height:1.65;margin-top:4px}
.prompt-answer-text p{color:var(--ink);margin:0 0 .8em}
.prompt-answer-text table{
    width:100%;border-collapse:collapse;margin:12px 0;font-size:14px;
}
.prompt-answer-text th,.prompt-answer-text td{
    text-align:left;padding:9px 11px;border-bottom:1px solid var(--bg3);
}
.prompt-answer-text th{
    background:var(--bg2);font-family:var(--sans);font-weight:500;color:var(--ink);
    border-bottom-color:var(--line);
}
.prompt-answer-text pre,.prompt-answer-text code{font-family:var(--mono)}
.prompt-answer-text pre{
    background:var(--bg2);border:1px solid var(--line);border-radius:8px;
    padding:12px;overflow:auto;font-size:12.5px;
}

.result-section{margin-top:22px}
.result-section.hidden{display:none}
.section-title{font-family:var(--sans);font-size:15px;font-weight:500;margin:0 0 12px;color:var(--ink)}
.result-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}
.result-cards > article{
    background:var(--bg2);border:1px solid var(--line);border-radius:var(--rs);
    padding:16px;font-size:13.5px;color:var(--ink2);
}

/* ── Legacy compatibility for any leftover classes ── */
.prompt-form{margin:0}
.prompt-examples{margin-top:14px}
.prompt-examples-label{color:var(--faint);font-size:13px;font-family:var(--sans);margin-right:4px}
