/* Floom standalone share pages — v3.
   TRUE STANDALONE PAGE, not a card on a page.
   NO outer card wrapper, NO borders, NO shadows. Content flows directly on the
   cool bg with generous air; blocks separated by HAIRLINE dividers only.
   Confident hero hierarchy carried by size + weight, not uppercase labels.
   Cool bg #FBFBFC, ink #16171A, muted #6B7280, accent #3E6FE0 (links only),
   near-black buttons. Squircle radii. No emoji, no em-dash. */
:root{
  --bg:#FBFBFC;
  --bg-2:#F4F5F7;
  --bg-3:#ECEDF0;
  --card:#FFFFFF;
  --ink:#16171A;
  --ink-soft:#3B3D44;
  --muted:#6B7280;
  --faint:#9CA0A8;
  --hair:rgba(16,17,20,.07);
  --hair-2:rgba(16,17,20,.045);
  --accent:#3E6FE0;
  --primary:#16171A;
  --primary-text:#FFFFFF;
  --ok:#1F8F57; --okbg:#EAF5EF;
  --warn:#9A6B18; --warnbg:#FBF2E0;
  --bad:#C2392F; --badbg:#FBEAE8;
  --r-btn:10px;
  --r-squircle:9px;
  --r-pill:999px;
  --r-tile:11px;
  --maxw:680px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font:15px/1.55 "Geist Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.mono{font-family:"Geist Mono","SF Mono",ui-monospace,SFMono-Regular,Menlo,monospace}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- top bar: shared-by (left) + Floom (right) ---- */
.topbar{
  max-width:var(--maxw);margin:0 auto;padding:30px 28px 0;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.sharedby{display:flex;align-items:center;gap:11px;min-width:0}
.sharedby .photo{
  width:32px;height:32px;border-radius:50%;flex:none;object-fit:cover;
  background:#E3E6EB
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'><circle cx='16' cy='12.5' r='5' fill='%23AEB4BF'/><path d='M6 27c0-5.5 4.5-9 10-9s10 3.5 10 9z' fill='%23AEB4BF'/></svg>")
    center/cover no-repeat;
}
.sharedby .txt{font-size:13.5px;color:var(--ink-soft);line-height:1.4;min-width:0}
.sharedby .txt b{color:var(--ink);font-weight:600}
.sharedby .txt .sub{color:var(--faint);font-size:12px}
.fl{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:13.5px;color:var(--ink);letter-spacing:-.01em;flex:none}
.fl-glyph{
  width:19px;height:19px;border-radius:6px;background:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;position:relative;flex:none;
}
.fl-glyph::after{
  content:"";width:0;height:0;
  border-left:6.5px solid #fff;border-top:4px solid transparent;border-bottom:4px solid transparent;
  margin-left:1.5px;
}

/* ---- page: content flows directly on bg, NO surface card ---- */
.page{max-width:var(--maxw);margin:0 auto;padding:0 28px 96px}

/* hairline section separators between blocks */
.rule{border:0;border-top:1px solid var(--hair);margin:0}

/* vertical rhythm between blocks */
.block{padding:30px 0}
.block:first-of-type{padding-top:38px}

/* ---- typography ---- */
.eyebrow{font-size:11.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin:0 0 12px}
h1.title{font-size:34px;line-height:1.12;letter-spacing:-.025em;font-weight:680;margin:0;color:var(--ink)}
.lead{font-size:16.5px;line-height:1.6;color:var(--ink-soft);margin:14px 0 0;max-width:600px}
.section-h{font-size:13.5px;font-weight:600;color:var(--ink);margin:0 0 14px;letter-spacing:-.005em}
.meta{font-size:13px;color:var(--muted)}
.metarow{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink-soft);margin-top:18px}
.metarow svg{flex:none;color:var(--faint)}
.metarow .dotsep{color:var(--faint);margin:0 2px}

/* ---- confident action row (no gray box) ---- */
.cta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.cta-line{font-size:13px;color:var(--muted);margin:14px 0 0}
.cta-line a{font-weight:500}
@media (max-width:540px){
  .cta{align-items:stretch}
  .cta .btn{flex:1}
}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  height:42px;padding:0 18px;border-radius:var(--r-btn);
  font-size:14px;font-weight:500;cursor:pointer;border:0;
  font-family:inherit;white-space:nowrap;letter-spacing:-.005em;
}
.btn-primary{background:var(--primary);color:var(--primary-text)}
.btn-secondary{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1px var(--hair)}
.btn-bad{background:transparent;color:var(--bad);box-shadow:inset 0 0 0 1px var(--hair)}
.btn svg{flex:none}

/* ---- bullet list (what it does) ---- */
.bullets{margin:0;padding:0;list-style:none}
.bullets li{
  position:relative;padding-left:24px;margin:0 0 12px;
  font-size:15px;line-height:1.55;color:var(--ink-soft);
}
.bullets li:last-child{margin-bottom:0}
.bullets li::before{
  content:"";position:absolute;left:4px;top:9px;width:5px;height:5px;border-radius:50%;
  background:var(--faint);
}

/* ---- tool chips: bare, no fill, no border ---- */
.tools{display:flex;flex-wrap:wrap;gap:18px}
.tool{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink-soft)}
.tool img{width:16px;height:16px;display:block;flex:none}

/* ---- status pills ---- */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 11px;border-radius:var(--r-pill)}
.pill .dot{width:6px;height:6px;border-radius:999px}
.pill.ok{color:var(--ok);background:var(--okbg)}
.pill.ok .dot{background:var(--ok)}
.pill.warn{color:var(--warn);background:var(--warnbg)}
.pill.warn .dot{background:var(--warn)}
.pill.neutral{color:var(--muted);background:var(--bg-2)}
.pill.neutral .dot{background:var(--faint)}

/* ---- output hero (run page): dominant, lightly inset, no border ---- */
.output{font-size:15px;line-height:1.68;color:var(--ink)}
.output h3{font-size:20px;line-height:1.25;letter-spacing:-.015em;margin:0 0 12px;font-weight:650;color:var(--ink)}
.output p{margin:0 0 13px}
.output ul{margin:0 0 13px;padding:0;list-style:none}
.output li{position:relative;padding-left:22px;margin:7px 0;color:var(--ink-soft)}
.output li::before{content:"";position:absolute;left:3px;top:11px;width:5px;height:5px;border-radius:50%;background:var(--faint)}
.output li b{color:var(--ink);font-weight:600}
.output > :last-child{margin-bottom:0}

/* ---- lightened tables: NO filled header, hairline rows, generous height ---- */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{
  text-align:left;padding:0 16px 12px 0;font-size:11.5px;text-transform:uppercase;
  letter-spacing:.04em;color:var(--faint);font-weight:600;border-bottom:1px solid var(--hair);
}
.tbl td{text-align:left;padding:15px 16px 15px 0;border-bottom:1px solid var(--hair-2);vertical-align:top;color:var(--ink-soft)}
.tbl tr:last-child td{border-bottom:0}
.tbl td b{color:var(--ink);font-weight:600}
.tbl td.num{color:var(--faint);font-variant-numeric:tabular-nums;width:24px}
.tbl td.fit{color:var(--ink);font-weight:500;white-space:nowrap;text-align:right;width:64px}
.tbl th.fit{text-align:right}

/* ---- key-value list ---- */
.kv{display:grid;grid-template-columns:130px 1fr;gap:13px 20px;font-size:14.5px}
.kv dt{color:var(--muted)}
.kv dd{margin:0;color:var(--ink)}

/* ============ FORMAT-AWARE FILE / ARTIFACT RENDERER ============
   The rendered file (and the run output) is a distinct ARTIFACT, not page chrome.
   It gets its own differentiated surface that steps OFF the page bg (#FBFBFC):
     - documents (md, csv, pdf, office, unknown) -> pure white #FFFFFF
     - images                                    -> soft neutral mat (--bg-2 #F4F5F7)
     - code / json / yaml                        -> faintly tinted mono surface (--mono-surface)
   Still FLAT: no border, no drop shadow. A single hairline ring (inset box-shadow)
   keeps it on-system while making the surface edge legible. Squircle radii.
   The kind is switched by data-kind on .artifact; the document bar (.filehead)
   sits inside the surface as a quiet header. Unknown kind degrades to the
   file-chip fallback (.filechip), never an empty/broken box. */

:root{ --mono-surface:#FAFAF7; --mat:#F4F5F7; }

/* the differentiated artifact surface */
.artifact{
  background:var(--card);                 /* default = white document surface */
  border-radius:14px;
  box-shadow:inset 0 0 0 1px var(--hair); /* single hairline ring, FLAT (not a shadow) */
  padding:26px 28px;
  overflow:hidden;
}
.artifact[data-kind="image"]{ background:var(--mat); }       /* neutral mat so transparency reads */
.artifact[data-kind="code"],
.artifact[data-kind="json"],
.artifact[data-kind="yaml"]{ background:var(--mono-surface); }
@media (max-width:540px){ .artifact{padding:20px 18px} }

/* quiet document bar at the top of the surface */
.filehead{display:flex;align-items:center;gap:13px;margin:0 0 20px;padding-bottom:16px;border-bottom:1px solid var(--hair-2)}
.fileicon{width:38px;height:38px;border-radius:var(--r-squircle);background:var(--bg-2);display:flex;align-items:center;justify-content:center;flex:none;color:var(--muted)}
.filename{font-size:13.5px;font-weight:600;color:var(--ink)}
.filehead .ro{margin-left:auto;font-size:12px;color:var(--faint);flex:none}
.langtag{margin-left:auto;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);background:var(--bg-2);border-radius:var(--r-pill);padding:3px 9px;flex:none}

/* ---- kind: markdown / rich text ---- */
.filerender h3{font-size:19px;line-height:1.25;letter-spacing:-.015em;margin:0 0 11px;font-weight:650}
.filerender p{margin:0 0 14px;color:var(--ink-soft);font-size:15px;line-height:1.6}
.filerender ul{margin:0 0 14px;padding:0;list-style:none}
.filerender li{position:relative;padding-left:22px;margin:7px 0;color:var(--ink-soft)}
.filerender li::before{content:"";position:absolute;left:3px;top:11px;width:5px;height:5px;border-radius:50%;background:var(--faint)}
.filerender > :last-child{margin-bottom:0}

/* ---- kind: csv / tabular data ---- */
.datacap{font-size:12px;color:var(--faint);margin:0 0 12px;font-variant-numeric:tabular-nums}
.datascroll{overflow-x:auto;margin:0 -2px}
.datatbl{border-collapse:collapse;font-size:13px;width:100%;min-width:560px}
.datatbl th{
  text-align:left;padding:0 18px 11px 0;font-size:11px;text-transform:uppercase;
  letter-spacing:.04em;color:var(--faint);font-weight:600;border-bottom:1px solid var(--hair);white-space:nowrap;
}
.datatbl td{padding:11px 18px 11px 0;border-bottom:1px solid var(--hair-2);color:var(--ink-soft);white-space:nowrap;vertical-align:top}
.datatbl tr:last-child td{border-bottom:0}
.datatbl td b{color:var(--ink);font-weight:600}
.datatbl .n{font-family:"Geist Mono",ui-monospace,monospace;font-variant-numeric:tabular-nums;color:var(--ink);text-align:right}
.datatbl th.n{text-align:right}

/* ---- kind: image (chart / png / jpg / svg) on a mat ---- */
.imgmat{display:flex;align-items:center;justify-content:center;padding:18px 14px}
.imgmat svg,.imgmat img{max-width:100%;height:auto;display:block;border-radius:8px;background:var(--card)}
.imgcap{font-size:12px;color:var(--faint);margin:14px 0 0;text-align:center;font-variant-numeric:tabular-nums}

/* ---- kind: code / json / yaml (DESIGNED, not shown in 3-file demo) ---- */
.codeblock{font-family:"Geist Mono",ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;line-height:1.7;color:var(--ink-soft);margin:0;white-space:pre;overflow-x:auto}
.codeblock .ln{color:var(--faint);display:inline-block;width:28px;-webkit-user-select:none;user-select:none}
.codeblock .kw{color:var(--ink);font-weight:600}

/* ---- kind: pdf / office doc -> page-like preview (DESIGNED, not shown in demo) ---- */
.docpreview{display:flex;align-items:center;gap:16px}
.docpage{width:96px;height:124px;border-radius:6px;background:var(--card);box-shadow:inset 0 0 0 1px var(--hair);flex:none;padding:11px 9px;overflow:hidden}
.docpage .l{height:5px;border-radius:3px;background:var(--bg-3);margin:0 0 6px}
.docpage .l.short{width:60%}
.docpreview .docmeta .fn{font-size:14px;font-weight:600;color:var(--ink)}
.docpreview .docmeta .pp{font-size:12.5px;color:var(--muted);margin:4px 0 12px}

/* ---- kind: unknown / binary -> clean file chip fallback (DESIGNED + default degrade) ---- */
.filechip{display:flex;align-items:center;gap:13px}
.filechip .ci{width:40px;height:40px;border-radius:var(--r-squircle);background:var(--bg-2);display:flex;align-items:center;justify-content:center;color:var(--muted);flex:none}
.filechip .cn{font-size:14px;font-weight:600;color:var(--ink)}
.filechip .cs{font-size:12.5px;color:var(--muted);margin-top:2px}
.filechip .dl{margin-left:auto;flex:none}

/* ---- footnote ---- */
.footnote{margin-top:34px;padding-top:22px;border-top:1px solid var(--hair);font-size:12.5px;color:var(--faint);line-height:1.6}
.footnote b{color:var(--muted);font-weight:500}

/* ---- multi-item pager: minimal, on the bg ---- */
.pager{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:20px 0 0;
}
.pager .where{font-size:13px;color:var(--ink);font-weight:600}
.pager .where .of{color:var(--faint);font-weight:500}
.pager .right{display:flex;align-items:center;gap:14px}
.pager .dots{display:flex;align-items:center;gap:6px}
.pager .dots i{width:6px;height:6px;border-radius:999px;background:var(--bg-3);display:block}
.pager .dots i.on{background:var(--ink)}
.pager .nav{display:flex;align-items:center;gap:8px}
.pgbtn{
  width:30px;height:30px;border-radius:8px;border:0;cursor:pointer;
  background:transparent;color:var(--ink-soft);box-shadow:inset 0 0 0 1px var(--hair);
  display:flex;align-items:center;justify-content:center;
}
.pgbtn:disabled{color:var(--faint);box-shadow:inset 0 0 0 1px var(--hair-2);cursor:default}

/* ---- approval: input-left two column ---- */
.approve-grid{display:grid;grid-template-columns:288px 1fr;gap:44px;align-items:start}
@media (max-width:680px){.approve-grid{grid-template-columns:1fr;gap:34px}.approve-grid > .col-left{order:2}}
.commentbox{
  background:var(--card);border-radius:var(--r-tile);box-shadow:inset 0 0 0 1px var(--hair);
  padding:13px 15px;font-size:14px;color:var(--ink);
  min-height:108px;line-height:1.55;
}
.commentbox .ph{color:var(--faint)}
.react-row{display:flex;align-items:center;gap:8px;margin:13px 0}
.react{
  width:36px;height:32px;border-radius:9px;background:transparent;box-shadow:inset 0 0 0 1px var(--hair);
  display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-soft);
}
.upload{
  display:flex;align-items:center;gap:9px;
  font-size:13px;color:var(--muted);cursor:pointer;margin-top:2px;
}
.upload svg{color:var(--faint);flex:none}
.decide{display:flex;gap:10px;margin-top:18px}
.decide .btn{flex:1}

/* ---- approval right: email-ish proposed output, no inset box ---- */
.proposed .addr{font-size:13.5px;color:var(--muted);margin:0 0 14px;padding-bottom:14px;border-bottom:1px solid var(--hair)}
.proposed .addr b{color:var(--ink);font-weight:600}
.proposed .body{font-size:14.5px;line-height:1.62;color:var(--ink-soft)}
.proposed .body p{margin:0 0 12px}
.proposed .body > :last-child{margin-bottom:0}

/* ============ SHARE MODAL (sender side — keeps a real dialog frame) ============ */
.modal-stage{
  background:radial-gradient(120% 90% at 50% 0%, #F0F1F4 0%, var(--bg-2) 62%, var(--bg-2) 100%);
  border-radius:16px;
  padding:46px 24px;
  display:flex;align-items:flex-start;justify-content:center;
  margin-top:30px;
}
.modal{
  width:100%;max-width:448px;background:var(--card);
  border-radius:16px;overflow:hidden;
  box-shadow:0 1px 1px rgba(16,17,20,.04),0 12px 40px -8px rgba(16,17,20,.14);
}
.modal-head{padding:20px 22px 0}
.modal-head h3{font-size:18px;font-weight:650;margin:0;letter-spacing:-.02em;color:var(--ink)}
.modal-head .x{position:absolute;top:18px;right:18px;width:28px;height:28px;border-radius:8px;background:var(--bg-2);display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer}
.modal-sub{padding:0 22px;font-size:13px;color:var(--muted);margin:5px 0 16px}
.modal-body{position:relative}
.access-list{padding:0 22px}
.access-row{display:flex;align-items:center;gap:12px;padding:11px 0}
.access-row + .access-row{border-top:1px solid var(--hair-2)}
.access-row .ava{width:32px;height:32px;border-radius:50%;flex:none;background:#E3E6EB
  url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'><circle cx='16' cy='12.5' r='5' fill='%23AEB4BF'/><path d='M6 27c0-5.5 4.5-9 10-9s10 3.5 10 9z' fill='%23AEB4BF'/></svg>")
  center/cover no-repeat}
.access-row .nm{font-size:14px;color:var(--ink);font-weight:500;line-height:1.3}
.access-row .em{font-size:12px;color:var(--faint)}
.access-row .role{margin-left:auto;font-size:13px;color:var(--muted)}
.toggle-block{margin:14px 22px 0;padding-top:16px;border-top:1px solid var(--hair)}
.toggle-row{display:flex;align-items:center;gap:13px}
.toggle-row .ico{width:34px;height:34px;border-radius:10px;background:var(--bg-2);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);flex:none}
.toggle-row .txt{min-width:0;flex:1}
.toggle-row .txt .t{font-size:14px;font-weight:600;color:var(--ink);line-height:1.3}
.toggle-row .txt .d{font-size:12px;color:var(--muted);margin-top:2px}
.switch{width:42px;height:25px;border-radius:999px;background:var(--ink);position:relative;flex:none;cursor:pointer}
.switch::after{content:"";position:absolute;top:3px;left:20px;width:19px;height:19px;border-radius:50%;background:#fff;transition:left .15s}
.switch.off{background:var(--bg-3)}
.switch.off::after{left:3px}
.linkbar{display:flex;align-items:center;gap:8px;margin-top:14px;background:var(--bg-2);border-radius:10px;padding:7px 7px 7px 13px}
.linkbar .url{font-size:12.5px;color:var(--ink-soft);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.linkbar .copy{height:32px;padding:0 14px;border-radius:8px;border:0;background:var(--ink);color:#fff;font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;flex:none;font-family:inherit}
.modal-foot{display:flex;align-items:flex-start;gap:9px;padding:18px 22px 22px;font-size:12px;color:var(--muted);line-height:1.5}
.modal-foot svg{color:var(--faint);flex:none;margin-top:1px}
