/* ============================================================
   SHARI — Interactive Demo  |  Design System
   Emerald + Gold · refined Islamic-fintech · bilingual (EN/AR, RTL)
   Self-contained, zero-dependency. Charts are pure SVG/CSS.
   ============================================================ */

:root{
  /* Brand */
  --green-900:#0a3d31;
  --green-800:#0e5c4a;   /* primary */
  --green-700:#13715a;
  --green-600:#1c8a6e;
  --green-300:#7fc9b3;
  --green-100:#e4f3ee;
  --gold-600:#a9842f;
  --gold-500:#c9a24b;    /* accent */
  --gold-300:#e6cd8f;
  --gold-100:#f7eed6;

  --ink:#0f1c18;
  --muted:#5d6f69;
  --brand-num:#0e5c4a;
  --line:#e6ece9;
  --paper:#ffffff;
  --canvas:#f4f7f5;
  --canvas-2:#eef3f0;

  --ok:#1c8a6e;
  --warn:#c9882f;
  --bad:#c1492f;
  --info:#2f6fc9;

  --r-sm:8px; --r:14px; --r-lg:22px; --r-xl:30px;
  --sh-1:0 1px 2px rgba(10,61,49,.06), 0 2px 8px rgba(10,61,49,.05);
  --sh-2:0 10px 30px rgba(10,61,49,.10), 0 2px 8px rgba(10,61,49,.06);
  --sh-3:0 24px 60px rgba(10,61,49,.22);

  --font-ui:"Schibsted Grotesk","Tajawal",system-ui,sans-serif;
  --font-display:"Schibsted Grotesk","Tajawal",system-ui,sans-serif;
  --font-ar:"Tajawal","Schibsted Grotesk",system-ui,sans-serif;

  --sidebar-w:248px;
  --topbar-h:64px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font-ui);
  color:var(--ink);
  background:
    radial-gradient(1200px 600px at 85% -10%, rgba(28,138,110,.10), transparent 60%),
    radial-gradient(900px 500px at -5% 10%, rgba(201,162,75,.10), transparent 55%),
    var(--canvas);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow:hidden;
}
html[dir="rtl"] body{font-family:var(--font-ar)}
html[dir="rtl"] .flip{transform:scaleX(-1)}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{display:block;max-width:100%}
::selection{background:var(--gold-300)}

/* scrollbars */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:#cdd9d4;border-radius:20px;border:3px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:#aebcb6;background-clip:content-box}

/* ============ App shell ============ */
.app{height:100vh;display:flex;flex-direction:column;opacity:0;transition:opacity .5s ease}
.app.ready{opacity:1}

.topbar{
  height:var(--topbar-h);flex:0 0 auto;display:flex;align-items:center;gap:18px;
  padding:0 22px;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);z-index:30;
}
.topbar .logo{height:38px;width:auto}
.topbar .logo.icon{display:none}
.brandmark{display:flex;align-items:center;gap:10px}
.search{
  flex:1;max-width:440px;display:flex;align-items:center;gap:10px;
  background:var(--canvas-2);border:1px solid transparent;border-radius:999px;
  padding:9px 16px;color:var(--muted);font-size:13.5px;transition:.2s;
}
.search:focus-within{border-color:var(--green-300);background:#fff;color:var(--ink)}
.search svg{width:16px;height:16px;flex:0 0 auto;opacity:.7}
.search input{flex:1;border:none;outline:none;background:none;font-family:inherit;font-size:13.5px;color:inherit}
.topbar-spacer{flex:1}
.topbar .actions{display:flex;align-items:center;gap:10px}

.btn{
  display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:13.5px;
  padding:9px 16px;border-radius:999px;transition:transform .12s ease, box-shadow .2s, background .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-gold{background:linear-gradient(135deg,var(--gold-500),var(--gold-600));color:#3a2c08;box-shadow:0 6px 16px rgba(169,132,47,.35)}
.btn-gold:hover{box-shadow:0 10px 22px rgba(169,132,47,.45)}
.btn-green{background:linear-gradient(135deg,var(--green-700),var(--green-800));color:#eafaf4;box-shadow:0 6px 16px rgba(14,92,74,.30)}
.btn-green:hover{box-shadow:0 10px 22px rgba(14,92,74,.42)}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--green-800)}
.btn-ghost:hover{border-color:var(--green-300);background:var(--green-100)}
.btn-sm{padding:6px 12px;font-size:12px}

.icon-btn{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--canvas-2);position:relative}
.icon-btn:hover{background:var(--green-100)}
.icon-btn svg{width:19px;height:19px;color:var(--green-800)}
.dot{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;background:var(--gold-500);border:2px solid #fff}

.lang-toggle{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:#fff}
.lang-toggle button{padding:7px 13px;font-size:12.5px;font-weight:700;color:var(--muted)}
.lang-toggle button.on{background:var(--green-800);color:#fff}

.avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-weight:800;color:#fff;
  background:conic-gradient(from 200deg,var(--green-700),var(--gold-500),var(--green-800));font-size:14px}

/* ============ Shell ============ */
.shell{flex:1;display:flex;min-height:0}
.sidebar{
  width:var(--sidebar-w);flex:0 0 auto;background:linear-gradient(180deg,var(--green-900),#072b22);
  color:#cfe6dd;padding:18px 14px;display:flex;flex-direction:column;gap:4px;overflow-y:auto;
}
.sidebar .grp{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:#6f9a8c;margin:14px 12px 6px}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;font-size:13.5px;font-weight:600;
  color:#bcd8cd;transition:.16s;position:relative;
}
.nav-item svg{width:18px;height:18px;flex:0 0 auto;opacity:.9}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:linear-gradient(100deg,rgba(201,162,75,.22),rgba(201,162,75,.06));color:#fff}
.nav-item.active::before{content:"";position:absolute;inset-inline-start:0;top:9px;bottom:9px;width:3px;border-radius:3px;background:var(--gold-500)}
.nav-spacer{flex:1}
.nav-foot{margin:10px 12px 4px;font-size:11px;color:#6f9a8c;line-height:1.5}
.nav-foot b{color:var(--gold-300)}

.content{flex:1;min-width:0;overflow-y:auto;padding:26px 30px 60px;position:relative;scroll-behavior:smooth}
.screen{display:none;animation:rise .5s cubic-bezier(.2,.7,.2,1);max-width:1640px;margin-inline:auto}
.screen.active{display:block}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:20px;flex-wrap:wrap}
.page-head .eyebrow{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-600)}
.page-head h1{font-family:var(--font-display);font-weight:600;font-size:30px;line-height:1.1;margin-top:4px;color:var(--green-900);letter-spacing:-.01em}
html[dir="rtl"] .page-head h1{font-family:var(--font-ar);font-weight:800}
.page-head p.sub{color:var(--muted);font-size:14px;margin-top:6px;max-width:60ch}

/* ============ Cards & grid ============ */
.grid{display:grid;gap:18px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);padding:20px;position:relative}
.card h3{font-size:14px;font-weight:700;color:var(--green-900);display:flex;align-items:center;gap:8px;margin-bottom:2px}
.card .card-sub{font-size:12px;color:var(--muted);margin-bottom:14px}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}

/* KPI tiles */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px}
.kpi{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 18px 16px;
  box-shadow:var(--sh-1);position:relative;overflow:hidden;transition:transform .15s, box-shadow .2s;
}
.kpi:hover{transform:translateY(-2px);box-shadow:var(--sh-2)}
.kpi::after{content:"";position:absolute;inset-inline-end:-30px;top:-30px;width:90px;height:90px;border-radius:50%;
  background:radial-gradient(circle,var(--green-100),transparent 70%);opacity:.8}
.kpi .k-label{font-size:12px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:7px}
.kpi .k-val{font-size:27px;font-weight:800;color:var(--green-900);margin-top:10px;letter-spacing:-.02em;line-height:1}
.kpi .k-val small{font-size:14px;font-weight:700;color:var(--muted)}
.kpi .k-foot{margin-top:10px;font-size:11.5px;color:var(--muted);display:flex;align-items:center;gap:6px}
.kpi.gold{border-color:var(--gold-300);background:linear-gradient(180deg,var(--gold-100),#fff)}
.kpi.gold::after{background:radial-gradient(circle,rgba(201,162,75,.25),transparent 70%)}
.kpi .badge-ico{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;background:var(--green-100);color:var(--green-700)}
.kpi.gold .badge-ico{background:var(--gold-100);color:var(--gold-600)}
.trend{font-weight:700}
.trend.up{color:var(--ok)} .trend.down{color:var(--bad)}

.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:11.5px;font-weight:700}
.pill.green{background:var(--green-100);color:var(--green-800)}
.pill.gold{background:var(--gold-100);color:var(--gold-600)}
.pill.red{background:#fbe9e6;color:var(--bad)}
.pill.blue{background:#e8f0fb;color:var(--info)}
.pill.grey{background:var(--canvas-2);color:var(--muted)}
.halal{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:999px;font-size:11px;font-weight:800;
  background:var(--green-100);color:var(--green-800);border:1px solid var(--green-300)}

/* Insight stream */
.stream{display:flex;flex-direction:column;gap:2px;max-height:430px;overflow-y:auto}
.insight{display:flex;gap:12px;padding:13px 10px;border-radius:12px;transition:.15s;cursor:pointer}
.insight:hover{background:var(--canvas)}
.insight .ic{width:34px;height:34px;border-radius:10px;flex:0 0 auto;display:grid;place-items:center;color:#fff}
.insight .ic svg{width:17px;height:17px}
.insight .meta{flex:1;min-width:0}
.insight .meta b{font-size:13px;color:var(--ink);font-weight:700}
.insight .meta p{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.45}
.insight .meta .when{font-size:10.5px;color:#9aa8a3;margin-top:5px;text-transform:uppercase;letter-spacing:.06em}
.insight .go{align-self:center;color:var(--gold-600);font-weight:700;font-size:12px;white-space:nowrap;opacity:0;transform:translateX(-6px);transition:.18s}
html[dir="rtl"] .insight .go{transform:translateX(6px)}
.insight:hover .go{opacity:1;transform:none}

/* Quick actions */
.qa{display:flex;flex-wrap:wrap;gap:10px}
.qa button{display:flex;align-items:center;gap:9px;padding:11px 14px;border-radius:14px;background:var(--canvas);border:1px solid var(--line);
  font-weight:700;font-size:12.5px;color:var(--green-900);transition:.15s}
.qa button:hover{background:#fff;border-color:var(--gold-300);box-shadow:var(--sh-1);transform:translateY(-1px)}
.qa button .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:linear-gradient(135deg,var(--green-700),var(--green-800));color:#fff}
.qa button .ic svg{width:16px;height:16px}

/* Ask Shari launcher */
.ask-launch{background:linear-gradient(135deg,var(--green-800),var(--green-900));color:#eafaf4;border:none;overflow:hidden}
.ask-launch::after{display:none}
.ask-launch h3{color:#fff}
.ask-launch .card-sub{color:#9fd3c3}
.ask-launch .spark{position:absolute;inset-inline-end:-20px;bottom:-30px;width:140px;height:140px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,162,75,.5),transparent 65%)}
.ask-input{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  border-radius:999px;padding:11px 16px;color:#cfeae0;font-size:13px;margin-top:6px}
.ask-input svg{width:18px;height:18px;color:var(--gold-300)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.chip{font-size:11.5px;font-weight:600;padding:6px 11px;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);color:#dff1ea;transition:.15s}
.chip:hover{background:rgba(201,162,75,.25);border-color:var(--gold-300)}

/* mini library / marketplace */
.minirow{display:flex;align-items:center;justify-content:space-between;padding:9px 6px;border-bottom:1px dashed var(--line);font-size:13px}
.minirow:last-child{border-bottom:none}
.stars{color:var(--gold-500);font-size:12px;letter-spacing:1px}

/* ============ Charts ============ */
.donut{--p:0;width:148px;height:148px;border-radius:50%;flex:0 0 auto;position:relative;
  background:conic-gradient(var(--green-700) calc(var(--p)*1%), var(--gold-400,#e6cd8f) 0);
  -webkit-mask:radial-gradient(circle 44px at center,transparent 98%,#000);mask:radial-gradient(circle 44px at center,transparent 98%,#000)}
.donut-wrap{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.donut-center{position:absolute;inset:0;display:grid;place-content:center;text-align:center}
.legend{display:flex;flex-direction:column;gap:9px;font-size:13px}
.legend .li{display:flex;align-items:center;gap:9px}
.legend .sw{width:11px;height:11px;border-radius:3px;flex:0 0 auto}
.legend b{margin-inline-start:auto;font-weight:800;color:var(--green-900)}

.bars{display:flex;flex-direction:column;gap:12px}
.bar-row{display:grid;grid-template-columns:140px 1fr 64px;align-items:center;gap:12px;font-size:12.5px}
.bar-track{height:12px;background:var(--canvas-2);border-radius:999px;overflow:hidden}
.bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green-600),var(--green-800));
  transform-origin:left;animation:grow 1s cubic-bezier(.2,.8,.2,1) both}
html[dir="rtl"] .bar-fill{transform-origin:right}
.bar-row b{text-align:end;font-weight:800;color:var(--green-900)}
@keyframes grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}

.scatter{width:100%;height:300px}
.scatter circle{transition:.2s;cursor:pointer}
.scatter circle:hover{stroke:var(--gold-500);stroke-width:2}

.spark-svg{width:100%;height:70px}

/* tabs */
.tabs{display:flex;gap:4px;overflow-x:auto;border-bottom:1px solid var(--line);margin-bottom:18px;padding-bottom:0}
.tab{padding:10px 13px;font-size:12.5px;font-weight:600;color:var(--muted);white-space:nowrap;border-bottom:2.5px solid transparent;transition:.15s}
.tab:hover{color:var(--green-800)}
.tab.on{color:var(--green-900);border-color:var(--gold-500);font-weight:800}
.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.filter{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--green-900);
  background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 13px}
.filter .v{color:var(--muted);font-weight:600}

/* ============ Tables ============ */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:start;font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:700;
  padding:11px 12px;border-bottom:1px solid var(--line);white-space:nowrap}
.tbl td{padding:13px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:.12s}
.tbl tbody tr:hover{background:var(--canvas)}
.row-actions{display:flex;gap:6px;flex-wrap:wrap}

/* ============ Chat (Ask Shari) ============ */
.chat-wrap{display:grid;grid-template-columns:240px 1fr;gap:18px;min-height:560px}
.chat-history{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px;box-shadow:var(--sh-1)}
.chat-history h4{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:6px 8px 10px}
.hist{padding:10px 11px;border-radius:11px;font-size:13px;color:var(--ink);cursor:pointer;margin-bottom:3px;display:flex;gap:9px;align-items:center}
.hist svg{width:15px;height:15px;color:var(--green-600);flex:0 0 auto}
.hist:hover{background:var(--canvas)}
.hist.on{background:var(--green-100);font-weight:700;color:var(--green-900)}
.chat-main{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);display:flex;flex-direction:column;overflow:hidden}
.chat-scroll{flex:1;padding:22px;display:flex;flex-direction:column;gap:18px;overflow-y:auto;max-height:560px}
.msg{display:flex;gap:12px;max-width:92%}
.msg .who{width:34px;height:34px;border-radius:10px;flex:0 0 auto;display:grid;place-items:center;font-weight:800;font-size:12px;color:#fff}
.msg.user{align-self:flex-end;flex-direction:row-reverse}
.msg.user .who{background:var(--gold-500);color:#3a2c08}
.msg.bot .who{background:linear-gradient(135deg,var(--green-700),var(--green-900))}
.bubble{background:var(--canvas);border:1px solid var(--line);border-radius:16px;padding:14px 16px;font-size:13.5px;line-height:1.55}
.msg.user .bubble{background:var(--green-800);color:#eafaf4;border-color:transparent}
.bubble h5{font-size:12.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--gold-600);margin:12px 0 6px}
.bubble h5:first-child{margin-top:0}
.bubble ul{margin:0;padding-inline-start:18px;display:flex;flex-direction:column;gap:5px}
.bubble li::marker{color:var(--green-600)}
.answer-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;padding-top:12px;border-top:1px dashed var(--line)}
.chat-input{border-top:1px solid var(--line);padding:14px 18px;display:flex;align-items:center;gap:10px;background:#fff}
.chat-input input{flex:1;border:1px solid var(--line);border-radius:999px;padding:11px 16px;font-family:inherit;font-size:13.5px;outline:none}
.chat-input input:focus{border-color:var(--green-300)}
.send{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--green-700),var(--green-800));display:grid;place-items:center}
.send svg{width:18px;height:18px;color:#fff}

/* sourcing pipeline */
.stepper{display:flex;gap:8px;margin-bottom:22px;flex-wrap:wrap}
.step{flex:1;min-width:120px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;position:relative}
.step .n{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:800;background:var(--canvas-2);color:var(--muted)}
.step.done .n{background:var(--green-700);color:#fff}
.step.now{border-color:var(--gold-400,#e6cd8f);box-shadow:0 0 0 3px var(--gold-100)}
.step.now .n{background:var(--gold-500);color:#3a2c08}
.step .t{font-size:12.5px;font-weight:700;margin-top:8px;color:var(--green-900)}
.step .d{font-size:11px;color:var(--muted);margin-top:2px}

.bid-best{background:var(--green-100)!important}
.bid-best td{font-weight:700}
.mark{font-size:10.5px;font-weight:800;padding:3px 8px;border-radius:6px}
.mark.best{background:var(--green-700);color:#fff}
.mark.next{background:var(--gold-100);color:var(--gold-600)}
.mark.no{background:var(--canvas-2);color:var(--muted)}

/* finance / murabaha */
.offers{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.offer{border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;background:#fff;position:relative;transition:.18s;box-shadow:var(--sh-1)}
.offer:hover{transform:translateY(-3px);box-shadow:var(--sh-2);border-color:var(--green-300)}
.offer.pick{border-color:var(--gold-500);box-shadow:0 0 0 3px var(--gold-100),var(--sh-2)}
.offer .lender{font-weight:800;color:var(--green-900);font-size:15px}
.offer .rate{font-family:var(--font-display);font-size:34px;color:var(--green-800);font-weight:600;margin:10px 0 2px}
.offer .ribbon{position:absolute;top:14px;inset-inline-end:14px}
.flow{display:flex;flex-direction:column;gap:0}
.flow .fl{display:flex;gap:14px;padding:12px 0;position:relative}
.flow .fl .n{width:30px;height:30px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-weight:800;font-size:13px;
  background:var(--green-800);color:#fff;z-index:1}
.flow .fl:not(:last-child)::before{content:"";position:absolute;inset-inline-start:14px;top:30px;bottom:-12px;width:2px;background:var(--green-300)}
.flow .fl .ft b{font-size:13.5px;color:var(--green-900)}
.flow .fl .ft p{font-size:12px;color:var(--muted);margin-top:2px}
.no-funds{display:flex;gap:12px;align-items:center;background:var(--green-100);border:1px solid var(--green-300);border-radius:14px;padding:14px 16px;margin-top:6px}
.no-funds svg{width:26px;height:26px;color:var(--green-700);flex:0 0 auto}
.no-funds p{font-size:12.5px;color:var(--green-900);line-height:1.5}

/* ============ Welcome modal ============ */
.welcome{position:fixed;inset:0;z-index:100;display:grid;place-items:center;
  background:radial-gradient(1000px 700px at 50% 0%,rgba(14,92,74,.96),rgba(7,43,34,.985));
  backdrop-filter:blur(4px);animation:fade .5s}
.welcome.hide{opacity:0;pointer-events:none;transition:opacity .5s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.welcome-card{width:min(560px,92vw);text-align:center;color:#eafaf4;padding:10px 30px}
.welcome img{height:190px;margin:0 auto 6px;filter:drop-shadow(0 18px 40px rgba(0,0,0,.4))}
.welcome .eyebrow{color:var(--gold-300);letter-spacing:.18em;text-transform:uppercase;font-size:12px;font-weight:700}
.welcome h1{font-family:var(--font-display);font-weight:600;font-size:34px;margin:12px 0 10px;line-height:1.15;text-wrap:balance}
html[dir="rtl"] .welcome h1{font-family:var(--font-ar);font-weight:800}
.welcome p{color:#bfe0d5;font-size:15px;line-height:1.6;max-width:46ch;margin:0 auto 26px;text-wrap:pretty}
.welcome .cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.welcome .lang-toggle{margin:0 auto 22px;width:max-content}
.powered{margin-top:26px;font-size:11.5px;color:#7fae9f;letter-spacing:.04em}

/* ============ Guided tour ============ */
.tour{position:fixed;inset:0;z-index:90;pointer-events:none;display:none}
.tour.on{display:block}
.tour-backdrop{position:absolute;inset:0;background:transparent;pointer-events:auto;transition:.25s}
.spotlight{position:absolute;border-radius:16px;box-shadow:0 0 0 9999px rgba(8,40,32,.5);
  transition:all .35s cubic-bezier(.4,.1,.2,1);pointer-events:none;border:2px solid var(--gold-400,#e6cd8f)}
.coach{position:absolute;width:330px;background:#fff;border-radius:18px;box-shadow:var(--sh-3);padding:20px;pointer-events:auto;
  transition:all .35s cubic-bezier(.4,.1,.2,1);border-top:4px solid var(--gold-500)}
.coach .step-tag{font-size:11px;font-weight:800;color:var(--gold-600);letter-spacing:.1em;text-transform:uppercase}
.coach h4{font-family:var(--font-display);font-weight:600;font-size:19px;color:var(--green-900);margin:7px 0 8px;line-height:1.2}
html[dir="rtl"] .coach h4{font-family:var(--font-ar);font-weight:800}
.coach p{font-size:13.5px;color:var(--muted);line-height:1.6}
.coach .nav{display:flex;align-items:center;justify-content:space-between;margin-top:18px;gap:10px}
.coach .prog{display:flex;gap:5px;align-items:center}
.coach .prog .d{width:7px;height:7px;border-radius:50%;background:var(--canvas-2)}
.coach .prog .d.on{background:var(--gold-500);width:18px;border-radius:99px}
.coach .nav-btns{display:flex;gap:8px}
.coach .count{font-size:11.5px;color:var(--muted);font-weight:700}
.tour-skip{position:fixed;top:18px;inset-inline-end:20px;z-index:95;background:rgba(255,255,255,.9);color:var(--green-900);
  font-size:12px;font-weight:700;padding:8px 14px;border-radius:999px;pointer-events:auto;box-shadow:var(--sh-1)}

/* fab restart */
.fab{position:fixed;bottom:22px;inset-inline-end:22px;z-index:40;display:flex;align-items:center;gap:9px;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-600));color:#3a2c08;font-weight:800;font-size:13px;
  padding:12px 18px;border-radius:999px;box-shadow:0 12px 30px rgba(169,132,47,.45)}
.fab svg{width:17px;height:17px}

/* utility */
.row{display:flex;gap:18px}
.col{display:flex;flex-direction:column;gap:18px}
.muted{color:var(--muted)} .mono{font-variant-numeric:tabular-nums}
.mt{margin-top:16px}.mb{margin-bottom:14px}
.center{display:grid;place-items:center}
.hide{display:none!important}

/* CTA screen */
.cta-hero{text-align:center;max-width:720px;margin:30px auto;padding:46px 30px;border-radius:var(--r-xl);
  background:linear-gradient(160deg,var(--green-800),var(--green-900));color:#eafaf4;box-shadow:var(--sh-3);position:relative;overflow:hidden}
.cta-hero::before{content:"";position:absolute;inset-inline-end:-60px;top:-60px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,75,.4),transparent 65%)}
.cta-hero img{height:120px;margin:0 auto 18px}
.cta-hero h1{font-family:var(--font-display);font-weight:600;font-size:34px;margin-bottom:14px}
html[dir="rtl"] .cta-hero h1{font-family:var(--font-ar);font-weight:800}
.cta-hero p{color:#bfe0d5;font-size:15px;line-height:1.65;max-width:52ch;margin:0 auto 26px}
.cta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;max-width:760px;margin:26px auto 0}
.cta-grid .c{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px;text-align:center}
.cta-grid .c b{display:block;font-family:var(--font-display);font-size:24px;color:var(--green-800)}
.cta-grid .c span{font-size:11.5px;color:var(--muted)}

/* ============ Charts ============ */
.chart{width:100%;height:auto;display:block;overflow:visible}
.chart .grid{stroke:var(--line);stroke-width:1}
.chart .axis{stroke:#cdd9d4;stroke-width:1.4}
.ax-x{font-size:9px;fill:var(--muted);text-anchor:middle;font-family:var(--font-ui)}
.ax-y{font-size:9px;fill:var(--muted);text-anchor:end;font-family:var(--font-ui)}
.ax-title{font-size:9.5px;fill:#9aa8a3;font-weight:700;text-anchor:middle;letter-spacing:.02em}
.chart .line{fill:none;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
.chart .line.draw{stroke-dasharray:1400;stroke-dashoffset:1400;animation:draw 1.3s cubic-bezier(.3,.7,.2,1) forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.chart .pt{opacity:0;animation:fadein .4s .9s forwards}
.chart .pt-a{fill:#0e5c4a}.chart .pt-b{fill:#c9a24b}
@keyframes fadein{to{opacity:1}}
.bub{transform-box:fill-box;transform-origin:center;opacity:0;animation:pop .55s cubic-bezier(.2,1.5,.4,1) forwards;animation-delay:var(--d)}
@keyframes pop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:.95}}
.bub-l{font-size:8px;fill:#fff;font-weight:800;text-anchor:middle;dominant-baseline:middle;pointer-events:none}
.donut-svg .seg{opacity:0;animation:segin .55s ease forwards;animation-delay:var(--d)}
@keyframes segin{from{opacity:0}to{opacity:1}}
.dn-t{font-size:17px;font-weight:800;fill:var(--green-900);text-anchor:middle;font-family:var(--font-ui)}
.dn-s{font-size:9px;fill:var(--muted);text-anchor:middle}
.pbar{fill:url(#none);fill:#1c8a6e;transform-box:fill-box;transform-origin:bottom;transform:scaleY(0);animation:barin .7s cubic-bezier(.2,.8,.2,1) forwards;animation-delay:var(--d)}
@keyframes barin{to{transform:scaleY(1)}}

/* dashboard layout */
.dash{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;align-items:start}
.mini-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:18px}
.mini-kpi{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:14px 16px;box-shadow:var(--sh-1)}
.mini-kpi .l{font-size:11.5px;color:var(--muted);font-weight:600}
.mini-kpi .v{font-size:23px;font-weight:800;color:var(--green-900);margin-top:6px;letter-spacing:-.02em}
.mini-kpi.gold .v{color:var(--gold-600)}
.legend-tag{font-size:11px;color:var(--muted);display:inline-flex;align-items:center;gap:6px;margin-inline-end:14px}
.legend-tag .sw{width:10px;height:10px;border-radius:3px}
.panel-note{font-size:12px;color:var(--muted);background:var(--canvas);border-radius:10px;padding:10px 12px;margin-top:12px;line-height:1.5}

/* tooltip */
#chTip{position:fixed;z-index:120;background:#0a3d31;color:#eafaf4;padding:7px 11px;border-radius:9px;font-size:12px;font-weight:600;
  pointer-events:none;opacity:0;transition:opacity .12s;box-shadow:var(--sh-2);max-width:260px;transform:translate(-50%,-130%)}
#chTip.show{opacity:1}

/* toasts */
#toasts{position:fixed;bottom:86px;inset-inline-end:22px;z-index:130;display:flex;flex-direction:column;gap:10px}
.toast{background:#fff;border:1px solid var(--line);border-inline-start:4px solid var(--gold-500);border-radius:13px;padding:12px 16px;
  box-shadow:var(--sh-2);font-size:13px;font-weight:600;color:var(--green-900);display:flex;gap:10px;align-items:center;min-width:240px;
  animation:toastin .35s cubic-bezier(.2,1.3,.4,1)}
.toast.out{animation:toastout .3s forwards}
.toast .tic{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;background:var(--green-100);color:var(--green-700);flex:0 0 auto}
@keyframes toastin{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes toastout{to{opacity:0;transform:translateX(20px)}}

/* splash */
#splash{position:fixed;inset:0;z-index:200;display:grid;place-items:center;background:radial-gradient(900px 600px at 50% 35%,#0e5c4a,#072b22)}
#splash.hide{opacity:0;pointer-events:none;transition:opacity .6s}
#splash img{height:120px;animation:breathe 1.8s ease-in-out infinite}
#splash .ring{margin-top:26px;width:34px;height:34px;border-radius:50%;border:3px solid rgba(255,255,255,.18);border-top-color:var(--gold-400,#e6cd8f);animation:spin .8s linear infinite}
@keyframes breathe{0%,100%{transform:scale(1);filter:drop-shadow(0 10px 26px rgba(0,0,0,.4))}50%{transform:scale(1.06);filter:drop-shadow(0 18px 40px rgba(201,162,75,.4))}}
@keyframes spin{to{transform:rotate(360deg)}}

/* count-up + stagger reveals */
.kpis>.kpi,.mini-kpis>.mini-kpi{opacity:0;animation:rise .5s cubic-bezier(.2,.7,.2,1) forwards}
.kpis>.kpi:nth-child(1),.mini-kpis>.mini-kpi:nth-child(1){animation-delay:.04s}
.kpis>.kpi:nth-child(2),.mini-kpis>.mini-kpi:nth-child(2){animation-delay:.10s}
.kpis>.kpi:nth-child(3),.mini-kpis>.mini-kpi:nth-child(3){animation-delay:.16s}
.kpis>.kpi:nth-child(4),.mini-kpis>.mini-kpi:nth-child(4){animation-delay:.22s}
.kpis>.kpi:nth-child(5){animation-delay:.28s}.kpis>.kpi:nth-child(6){animation-delay:.34s}
.kpis>.kpi:nth-child(7){animation-delay:.40s}.kpis>.kpi:nth-child(8){animation-delay:.46s}

/* pulsing tour hotspot */
.spotlight::after{content:"";position:absolute;inset:-2px;border-radius:16px;border:2px solid var(--gold-400,#e6cd8f);animation:pulsering 1.6s ease-out infinite}
@keyframes pulsering{0%{box-shadow:0 0 0 0 rgba(201,162,75,.45)}70%{box-shadow:0 0 0 14px rgba(201,162,75,0)}100%{box-shadow:0 0 0 0 rgba(201,162,75,0)}}

/* ============ WhatsApp intake (Module 1) ============ */
.intake-grid{display:grid;grid-template-columns:330px 1fr;gap:22px;align-items:start}
.phone{width:330px;background:#0b141a;border-radius:36px;padding:12px;box-shadow:var(--sh-3);border:1px solid #20303a}
.phone .notch{width:130px;height:22px;background:#0b141a;border-radius:0 0 16px 16px;margin:0 auto 4px}
.wa{background:#e9e2d8;border-radius:26px;overflow:hidden;height:560px;display:flex;flex-direction:column;
  background-image:radial-gradient(circle at 20% 10%,rgba(0,0,0,.03),transparent),linear-gradient(#efe9df,#e9e2d8)}
.wa-top{background:linear-gradient(135deg,var(--green-700),var(--green-900));color:#fff;padding:14px 16px;display:flex;align-items:center;gap:11px}
.wa-top .ava{width:36px;height:36px;border-radius:50%;background:#fff;display:grid;place-items:center;overflow:hidden}
.wa-top .ava img{height:30px}
.wa-top b{font-size:14px}.wa-top span{font-size:11px;opacity:.85;display:block}
.wa-body{flex:1;padding:16px 14px;display:flex;flex-direction:column;gap:10px;overflow-y:auto}
.wa-msg{max-width:84%;padding:9px 12px;border-radius:12px;font-size:12.5px;line-height:1.45;box-shadow:0 1px 1px rgba(0,0,0,.08);position:relative}
.wa-msg.in{background:#fff;align-self:flex-start;border-top-left-radius:3px}
.wa-msg.out{background:#d6f5c6;align-self:flex-end;border-top-right-radius:3px}
html[dir="rtl"] .wa-msg.in{align-self:flex-end;border-top-left-radius:12px;border-top-right-radius:3px}
html[dir="rtl"] .wa-msg.out{align-self:flex-start}
.wa-voice{display:flex;align-items:center;gap:9px;min-width:170px}
.wa-voice .play{width:28px;height:28px;border-radius:50%;background:var(--green-700);color:#fff;display:grid;place-items:center;flex:0 0 auto}
.wa-wave{flex:1;height:22px;background:repeating-linear-gradient(90deg,var(--green-600) 0 2px,transparent 2px 5px);opacity:.5;border-radius:3px}
.wa-time{font-size:9.5px;color:#7c8b84;text-align:end;margin-top:3px}
.wa-card{background:#fff;border-radius:12px;padding:11px 12px;align-self:stretch;box-shadow:0 1px 2px rgba(0,0,0,.1);font-size:12.5px}
.wa-input{background:#fff;margin:8px;border-radius:22px;padding:10px 14px;color:#9aa8a3;font-size:12.5px;display:flex;align-items:center;gap:8px}

.extract h3 .pill{margin-inline-start:auto}
.transcript{background:var(--green-100);border:1px solid var(--green-300);border-radius:14px;padding:14px 16px;font-style:italic;color:var(--green-900);font-size:13.5px;line-height:1.6;margin-bottom:16px}
.field-row{display:grid;grid-template-columns:150px 1fr 120px;align-items:center;gap:14px;padding:11px 0;border-bottom:1px solid var(--line)}
.field-row:last-child{border-bottom:none}
.field-row .fk{font-size:12px;color:var(--muted);font-weight:600}
.field-row .fv{font-size:13.5px;font-weight:700;color:var(--green-900)}
.conf{display:flex;align-items:center;gap:9px}
.conf-bar{flex:1;height:7px;background:var(--canvas-2);border-radius:9px;overflow:hidden}
.conf-fill{height:100%;border-radius:9px;transform-origin:left;animation:grow 1s cubic-bezier(.2,.8,.2,1) both}
html[dir="rtl"] .conf-fill{transform-origin:right}
.conf-v{font-size:11.5px;font-weight:800;width:34px;text-align:end}
.conf.hi .conf-fill{background:var(--green-600)}.conf.hi .conf-v{color:var(--green-700)}
.conf.mid .conf-fill{background:var(--gold-500)}.conf.mid .conf-v{color:var(--gold-600)}
.conf.lo .conf-fill{background:var(--bad)}.conf.lo .conf-v{color:var(--bad)}

/* ============ Investor: comparison + ROI ============ */
.cmp{width:100%;border-collapse:collapse;font-size:13.5px}
.cmp th{padding:14px 12px;text-align:center;font-size:12px;border-bottom:2px solid var(--line)}
.cmp th.shari{background:linear-gradient(135deg,var(--green-800),var(--green-900));color:#fff;border-radius:12px 12px 0 0}
.cmp td{padding:13px 12px;border-bottom:1px solid var(--line);text-align:center}
.cmp td.f{text-align:start;font-weight:600;color:var(--green-900)}
.cmp td.shari{background:var(--green-100)}
.ck{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:50%;font-weight:900;font-size:13px}
.ck.no{background:#f3ecea;color:#c1492f}.ck.yes{background:var(--green-100);color:var(--green-700)}.ck.plus{background:var(--gold-500);color:#3a2c08}

.roi-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:20px;align-items:center}
.roi-ctrl label{display:block;font-size:12.5px;font-weight:700;color:var(--green-900);margin:16px 0 8px}
.roi-ctrl input[type=range]{width:100%;accent-color:var(--green-700)}
.roi-ctrl .rv{font-family:var(--font-display);font-size:22px;color:var(--green-800);font-weight:600}
.roi-out{background:linear-gradient(160deg,var(--green-800),var(--green-900));color:#eafaf4;border-radius:var(--r-lg);padding:24px;text-align:center}
.roi-out .big{font-family:var(--font-display);font-size:40px;font-weight:600;color:#fff}
.roi-out .lbl{font-size:12.5px;color:#bfe0d5;margin-top:4px}
.roi-out .split{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:20px}
.roi-out .split b{display:block;font-size:21px;color:var(--gold-300);font-family:var(--font-display)}
.roi-out .split span{font-size:11px;color:#bfe0d5}
.print-only{display:none}

/* ============ Dark mode ============ */
html.dark{--canvas:#0a1b16;--canvas-2:#142a23;--paper:#11241d;--line:#23392f;--ink:#e9f3ef;--muted:#a0b8af;--brand-num:#eafaf4}
html.dark body{background:radial-gradient(1200px 600px at 85% -10%,rgba(28,138,110,.16),transparent 60%),radial-gradient(900px 520px at -5% 10%,rgba(201,162,75,.10),transparent 55%),#07140f}
html.dark .topbar{background:rgba(11,28,23,.9)}
html.dark .topbar .logo{filter:brightness(0) invert(1)}
/* surfaces that were hard-coded light */
html.dark .search,html.dark .icon-btn,html.dark .lang-toggle,html.dark .filter,html.dark .btn-ghost,
html.dark .qa button,html.dark .offer,html.dark .step,html.dark .cta-grid .c,html.dark .chat-input{background:var(--canvas-2);border-color:var(--line)}
html.dark .btn-ghost,html.dark .icon-btn svg{color:#bfe0d5}
html.dark .qa button:hover,html.dark .search:focus-within,html.dark .offer:hover{background:#19392e}
html.dark .tbl tbody tr:hover,html.dark .insight:hover{background:#16332a}
html.dark .kpi.gold,html.dark .mini-kpi.gold{background:linear-gradient(180deg,#2a230f,#14241d);border-color:#3a2f12}
/* brand-dark text that must go light on dark surfaces */
html.dark .page-head h1,html.dark .card h3,html.dark .kpi .k-val,html.dark .mini-kpi .v,html.dark .legend b,
html.dark .bar-row b,html.dark .tab.on,html.dark .tab:hover,html.dark .qa button,html.dark .filter,
html.dark .step .t,html.dark .offer .lender,html.dark .offer .rate,html.dark .flow .fl .ft b,
html.dark .field-row .fv,html.dark .cmp td.f,html.dark .roi-ctrl label,html.dark .roi-ctrl .rv,
html.dark .cta-grid .c b,html.dark .dn-t,html.dark .ax-y{color:#eafaf4;fill:#eafaf4}
html.dark .bubble h5{color:var(--gold-300)}
html.dark .ask-input{background:rgba(255,255,255,.08)}
/* light-tint content surfaces → dark translucent (keep text readable) */
html.dark .bid-best{background:rgba(28,138,110,.20)!important}
html.dark .transcript,html.dark .no-funds{background:rgba(28,138,110,.13);border-color:rgba(28,138,110,.34)}
html.dark .transcript,html.dark .no-funds p{color:#dcefe8}
html.dark .cmp td.shari{background:rgba(28,138,110,.13)}
html.dark .hist.on{background:rgba(28,138,110,.20);color:#eafaf4}

/* print — ROI one-pager */
@media print{
  .topbar,.sidebar,.tour,.tour-skip,.fab,#toasts,#chTip,#splash,#welcome,.page-head button{display:none!important}
  .screen:not(.active){display:none!important}
  body,.content{overflow:visible!important;background:#fff!important}
  .app{height:auto!important}
  .roi-out{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* responsive */
.hamburger{display:none}
.nav-scrim{display:none}
@media (max-width:1080px){
  .chat-wrap{grid-template-columns:1fr}
  .sidebar{width:74px}
  .nav-item span,.sidebar .grp,.nav-foot{display:none}
  .nav-item{justify-content:center}
  .intake-grid{grid-template-columns:1fr;justify-items:center}
  .phone{width:min(330px,92vw)}
}
@media (max-width:760px){
  /* off-canvas sidebar drawer */
  .hamburger{display:grid}
  .sidebar{position:fixed;top:var(--topbar-h);bottom:0;inset-inline-start:0;width:min(280px,82vw);
    transform:translateX(-100%);transition:transform .3s ease;z-index:55;box-shadow:var(--sh-3)}
  html[dir="rtl"] .sidebar{transform:translateX(100%)}
  body.nav-open .sidebar{transform:none}
  .sidebar .grp,.nav-foot{display:block}
  .nav-item{justify-content:flex-start}
  .nav-item span{display:inline}
  .nav-scrim{position:fixed;inset:var(--topbar-h) 0 0 0;background:rgba(7,30,24,.5);z-index:54}
  body.nav-open .nav-scrim{display:block}
  .content{padding:18px 14px 72px}
  .search{display:none}
  .topbar{gap:10px;padding:0 14px}
  .topbar .logo.full{display:none}.topbar .logo.icon{display:block;height:32px}
  #bell{display:none}
  .page-head h1{font-size:24px}
  .tbl,.cmp{display:block;width:100%;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .coach{width:min(330px,92vw)}
  .roi-grid{grid-template-columns:1fr}
  .welcome img{height:128px}.welcome h1{font-size:26px}.welcome-card{padding:6px 18px}
  .welcome p{font-size:14px}
  .content .grid{grid-template-columns:1fr!important}
}
@media (max-width:440px){
  #askTop span[data-i18n]{display:none}
  .step{min-width:100%}
}

/* ===== impeccable polish: brand-on-dark, focus, reduced motion ===== */
/* the stacked logo is green-on-transparent; render white on the dark splash/welcome/closing screens */
#splash img,.welcome img,.cta-hero img{filter:brightness(0) invert(1)}
:focus-visible{outline:2.5px solid var(--gold-500);outline-offset:2px;border-radius:6px}
.nav-item:focus-visible,.tab:focus-visible{outline-offset:-2px}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  #splash .ring{animation:none!important}
  .spotlight::after{animation:none!important}
}

/* ===== tour flow: progress bar + auto-play ===== */
.coach .nav{gap:10px}
.coach .prog{flex:1;display:flex;align-items:center;gap:9px}
.tour-bar{flex:1;min-width:54px;height:5px;background:var(--canvas-2);border-radius:4px;overflow:hidden}
.tour-bar i{display:block;height:100%;border-radius:4px;background:linear-gradient(90deg,var(--green-600),var(--gold-500));transition:width .35s cubic-bezier(.2,.8,.2,1)}
.coach .count{font-size:11px;color:var(--muted);font-weight:700;white-space:nowrap}
.coach-auto{width:30px;height:30px;border-radius:8px;flex:0 0 auto;display:grid;place-items:center;font-size:11px;
  background:var(--canvas-2);color:var(--green-800);border:1px solid var(--line);transition:.15s}
.coach-auto:hover{border-color:var(--gold-300)}
.coach-auto.on{background:var(--green-800);color:#fff;border-color:var(--green-800)}

/* ===== journey "next step" footer (free navigation) ===== */
.journey{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:30px;padding:16px 20px;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);flex-wrap:wrap}
.journey .jl{font-size:12px;color:var(--muted);font-weight:600}
.journey .jl b{color:var(--green-900);font-weight:800}
html.dark .journey .jl b{color:#eafaf4}
.journey .jbtns{display:flex;gap:10px}
.jstep{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:13px;padding:10px 16px;border-radius:12px;
  background:var(--canvas);border:1px solid var(--line);color:var(--green-900);transition:.15s}
.jstep:hover{border-color:var(--gold-300);background:#fff;box-shadow:var(--sh-1)}
html.dark .jstep{background:var(--canvas-2);color:#eafaf4}
html.dark .jstep:hover{background:#19392e}
.jstep.primary{background:linear-gradient(135deg,var(--green-700),var(--green-800));color:#fff;border-color:transparent}
.jstep .ar-flip{display:inline-flex}
html[dir="rtl"] .jstep .ar-flip{transform:scaleX(-1)}

/* awarded-item banner on finance screen (action continuity) */
.award-banner{display:flex;align-items:center;gap:12px;background:var(--green-100);border:1px solid var(--green-300);
  border-radius:14px;padding:13px 16px;margin-bottom:18px;font-size:13.5px;color:var(--green-900)}
.award-banner .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--green-700);color:#fff;flex:0 0 auto}
.award-banner b{font-weight:800}
html.dark .award-banner{background:rgba(28,138,110,.16);border-color:rgba(28,138,110,.34);color:#eafaf4}

/* ===== intake channels ===== */
.channels{display:flex;flex-wrap:wrap;gap:10px}
.chan{display:flex;align-items:center;gap:9px;padding:10px 14px;border-radius:12px;border:1px solid var(--line);background:var(--canvas);transition:.15s;font-weight:600;color:var(--green-900)}
html.dark .chan{background:var(--canvas-2);color:#eafaf4}
.chan:hover{border-color:var(--gold-300)}
.chan .chan-ic{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:#fff;color:var(--muted);border:1px solid var(--line)}
html.dark .chan .chan-ic{background:#0f241d}
.chan.on .chan-ic{background:var(--green-700);color:#fff;border-color:transparent}
.chan .chan-n{font-size:13px}
.chan .chan-st{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.chan.on .chan-st{color:var(--green-700)} html.dark .chan.on .chan-st{color:var(--green-300)}

/* ===== approvals chain + budget ===== */
.ap-chain{display:flex;flex-direction:column;gap:8px}
.ap-step{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--line);border-radius:12px}
.ap-step.done{background:var(--green-100);border-color:var(--green-300)}
html.dark .ap-step.done{background:rgba(28,138,110,.16);border-color:rgba(28,138,110,.34)}
.ap-step.now{box-shadow:0 0 0 3px var(--gold-100)}
.ap-dot{width:28px;height:28px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-weight:800;font-size:13px;background:var(--green-700);color:#fff}
.ap-step.now .ap-dot{background:var(--gold-500);color:#3a2c08}
.ap-meta{flex:1}.ap-meta b{font-size:13.5px;color:var(--green-900)} html.dark .ap-meta b{color:#eafaf4}
.ap-when{font-size:11px;color:var(--muted);margin-inline-start:8px}
.bbar{height:14px;border-radius:8px;background:var(--canvas-2);overflow:hidden;display:flex}
.bbar i{height:100%;display:block}
.bbar .bc,.bsw.bc{background:var(--green-600)}.bbar .bp,.bsw.bp{background:var(--gold-500)}
.brow{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px dashed var(--line);font-size:13px}
.brow:last-child{border-bottom:none}.brow b{color:var(--green-900);font-weight:800} html.dark .brow b{color:#eafaf4}
.bsw{display:inline-block;width:10px;height:10px;border-radius:3px;margin-inline-end:7px}
.wa-approve{display:flex;gap:8px;align-self:flex-start;background:#fff;padding:8px;border-radius:12px;box-shadow:0 1px 2px rgba(0,0,0,.12)}
html[dir="rtl"] .wa-approve{align-self:flex-end}

/* ===== persona picker + chip ===== */
.persona-pick{margin:0 auto 18px;text-align:center}
.persona-pick .pp-label{display:block;font-size:12px;color:#9fd3c3;margin-bottom:8px;font-weight:600}
.pp-btns{display:inline-flex;gap:8px;flex-wrap:wrap;justify-content:center}
.pp-btns button{padding:9px 16px;border-radius:999px;font-weight:700;font-size:13px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#eafaf4;transition:.15s}
.pp-btns button:hover{background:rgba(255,255,255,.18)}
.pp-btns button.on{background:linear-gradient(135deg,var(--gold-500),var(--gold-600));color:#3a2c08;border-color:transparent}
.persona-chip{font-size:11.5px;font-weight:700;color:var(--green-800);background:var(--green-100);border:1px solid var(--green-300);padding:5px 11px;border-radius:999px;white-space:nowrap}
html.dark .persona-chip{background:rgba(28,138,110,.18);border-color:rgba(28,138,110,.34);color:#cfeee2}
@media (max-width:760px){.persona-chip{display:none}}

/* ===== chat typing indicator + skeleton/empty ===== */
.typing{display:inline-flex;gap:5px;align-items:center;padding:4px 2px}
.typing i{width:7px;height:7px;border-radius:50%;background:var(--green-600);opacity:.5;animation:typed 1s infinite ease-in-out}
.typing i:nth-child(2){animation-delay:.15s}.typing i:nth-child(3){animation-delay:.3s}
@keyframes typed{0%,80%,100%{transform:translateY(0);opacity:.4}40%{transform:translateY(-4px);opacity:1}}
.skeleton{background:linear-gradient(90deg,var(--canvas-2) 25%,var(--canvas) 37%,var(--canvas-2) 63%);background-size:400% 100%;animation:shimmer 1.4s infinite;border-radius:8px}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}
.empty{text-align:center;color:var(--muted);padding:36px 20px}
@media (prefers-reduced-motion:reduce){.typing i,.skeleton{animation:none}}
