/* ============================================================
   Clear Mint — V6 additions for AI Assistant, Family Vault,
   Reports & Insights. Additive; reuses cm-/st-/an- vocabulary.
   ============================================================ */

/* ---------------- Robot mascot ---------------- */
.cm-robot { position:relative; display:inline-block; line-height:0; }
.cm-robot img { display:block; width:100%; height:100%; object-fit:contain;
  filter: drop-shadow(0 14px 22px rgba(20,70,52,.16)); }
.cm-robot::before { content:''; position:absolute; left:50%; top:54%;
  width:78%; height:64%; transform:translate(-50%,-50%);
  background:radial-gradient(closest-side, rgba(46,139,87,.22), rgba(46,139,87,0) 70%);
  filter:blur(6px); z-index:-1; pointer-events:none; }
.cm-robot.float { animation: cm-float 5.5s ease-in-out infinite; }
.cm-robot.float2 { animation: cm-float 6.5s ease-in-out infinite; }
@keyframes cm-float { 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-9px); } }
@media (prefers-reduced-motion: reduce){ .cm-robot.float, .cm-robot.float2 { animation:none; } }

/* ---------------- Score gauge (semicircle) ---------------- */
.cm-scoregauge { position:relative; display:inline-block; }
.cm-scoregauge .sg-center { position:absolute; left:0; right:0; bottom:8%; text-align:center; }
.cm-scoregauge .sg-score { font-family:var(--font-serif); font-weight:700; color:var(--ink-900); line-height:1; }
.cm-scoregauge .sg-label { font-size:12px; font-weight:800; color:var(--green-600); margin-top:3px; letter-spacing:.01em; }
.cm-stars { display:flex; gap:3px; justify-content:center; color:var(--gold); }

/* ---------------- Hero band ---------------- */
.cm-hero { position:relative; overflow:hidden; border-radius:var(--r-card);
  background:linear-gradient(135deg,#0D3B2E 0%,#11422F 52%,#0A2E22 100%);
  border:1px solid rgba(212,169,93,.24); color:#EAF0EA; padding:30px 34px; }
.cm-hero::after { content:''; position:absolute; right:-40px; top:-60px; width:360px; height:360px;
  background:radial-gradient(closest-side, rgba(46,139,87,.30), transparent 72%); pointer-events:none; }
.cm-hero::before { content:''; position:absolute; left:-60px; bottom:-90px; width:300px; height:300px;
  background:radial-gradient(closest-side, rgba(212,169,93,.16), transparent 72%); pointer-events:none; }
.cm-hero-grid { position:relative; z-index:1; display:grid; grid-template-columns:auto 1fr auto; gap:28px; align-items:center; }
.cm-hero h1 { font-family:var(--font-serif); font-size:30px; font-weight:700; margin:0 0 8px; color:#FBFAF6; letter-spacing:0; }
.cm-hero p { margin:0; font-size:15px; line-height:1.5; color:rgba(234,240,234,.82); max-width:440px; }
.cm-hero .hero-chips { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.cm-chip-action { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.08);
  border:1px solid rgba(212,169,93,.30); color:#F4F8F2; border-radius:var(--r-pill);
  padding:9px 15px; font-size:13px; font-weight:700; cursor:pointer; transition:.15s; white-space:nowrap; }
.cm-chip-action:hover { background:rgba(255,255,255,.16); }
.cm-chip-action svg { color:var(--gold); }
.cm-hero-score { background:rgba(255,255,255,.07); border:1px solid rgba(212,169,93,.22);
  border-radius:16px; padding:16px 22px; text-align:center; backdrop-filter:blur(2px); }
.cm-hero-score .hs-cap { font-size:12px; font-weight:700; color:rgba(234,240,234,.8); margin-bottom:6px; }
.cm-hero-score .cm-scoregauge .sg-score { color:#FBFAF6; }
.cm-hero-score .cm-scoregauge .sg-label { color:var(--gold-soft); }
.cm-hero-score .hs-foot { font-size:11.5px; color:rgba(234,240,234,.7); margin-top:8px; font-weight:600; }
@media (max-width:1080px){ .cm-hero-grid { grid-template-columns:1fr; text-align:left; }
  .cm-hero-score { justify-self:start; } .cm-hero .robot-hero { display:none; } }

/* ---------------- Quick insight strip ---------------- */
.cm-qi { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.cm-qi-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--r-card);
  box-shadow:var(--shadow-card); padding:15px 16px; position:relative; overflow:hidden; min-height:120px; }
.cm-qi-card .qi-top { display:flex; align-items:center; gap:9px; margin-bottom:9px; }
.cm-qi-card .qi-bot { width:30px; height:30px; flex:0 0 30px; }
.cm-qi-card .qi-tag { font-size:11.5px; font-weight:800; letter-spacing:.01em; }
.cm-qi-card .qi-text { font-size:12px; font-weight:600; color:var(--ink-500); line-height:1.42; }
.cm-qi-card .qi-link { margin-top:9px; font-size:11.5px; font-weight:800; color:var(--green-600);
  display:inline-flex; align-items:center; gap:4px; cursor:pointer; }
@media (max-width:1280px){ .cm-qi { grid-template-columns:repeat(3,1fr); } }
@media (max-width:760px){ .cm-qi { grid-template-columns:1fr; } }

/* ---------------- Chat ---------------- */
.cm-chat { display:flex; flex-direction:column; height:100%; min-height:430px; }
.cm-chat-scroll { flex:1; overflow-y:auto; display:flex; flex-direction:column; gap:16px; padding-right:4px; }
.cm-msg { display:flex; gap:11px; align-items:flex-end; max-width:86%; }
.cm-msg .cm-robot { width:38px; height:38px; flex:0 0 38px; }
.cm-bubble { border-radius:16px; padding:12px 15px; font-size:13.5px; line-height:1.5; font-weight:500; }
.cm-msg.bot .cm-bubble { background:var(--mint-50); color:var(--ink-700); border:1px solid var(--line); border-bottom-left-radius:5px; }
.cm-msg.user { align-self:flex-end; flex-direction:row-reverse; }
.cm-msg.user .cm-bubble { background:var(--forest); color:#F4F8F2; border-bottom-right-radius:5px; }
.cm-msg .stamp { font-size:10.5px; color:var(--ink-400); margin-top:5px; font-weight:600; }
.cm-suggest { display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.cm-suggest button { background:#fff; border:1px solid var(--line); border-radius:var(--r-pill);
  padding:8px 13px; font-size:12.5px; font-weight:700; color:var(--ink-700); cursor:pointer; font-family:inherit; transition:.15s; }
.cm-suggest button:hover { background:var(--mint-50); border-color:var(--green-500); color:var(--green-600); }
.cm-composer { display:flex; align-items:center; gap:10px; margin-top:14px; background:#fff;
  border:1px solid var(--line); border-radius:14px; padding:8px 8px 8px 16px; }
.cm-composer input { flex:1; border:0; outline:0; background:transparent; font-family:inherit;
  font-size:14px; color:var(--ink-900); }
.cm-composer .send { width:40px; height:40px; flex:0 0 40px; border-radius:11px; border:0; cursor:pointer;
  background:var(--forest); color:#fff; display:flex; align-items:center; justify-content:center; }
.cm-composer .send:hover { background:var(--emerald); }
.cm-composer .mic { color:var(--ink-400); cursor:pointer; display:flex; }
.cm-typing { display:inline-flex; gap:4px; align-items:center; padding:4px 2px; }
.cm-typing i { width:7px; height:7px; border-radius:50%; background:var(--green-500); opacity:.5;
  animation:cm-typing 1.1s infinite ease-in-out; }
.cm-typing i:nth-child(2){ animation-delay:.18s; } .cm-typing i:nth-child(3){ animation-delay:.36s; }
@keyframes cm-typing { 0%,80%,100%{ transform:translateY(0); opacity:.4; } 40%{ transform:translateY(-4px); opacity:1; } }

/* ---------------- Recommendation rows ---------------- */
.cm-rec { display:flex; align-items:flex-start; gap:13px; padding:14px 0; border-bottom:1px solid var(--line); }
.cm-rec:last-child { border-bottom:0; }
.cm-rec-ic { width:38px; height:38px; flex:0 0 38px; border-radius:11px; display:flex; align-items:center; justify-content:center; }
.cm-rec-body { flex:1; min-width:0; }
.cm-rec-title { font-size:14px; font-weight:800; color:var(--ink-900); }
.cm-rec-sub { font-size:12.5px; font-weight:500; color:var(--ink-500); margin-top:3px; line-height:1.45; }
.cm-rec-impact { text-align:right; flex:0 0 auto; }
.cm-rec-impact .k { font-size:10.5px; font-weight:700; color:var(--ink-400); }
.cm-rec-impact .v { font-size:13px; font-weight:800; margin-top:2px; }

/* ---------------- Prediction rows ---------------- */
.cm-pred { display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px solid var(--line); }
.cm-pred:last-child { border-bottom:0; }
.cm-pred-ic { width:32px; height:32px; flex:0 0 32px; border-radius:9px; background:var(--mint-50);
  color:var(--green-600); display:flex; align-items:center; justify-content:center; }
.cm-pred-tx { flex:1; font-size:13px; font-weight:600; color:var(--ink-700); line-height:1.4; }
.cm-pred-tx b { font-weight:800; color:var(--ink-900); }
.cm-pred-when { font-size:11.5px; font-weight:800; color:var(--gold); white-space:nowrap; }

/* ---------------- Learning / tool tiles ---------------- */
.cm-learn { display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px solid var(--line); cursor:pointer; }
.cm-learn:last-child { border-bottom:0; }
.cm-learn-ic { width:38px; height:38px; flex:0 0 38px; border-radius:11px; display:flex; align-items:center; justify-content:center; }
.cm-learn-body { flex:1; min-width:0; }
.cm-learn-title { font-size:13.5px; font-weight:800; color:var(--ink-900); }
.cm-learn-sub { font-size:11.5px; font-weight:500; color:var(--ink-400); margin-top:2px; }

.cm-tools { display:grid; grid-template-columns:repeat(6,1fr); gap:14px; }
.cm-tool { background:var(--surface); border:1px solid var(--line); border-radius:var(--r-card);
  box-shadow:var(--shadow-card); padding:18px 16px; text-align:left; cursor:pointer; transition:.15s; }
.cm-tool:hover { border-color:var(--green-500); box-shadow:var(--shadow-pop); transform:translateY(-2px); }
.cm-tool .t-ic { width:42px; height:42px; border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:12px; }
.cm-tool .t-name { font-size:13.5px; font-weight:800; color:var(--ink-900); }
.cm-tool .t-sub { font-size:11.5px; font-weight:500; color:var(--ink-400); margin-top:4px; line-height:1.4; }
@media (max-width:1280px){ .cm-tools { grid-template-columns:repeat(3,1fr); } }
@media (max-width:620px){ .cm-tools { grid-template-columns:1fr 1fr; } }

/* ---------------- Scenario planner ---------------- */
.cm-scenarios { display:grid; grid-template-columns:repeat(6,1fr); gap:14px; }
.cm-scn { border:1px solid var(--line); border-radius:var(--r-card); background:#fff; padding:16px;
  text-align:center; cursor:pointer; transition:.15s; }
.cm-scn:hover { background:var(--mint-50); border-color:var(--green-500); }
.cm-scn.active { background:linear-gradient(155deg,#11422F,#0A2E22); border-color:rgba(212,169,93,.3); }
.cm-scn .s-ic { width:44px; height:44px; border-radius:13px; margin:0 auto 10px; display:flex; align-items:center; justify-content:center;
  background:var(--mint-100); color:var(--green-600); }
.cm-scn.active .s-ic { background:rgba(212,169,93,.16); color:var(--gold); }
.cm-scn .s-name { font-size:13px; font-weight:800; color:var(--ink-900); }
.cm-scn.active .s-name { color:#FBFAF6; }
@media (max-width:1280px){ .cm-scenarios { grid-template-columns:repeat(3,1fr); } }
@media (max-width:620px){ .cm-scenarios { grid-template-columns:1fr 1fr; } }

/* ---------------- Family member rows ---------------- */
.cm-member { display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid var(--line); }
.cm-member:last-child { border-bottom:0; }
.cm-member-av { width:42px; height:42px; flex:0 0 42px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:14px; color:#fff; }
.cm-member-body { flex:1; min-width:0; }
.cm-member-name { font-size:14px; font-weight:800; color:var(--ink-900); }
.cm-member-role { font-size:12px; font-weight:600; color:var(--ink-400); margin-top:1px; }

/* role permission pills */
.cm-roletag { font-size:10.5px; font-weight:800; padding:3px 9px; border-radius:999px; letter-spacing:.02em; }

/* workspace tiles */
.cm-ws { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.cm-ws-tile { display:flex; align-items:center; gap:11px; padding:14px; border:1px solid var(--line);
  border-radius:var(--r-ctrl); background:#fff; cursor:pointer; transition:.15s; }
.cm-ws-tile:hover { background:var(--mint-50); border-color:var(--green-500); }
.cm-ws-tile .w-ic { width:36px; height:36px; flex:0 0 36px; border-radius:10px; display:flex; align-items:center; justify-content:center; }
.cm-ws-tile .w-name { font-size:13px; font-weight:800; color:var(--ink-900); }
.cm-ws-tile .w-sub { font-size:11px; font-weight:500; color:var(--ink-400); margin-top:1px; }

/* document folder chips */
.cm-folders { display:grid; grid-template-columns:repeat(5,1fr); gap:12px; margin-bottom:18px; }
.cm-folder { border:1px solid var(--line); border-radius:var(--r-ctrl); padding:14px; cursor:pointer; transition:.15s; }
.cm-folder:hover { background:var(--mint-50); border-color:var(--green-500); }
.cm-folder .f-ic { color:var(--gold); margin-bottom:9px; display:flex; }
.cm-folder .f-name { font-size:13px; font-weight:800; color:var(--ink-900); }
.cm-folder .f-count { font-size:11px; font-weight:600; color:var(--ink-400); margin-top:2px; }
@media (max-width:1100px){ .cm-folders { grid-template-columns:repeat(3,1fr); } }
@media (max-width:600px){ .cm-folders { grid-template-columns:1fr 1fr; } }

/* checklist tasks */
.cm-task { display:flex; align-items:flex-start; gap:11px; padding:12px 0; border-bottom:1px solid var(--line); }
.cm-task:last-child { border-bottom:0; }
.cm-task .box { width:20px; height:20px; flex:0 0 20px; border-radius:6px; border:2px solid var(--line); margin-top:1px;
  display:flex; align-items:center; justify-content:center; cursor:pointer; color:transparent; }
.cm-task.done .box { background:var(--green-500); border-color:var(--green-500); color:#fff; }
.cm-task-body { flex:1; min-width:0; }
.cm-task-title { font-size:13.5px; font-weight:700; color:var(--ink-900); }
.cm-task.done .cm-task-title { text-decoration:line-through; color:var(--ink-400); }
.cm-task-sub { font-size:11.5px; font-weight:600; color:var(--ink-400); margin-top:2px; }

/* announcement cards */
.cm-ann { border:1px solid var(--line); border-radius:var(--r-ctrl); padding:14px; margin-bottom:12px; }
.cm-ann:last-child { margin-bottom:0; }
.cm-ann.feat { background:linear-gradient(180deg,#F4FBF8,#EAF7F1); border-color:var(--mint-100); }
.cm-ann .a-title { font-size:13.5px; font-weight:800; color:var(--ink-900); display:flex; align-items:center; gap:7px; }
.cm-ann .a-body { font-size:12.5px; font-weight:500; color:var(--ink-600,var(--ink-500)); margin-top:5px; line-height:1.45; }
.cm-ann .a-meta { font-size:11px; font-weight:600; color:var(--ink-400); margin-top:8px; }

/* goal progress row (vault) */
.cm-goalrow { display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px solid var(--line); }
.cm-goalrow:last-child { border-bottom:0; }
.cm-goalrow .g-ic { width:36px; height:36px; flex:0 0 36px; border-radius:10px; display:flex; align-items:center; justify-content:center; }
.cm-goalrow .g-main { flex:1; min-width:0; }
.cm-goalrow .g-top { display:flex; align-items:baseline; justify-content:space-between; gap:8px; margin-bottom:5px; }
.cm-goalrow .g-name { font-size:13px; font-weight:800; color:var(--ink-900); }
.cm-goalrow .g-fig { font-size:11.5px; font-weight:700; color:var(--ink-400); }

/* report library cards */
.cm-replib { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
.cm-repcard { border:1px solid var(--line); border-radius:var(--r-card); padding:16px; cursor:pointer; transition:.15s;
  position:relative; background:#fff; }
.cm-repcard:hover { border-color:var(--green-500); box-shadow:var(--shadow-card); transform:translateY(-2px); }
.cm-repcard .rc-ic { width:46px; height:46px; border-radius:13px; display:flex; align-items:center; justify-content:center; margin-bottom:14px; }
.cm-repcard .rc-name { font-size:13.5px; font-weight:800; color:var(--ink-900); }
.cm-repcard .rc-when { font-size:11px; font-weight:600; color:var(--ink-400); margin-top:3px; }
.cm-repcard .rc-star { position:absolute; top:14px; right:14px; color:var(--gold); }
.cm-repcard.dashed { border-style:dashed; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; color:var(--green-600); min-height:150px; }
@media (max-width:1280px){ .cm-replib { grid-template-columns:repeat(3,1fr); } }
@media (max-width:680px){ .cm-replib { grid-template-columns:1fr 1fr; } }

/* template chips */
.cm-tmpls { display:grid; grid-template-columns:1fr 1fr 1fr; gap:9px; }
.cm-tmpl { display:inline-flex; align-items:center; gap:7px; border:1px solid var(--line); border-radius:var(--r-ctrl);
  padding:9px 12px; font-size:12px; font-weight:700; color:var(--ink-700); background:#fff; cursor:pointer; }
.cm-tmpl:hover { background:var(--mint-50); border-color:var(--green-500); color:var(--green-600); }

/* numbered steps */
.cm-step { display:flex; gap:12px; padding:9px 0; }
.cm-step .n { width:24px; height:24px; flex:0 0 24px; border-radius:50%; background:var(--mint-100); color:var(--green-600);
  font-size:12px; font-weight:800; display:flex; align-items:center; justify-content:center; }
.cm-step .s-name { font-size:13px; font-weight:800; color:var(--ink-900); }
.cm-step .s-sub { font-size:11.5px; font-weight:500; color:var(--ink-400); margin-top:2px; }

/* generic section eyebrow head (reuse an-sec but lightweight) */
.cm-sechead { display:flex; align-items:flex-end; justify-content:space-between; gap:14px; margin:28px 0 14px; flex-wrap:wrap; }
.cm-sechead h2 { font-family:var(--font-serif); font-size:22px; font-weight:600; color:var(--ink-900); margin:0; letter-spacing:0; }
.cm-sechead .eyebrow { font-size:11.5px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); margin-bottom:3px; }
.cm-sechead .link { font-size:12.5px; font-weight:800; color:var(--green-600); cursor:pointer; display:inline-flex; align-items:center; gap:5px; }

/* bottom ask banner */
.cm-askbanner { display:flex; align-items:center; gap:16px; background:linear-gradient(120deg,#0D3B2E,#11422F);
  border:1px solid rgba(212,169,93,.24); border-radius:var(--r-card); padding:18px 22px; margin-top:20px; position:relative; overflow:hidden; }
.cm-askbanner .robot { width:62px; height:62px; flex:0 0 62px; }
.cm-askbanner .ab-tx { flex:0 0 auto; max-width:280px; }
.cm-askbanner .ab-tx .t { font-family:var(--font-serif); color:var(--gold); font-size:17px; font-weight:600; }
.cm-askbanner .ab-tx .s { color:rgba(234,240,234,.74); font-size:12.5px; margin-top:3px; }
.cm-askbanner .ab-in { flex:1; display:flex; align-items:center; gap:10px; background:rgba(255,255,255,.10);
  border:1px solid rgba(212,169,93,.26); border-radius:12px; padding:8px 8px 8px 16px; }
.cm-askbanner .ab-in input { flex:1; border:0; outline:0; background:transparent; color:#F4F8F2; font-family:inherit; font-size:13.5px; }
.cm-askbanner .ab-in input::placeholder { color:rgba(234,240,234,.55); }
.cm-askbanner .ab-in .send { width:38px; height:38px; flex:0 0 38px; border-radius:10px; border:0; background:var(--gold); color:#3A2E12;
  display:flex; align-items:center; justify-content:center; cursor:pointer; }
@media (max-width:900px){ .cm-askbanner { flex-wrap:wrap; } .cm-askbanner .ab-in { width:100%; flex:1 1 100%; } }

/* feature strip (bottom of vault) */
.cm-featstrip { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:20px; }
.cm-feat { display:flex; gap:13px; align-items:flex-start; }
.cm-feat .fi { width:40px; height:40px; flex:0 0 40px; border-radius:12px; background:var(--mint-100); color:var(--green-600);
  display:flex; align-items:center; justify-content:center; }
.cm-feat .ft { font-size:13.5px; font-weight:800; color:var(--ink-900); }
.cm-feat .fs { font-size:12px; font-weight:500; color:var(--ink-400); margin-top:3px; line-height:1.4; }
@media (max-width:900px){ .cm-featstrip { grid-template-columns:1fr 1fr; } }

/* 3-col helper */
.cm-grid-3a { display:grid; grid-template-columns:1fr 1fr 1fr; gap:20px; }
.cm-grid-2c { display:grid; grid-template-columns:1.3fr 1fr; gap:20px; }
@media (max-width:1180px){ .cm-grid-3a, .cm-grid-2c { grid-template-columns:1fr; } }

/* responsive KPI strips (independent of an-exec media queries) */
.cm-kpi8 { display:grid; grid-template-columns:repeat(8,1fr); gap:14px; }
@media (max-width:1480px){ .cm-kpi8 { grid-template-columns:repeat(4,1fr); } }
@media (max-width:820px){ .cm-kpi8 { grid-template-columns:repeat(2,1fr); } }
.cm-kpi5 { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
@media (max-width:1280px){ .cm-kpi5 { grid-template-columns:repeat(3,1fr); } }
@media (max-width:680px){ .cm-kpi5 { grid-template-columns:repeat(2,1fr); } }
.cm-kpi4 { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
@media (max-width:1080px){ .cm-kpi4 { grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .cm-kpi4 { grid-template-columns:1fr; } }

/* vault hero 3-col */
.cm-hero3 { display:grid; grid-template-columns:auto 1fr auto; gap:24px; align-items:center; }
@media (max-width:1180px){ .cm-hero3 { grid-template-columns:1fr; justify-items:center; } }
.cm-hero3 .vh-score { text-align:center; background:#fff; border:1px solid var(--line); border-radius:16px; padding:16px 24px; box-shadow:var(--shadow-card); }
@media (max-width:1180px){ .cm-hero3 > .cm-robot { display:none; } }
/* estate 2-col */
.cm-estate { display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:center; }
@media (max-width:1100px){ .cm-estate { grid-template-columns:1fr; } .cm-estate .est-grid { grid-template-columns:1fr!important; } }
