:root {
  --ffcp-charcoal: #333138;
  --ffcp-teal: #258ea6;
  --ffcp-coral: #e28665;
  --ffcp-light: #e6e7e8;
  --ffcp-white: #ffffff;
  --ffcp-border: #d7d8da;
  --ffcp-text: #333138;
  --ffcp-muted: #66616e;
  --ffcp-soft: #f6f7f8;
  --ffcp-accent: #258ea6;
  --ffcp-accent-2: #e28665;
  --ffcp-accent-soft: rgba(37,142,166,.14);
}
body.ffcp-portal-template {
  background: var(--ffcp-charcoal);
}
body.ffcp-portal-template #wpadminbar { position: fixed; }
body.ffcp-portal-template .ffcp-template-shell {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 28px;
  box-sizing: border-box;
}
body.ffcp-portal-template.admin-bar .ffcp-template-shell { padding-top: calc(28px + 32px); }
body.ffcp-portal-template .site,
body.ffcp-portal-template .site-content,
body.ffcp-portal-template .content,
body.ffcp-portal-template .content-area,
body.ffcp-portal-template .entry-content,
body.ffcp-portal-template .post,
body.ffcp-portal-template .page,
body.ffcp-portal-template article,
body.ffcp-portal-template main,
body.ffcp-portal-template .container,
body.ffcp-portal-template .wp-site-blocks,
body.ffcp-portal-template .is-layout-constrained,
body.ffcp-portal-template .alignwide,
body.ffcp-portal-template .alignfull,
body.ffcp-portal-template .row,
body.ffcp-portal-template [class*="container"] {
  max-width: none !important;
  width: 100% !important;
}
body.ffcp-portal-template .entry-content,
body.ffcp-portal-template .post,
body.ffcp-portal-template .page,
body.ffcp-portal-template article,
body.ffcp-portal-template main,
body.ffcp-portal-template .content-area,
body.ffcp-portal-template .site-content {
  margin: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.ffcp-layout {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 28px;
  width: 100%;
  max-width: 1600px;
  margin: 0 auto;
  color: var(--ffcp-text);
}
.ffcp-sidebar {
  background: linear-gradient(180deg, #292731 0%, #333138 100%);
  color: var(--ffcp-white);
  border-radius: 28px;
  padding: 22px 18px;
  box-shadow: 0 18px 42px rgba(0,0,0,.18);
  position: sticky;
  top: 24px;
  min-height: calc(100vh - 56px);
  display: flex;
  flex-direction: column;
}
.ffcp-main-logo { max-width: 100%; height: auto; display:block; }
.ffcp-brand-text { color:#fff; font-size:1.6rem; font-weight:800; }
.ffcp-nav { display:grid; gap:10px; margin-top: 24px; }
.ffcp-nav-link {
  display:flex; align-items:center; gap:12px; color:var(--ffcp-light); text-decoration:none;
  border-radius:14px; padding:14px 16px; font-weight:700; background:transparent;
  border:1px solid rgba(255,255,255,.07); transition:.2s ease;
}
.ffcp-nav-link:hover, .ffcp-nav-link:focus, .ffcp-nav-link.is-active {
  background: var(--ffcp-accent); color:#fff; transform: translateY(-1px);
}
.ffcp-sidebar-footer { margin-top:auto; padding-top:22px; border-top:1px solid rgba(230,231,232,.18); }
.ffcp-sidebar-footer strong { display:block; color:#fff; margin-bottom:8px; }
.ffcp-sidebar-footer p { margin:0 0 12px; color:rgba(230,231,232,.92); }
.ffcp-mini-brand img { width:42px; height:42px; object-fit:contain; }
.ffcp-main { min-width:0; }
.ffcp-wrap { display:grid; gap:24px; }
.ffcp-hero-card, .ffcp-card {
  border:1px solid var(--ffcp-border);
  border-radius:28px;
  padding:28px;
  background:#fff;
  box-shadow: 0 10px 28px rgba(0,0,0,.05);
  color: var(--ffcp-text);
}
.ffcp-hero-card {
  margin-bottom:24px; display:flex; align-items:center; justify-content:space-between; gap:24px; min-height:152px;
}
.ffcp-hero-left { display:flex; align-items:center; gap:18px; min-width:0; }
.ffcp-hero-icon { width:84px; height:84px; min-width:84px; border-radius:999px; background:#eef7f9; border:1px solid var(--ffcp-border); display:inline-flex; align-items:center; justify-content:center; overflow:hidden; }
.ffcp-hero-icon img { max-width:74%; height:auto; }
.ffcp-hero-icon-fallback .dashicons, .ffcp-section-icon .dashicons { color: var(--ffcp-accent); }
.ffcp-hero-card h1, .ffcp-card h2, .ffcp-product-card h3, .ffcp-file-title, .ffcp-meta-grid dt, .ffcp-meta-grid dd { color: var(--ffcp-charcoal); }
.ffcp-hero-card h1 { margin:0 0 8px; font-size: clamp(2rem, 3vw, 3rem); line-height:1.05; }
.ffcp-hero-card p, .ffcp-card p, .ffcp-content, .ffcp-files, .ffcp-price, .ffcp-product-desc, .ffcp-file-meta, .ffcp-subtle, .ffcp-activity-meta span { color: var(--ffcp-muted); }
.ffcp-project-summary { margin-bottom: 18px; max-width: 76ch; font-size: 1.02rem; line-height: 1.65; }
.ffcp-card-heading, .ffcp-card-heading-main { display:flex; gap:14px; align-items:flex-start; }
.ffcp-card-heading { margin-bottom:20px; }
.ffcp-card-heading-split { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.ffcp-section-icon { width:48px; height:48px; border-radius:999px; background:#f4f7f8; border:1px solid var(--ffcp-border); display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; }
.ffcp-overview-grid { display:grid; grid-template-columns:minmax(420px,1.2fr) minmax(320px,.9fr); gap:24px; align-items:stretch; }
.ffcp-meta-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(160px,1fr)); gap:16px; margin-top:22px; }
.ffcp-meta-grid div { background:var(--ffcp-soft); border:1px solid var(--ffcp-border); border-radius:16px; padding:16px; min-height:86px; align-content:start; }
.ffcp-meta-grid dt { font-size:.92rem; font-weight:700; margin-bottom:6px; }
.ffcp-meta-grid dd { margin:0; font-size:1.05rem; line-height:1.45; word-break:break-word; }
.ffcp-status-pill { display:inline-block; background:var(--ffcp-accent-soft); color:var(--ffcp-accent); border-radius:999px; padding:7px 13px; font-size:.92rem; font-weight:800; }
.ffcp-banner-wrap { border-radius:22px; overflow:hidden; min-height:260px; background:var(--ffcp-soft); border:1px solid var(--ffcp-border); }
.ffcp-banner-image { width:100%; height:100%; min-height:260px; object-fit:cover; display:block; }
.ffcp-grid { display:grid; gap:16px; }
.ffcp-product-card {
  border:1px solid var(--ffcp-border); border-radius:20px; padding:18px; background:#fafafa;
  display:grid; grid-template-columns: 140px minmax(0,1fr) auto; gap:18px; align-items:center;
}
.ffcp-product-action { display:flex; flex-direction:column; gap:10px; align-items:stretch; }
.ffcp-product-action .ffcp-button, .ffcp-product-action .ffcp-outline-button { white-space:nowrap; padding:14px 18px; }
.ffcp-product-details { background:#fff; }
.ffcp-product-media { width:140px; height:140px; border-radius:18px; overflow:hidden; background:#f1f2f3; display:flex; align-items:center; justify-content:center; }
.ffcp-product-media img { width:100%; height:100%; object-fit:cover; }
.ffcp-product-placeholder { font-size:42px; width:42px; height:42px; color:#b2b5ba; }
.ffcp-product-card h3 { margin:0 0 8px; font-size:2rem; }
.ffcp-product-desc { margin:0 0 10px; font-size:1.05rem; }
.ffcp-price { font-size:1.8rem; font-weight:800; color:var(--ffcp-accent); }
.ffcp-price ins, .ffcp-price bdi, .ffcp-price .amount { color:var(--ffcp-accent) !important; }
.ffcp-price del { opacity:.65; margin-right:8px; }
.ffcp-button, .ffcp-outline-button {
  display:inline-flex; align-items:center; justify-content:center; gap:10px; border-radius:14px; padding:16px 22px;
  font-weight:800; text-decoration:none; transition:.2s ease; cursor:pointer; border:none; font-size:1rem;
}
.ffcp-button { background:var(--ffcp-accent); color:#fff; }
.ffcp-button:hover, .ffcp-button:focus { filter:brightness(.95); transform:translateY(-1px); color:#fff; }
.ffcp-button-alt { background: var(--ffcp-accent-2); }
.ffcp-button-secondary { min-width: 240px; }
.ffcp-outline-button { background:#fff; color:var(--ffcp-accent); border:2px solid var(--ffcp-accent); }
.ffcp-outline-button:hover { background: var(--ffcp-accent); color:#fff; }
.ffcp-files-grid { display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:16px; }
.ffcp-file-card { border:1px solid var(--ffcp-border); border-radius:18px; padding:18px; background:#fafafa; display:flex; align-items:center; justify-content:space-between; gap:14px; min-height:114px; }
.ffcp-file-head { display:flex; align-items:center; gap:14px; min-width:0; }
.ffcp-file-icon { width:56px; height:56px; border-radius:14px; background:#eef7f9; display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; }
.ffcp-file-title { font-size:1.15rem; font-weight:800; margin-bottom:4px; }
.ffcp-file-link { font-weight:800; color:var(--ffcp-accent); text-decoration:none; white-space:nowrap; }
.ffcp-file-link:hover { text-decoration:underline; }
.ffcp-locked { color:var(--ffcp-accent-2); font-weight:800; }
.ffcp-collab-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px; }
.ffcp-collab-panel { border:1px solid var(--ffcp-border); border-radius:20px; padding:20px; background:#fafafa; }
.ffcp-collab-panel h3, .ffcp-activity-list h3 { margin-top:0; font-size:1.35rem; }
.ffcp-comment-form textarea, .ffcp-decision-form textarea {
  width:100%; box-sizing:border-box; min-height:120px; border-radius:14px; border:1px solid var(--ffcp-border); padding:14px; font:inherit; margin-bottom:14px;
}
.ffcp-decision-actions { display:flex; gap:12px; flex-wrap:wrap; }
.ffcp-decision-note { background:var(--ffcp-soft); border:1px solid var(--ffcp-border); border-radius:14px; padding:12px 14px; }
.ffcp-activity-list { border-top:1px solid var(--ffcp-border); padding-top:18px; }
.ffcp-activity-item { border:1px solid var(--ffcp-border); border-left:4px solid var(--ffcp-accent); border-radius:16px; padding:14px 16px; margin-bottom:12px; background:#fff; }
.ffcp-activity-revision { border-left-color: var(--ffcp-accent-2); }
.ffcp-activity-approved { border-left-color: #34a853; }
.ffcp-activity-meta { display:flex; justify-content:space-between; gap:14px; margin-bottom:8px; flex-wrap:wrap; }
.ffcp-files-repeater .ffcp-file-row { display:grid; grid-template-columns:1.1fr 1.6fr auto 160px auto; gap:10px; align-items:center; margin-bottom:10px; }
.ffcp-sortable-sections { margin: 10px 0 18px; padding:0; list-style:none; }
.ffcp-sortable-item { display:flex; gap:10px; align-items:center; padding:12px 14px; background:#fff; border:1px solid #dcdcde; border-radius:10px; margin-bottom:10px; cursor:move; }
@media (max-width: 1280px) {
  .ffcp-layout { grid-template-columns:260px minmax(0,1fr); }
  .ffcp-meta-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .ffcp-files-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 960px) {
  body.ffcp-portal-template .ffcp-template-shell { padding: 18px; }
  .ffcp-layout { grid-template-columns: 1fr; }
  .ffcp-sidebar { position:relative; top:0; min-height:auto; }
  .ffcp-overview-grid, .ffcp-collab-grid { grid-template-columns: 1fr; }
  .ffcp-product-card { grid-template-columns: 110px minmax(0,1fr); }
  .ffcp-product-action { grid-column: 1 / -1; }
  .ffcp-files-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .ffcp-hero-card { flex-direction:column; align-items:flex-start; }
  .ffcp-hero-actions { width:100%; }
  .ffcp-button-secondary { width:100%; }
  .ffcp-meta-grid { grid-template-columns: 1fr; }
  .ffcp-files-repeater .ffcp-file-row { grid-template-columns:1fr; }
}


.ffcp-login-shell { max-width: 720px; margin: 40px auto; }
.ffcp-login-card { background:#fff; border:1px solid var(--ffcp-border); border-radius:28px; padding:36px; box-shadow:0 18px 42px rgba(0,0,0,.08); }
.ffcp-login-logo { max-width:260px; height:auto; display:block; margin-bottom:18px; }
.ffcp-login-brand h1 { margin:0 0 10px; color:var(--ffcp-charcoal); font-size: clamp(2rem, 4vw, 2.8rem); }
.ffcp-login-brand p { margin:0 0 18px; color:var(--ffcp-muted); font-size:1.05rem; }
.ffcp-login-form label { display:block; font-weight:700; margin-bottom:8px; color:var(--ffcp-charcoal); }
.ffcp-login-form input[type="email"] { width:100%; box-sizing:border-box; border:1px solid var(--ffcp-border); border-radius:14px; padding:16px; font:inherit; margin-bottom:14px; }
.ffcp-login-notice { border-radius:14px; padding:14px 16px; margin:0 0 18px; font-weight:700; }
.ffcp-login-notice-email_sent, .ffcp-login-notice-expired { background:#eef7f9; color:var(--ffcp-teal); }
.ffcp-login-notice-invalid_email, .ffcp-login-notice-email_failed { background:#fff3ee; color:var(--ffcp-coral); }


/* Block theme integration fixes */
body.ffcp-portal-template .wp-block-post-title,
body.ffcp-portal-template .entry-title,
body.ffcp-portal-template h1.wp-block-post-title {
  display:none !important;
}
body.ffcp-portal-template main.wp-block-group,
body.ffcp-portal-template .wp-site-blocks > main {
  max-width:none !important;
  width:100% !important;
}
body.ffcp-portal-template .wp-site-blocks > main > .wp-block-post-content,
body.ffcp-portal-template main .wp-block-post-content {
  max-width:none !important;
  width:100% !important;
}
body.ffcp-portal-template .wp-site-blocks > main,
body.ffcp-portal-template .wp-site-blocks > .wp-block-group:has(> .wp-block-post-content) {
  padding-left:24px !important;
  padding-right:24px !important;
}
body.ffcp-portal-template .ffcp-template-shell {
  width:min(1440px, 100%);
  margin:0 auto;
}
body.ffcp-portal-template .ffcp-layout {
  align-items:start;
}
body.ffcp-portal-template .ffcp-branding img.ffcp-main-logo {
  max-width:220px;
  height:auto;
}

/* Portal page header/nav polish */
body.single-ff_client_portal .ff-site-header { z-index: 1001; }
body.single-ff_client_portal .ff-site-header .ff-logo-row {
  width: min(1440px, calc(100vw - 28px));
  max-width: min(1440px, calc(100vw - 28px));
  margin-left: auto;
  margin-right: auto;
  padding-left: 12px;
  padding-right: 12px;
}
body.single-ff_client_portal .ff-site-header .wp-block-navigation__container {
  gap: clamp(.65rem, 1.2vw, 1.15rem) !important;
}
body.single-ff_client_portal .ff-site-header .wp-block-navigation-item__content {
  font-size: .95rem;
}
body.single-ff_client_portal .wp-site-blocks > main,
body.single-ff_client_portal main.wp-block-group {
  padding-top: 12px !important;
}
body.single-ff_client_portal .ffcp-template-shell {
  margin-top: 0 !important;
}
@media (max-width: 1180px) {
  body.single-ff_client_portal .ff-site-header .wp-block-navigation-item__content { font-size: .9rem; }
  body.single-ff_client_portal .ff-site-header .wp-block-navigation__container { gap: .75rem !important; }
}

.ffcp-overview-docs { margin-top: 22px; }
.ffcp-overview-docs h3 { margin: 0 0 8px; font-size: 1.2rem; color: var(--ffcp-charcoal); }
.ffcp-overview-docs .ffcp-files-grid { grid-template-columns: repeat(2, minmax(0,1fr)); margin-top: 14px; }
.ffcp-overview-docs .ffcp-file-card { min-height: 96px; }
@media (max-width: 960px) {
  .ffcp-overview-docs .ffcp-files-grid { grid-template-columns: 1fr; }
}

/* Project messages */
.ffcp-message-composer{background:linear-gradient(135deg,rgba(37,142,166,.12),rgba(226,134,101,.10));border:1px solid rgba(255,255,255,.12);border-radius:22px;padding:18px;margin-bottom:18px;}
.ffcp-message-composer label{display:block;font-weight:800;margin-bottom:8px;}
.ffcp-message-composer textarea{width:100%;box-sizing:border-box;border-radius:18px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.96);color:#333138;padding:14px;min-height:132px;}
.ffcp-message-notify{display:flex!important;gap:8px;align-items:center;font-weight:600!important;margin:12px 0!important;color:inherit;}
.ffcp-message-thread{display:flex;flex-direction:column;gap:14px;}
.ffcp-message-bubble{max-width:88%;border-radius:22px;padding:16px 18px;border:1px solid rgba(255,255,255,.12);box-shadow:0 14px 34px rgba(0,0,0,.18);}
.ffcp-message-bubble.is-me{align-self:flex-end;background:var(--ffcp-accent,#258ea6);color:#fff;}
.ffcp-message-bubble.is-other{align-self:flex-start;background:rgba(255,255,255,.94);color:#333138;}
.ffcp-message-meta{display:flex;gap:10px;justify-content:space-between;align-items:baseline;font-size:.92rem;margin-bottom:8px;opacity:.95;}
.ffcp-message-meta span{font-size:.82rem;opacity:.82;}
.ffcp-message-content p{margin:0 0 10px;}
.ffcp-message-content p:last-child{margin-bottom:0;}
@media (max-width:700px){.ffcp-message-bubble{max-width:100%;}.ffcp-message-meta{display:block;}.ffcp-message-meta span{display:block;margin-top:3px;}}

/* v1.7.1 deliverable review workflow */
.ffcp-deliverable-review {
    margin-top: 24px;
    padding: 22px;
    border: 1px solid rgba(230, 231, 232, 0.14);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.055);
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: 22px;
    align-items: start;
}
.ffcp-deliverable-review h3 { margin-top: 0; }
.ffcp-review-status { margin: 12px 0 0; }
.ffcp-review-form label { display: block; font-weight: 700; margin-bottom: 8px; }
.ffcp-review-form textarea {
    width: 100%;
    border-radius: 16px;
    border: 1px solid rgba(230, 231, 232, 0.18);
    background: rgba(255, 255, 255, 0.08);
    color: inherit;
    padding: 12px 14px;
}
.ffcp-decision-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }
@media (max-width: 760px) {
    .ffcp-deliverable-review { grid-template-columns: 1fr; }
}

/* v1.7.2 premium composer visibility + polished review inputs */
.ffcp-message-composer,
.ffcp-deliverable-review {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(230, 231, 232, 0.22) !important;
  box-shadow: 0 18px 44px rgba(0,0,0,.16);
}
.ffcp-message-composer::before,
.ffcp-deliverable-review::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: linear-gradient(180deg, var(--ffcp-accent, #258ea6), var(--ffcp-accent-2, #e28665));
}
.ffcp-message-composer form,
.ffcp-review-form,
.ffcp-review-copy {
  position: relative;
  z-index: 1;
}
.ffcp-message-composer label,
.ffcp-review-form label {
  color: inherit;
  letter-spacing: .01em;
}
.ffcp-message-composer textarea,
.ffcp-review-form textarea,
.ffcp-comment-form textarea,
.ffcp-decision-form textarea {
  display: block !important;
  width: 100% !important;
  box-sizing: border-box !important;
  min-height: 132px;
  margin: 0 0 14px !important;
  padding: 16px 18px !important;
  border: 2px solid rgba(230, 231, 232, 0.72) !important;
  border-radius: 18px !important;
  background: #ffffff !important;
  color: #333138 !important;
  font: inherit !important;
  line-height: 1.55 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8), 0 10px 24px rgba(0,0,0,.08) !important;
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.ffcp-message-composer textarea::placeholder,
.ffcp-review-form textarea::placeholder,
.ffcp-comment-form textarea::placeholder,
.ffcp-decision-form textarea::placeholder {
  color: rgba(51,49,56,.62) !important;
}
.ffcp-message-composer textarea:hover,
.ffcp-review-form textarea:hover,
.ffcp-comment-form textarea:hover,
.ffcp-decision-form textarea:hover {
  border-color: rgba(37, 142, 166, .78) !important;
}
.ffcp-message-composer textarea:focus,
.ffcp-review-form textarea:focus,
.ffcp-comment-form textarea:focus,
.ffcp-decision-form textarea:focus {
  outline: none !important;
  border-color: var(--ffcp-accent, #258ea6) !important;
  box-shadow: 0 0 0 4px rgba(37,142,166,.18), 0 12px 28px rgba(0,0,0,.10) !important;
  transform: translateY(-1px);
}
.ffcp-message-notify {
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.10);
}
.ffcp-deliverable-review {
  background: linear-gradient(135deg, rgba(51,49,56,.88), rgba(51,49,56,.72)) !important;
}
.ffcp-review-copy h3,
.ffcp-review-copy p,
.ffcp-review-form label {
  color: #fff;
}
.ffcp-review-copy .ffcp-subtle,
.ffcp-review-status {
  color: rgba(255,255,255,.82) !important;
}
.ffcp-decision-note {
  background: rgba(255,255,255,.94) !important;
  color: #333138 !important;
  border-color: rgba(255,255,255,.35) !important;
}
@media (max-width: 760px) {
  .ffcp-message-composer,
  .ffcp-deliverable-review { border-radius: 20px; }
}

/* v1.7.4 stronger text-message style + client portal finder */
.ffcp-message-thread {
  gap: 18px !important;
  padding: 10px 2px 4px !important;
}
.ffcp-message-bubble {
  position: relative !important;
  max-width: min(78%, 680px) !important;
  padding: 14px 16px !important;
  border: 0 !important;
  border-radius: 22px !important;
  box-shadow: 0 12px 26px rgba(51,49,56,.14) !important;
}
.ffcp-message-bubble.is-me {
  align-self: flex-end !important;
  background: #258ea6 !important;
  color: #fff !important;
  border-bottom-right-radius: 7px !important;
}
.ffcp-message-bubble.is-other {
  align-self: flex-start !important;
  background: #e28665 !important;
  color: #fff !important;
  border-bottom-left-radius: 7px !important;
}
.ffcp-message-bubble::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 16px;
  height: 16px;
}
.ffcp-message-bubble.is-me::after {
  right: -6px;
  background: #258ea6;
  clip-path: polygon(0 0, 100% 100%, 0 100%);
}
.ffcp-message-bubble.is-other::after {
  left: -6px;
  background: #e28665;
  clip-path: polygon(100% 0, 100% 100%, 0 100%);
}
.ffcp-message-meta {
  color: rgba(255,255,255,.92) !important;
  margin-bottom: 6px !important;
}
.ffcp-message-content,
.ffcp-message-content p {
  color: #fff !important;
}
.ffcp-message-composer {
  background: #333138 !important;
  border-color: rgba(230,231,232,.18) !important;
}
.ffcp-message-composer label:not(.ffcp-message-notify) {
  color: #fff !important;
}
.ffcp-message-notify {
  color: #e6e7e8 !important;
}
.ffcp-my-portals-list {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}
.ffcp-my-portal-card {
  display: block;
  padding: 16px 18px;
  border-radius: 18px;
  background: #fff;
  color: #333138 !important;
  text-decoration: none !important;
  border: 1px solid rgba(51,49,56,.12);
  box-shadow: 0 10px 26px rgba(51,49,56,.10);
}
.ffcp-my-portal-card strong { display:block; font-size:1.05rem; }
.ffcp-my-portal-card span { display:block; margin-top:4px; color:rgba(51,49,56,.72); }
.ffcp-my-portal-card:hover { transform: translateY(-1px); border-color:#258ea6; }
@media (max-width:700px){
  .ffcp-message-bubble{max-width:92% !important;}
}

.ffcp-product-deliverables{
  margin: 12px 0 0;
  padding-left: 18px;
  color: rgba(255,255,255,.78);
  font-size: .92rem;
}
.ffcp-product-deliverables li{ margin: 4px 0; }
.ffcp-approved-badge{
  display:inline-flex;
  align-items:center;
  margin-top:10px;
  padding:5px 10px;
  border-radius:999px;
  background:rgba(37,142,166,.18);
  border:1px solid rgba(37,142,166,.55);
  color:#e6e7e8;
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.ffcp-approve-package-form{ margin:0; }
.ffcp-approve-package-form .ffcp-button{ width:100%; border:0; cursor:pointer; }
