/* socialmocial-theme.css */
:root {
  --bg: #0b0b0c;
  --panel: #121316;
  --panelMuted: #0f1012cc;
  --panelAlt: #0f1012;
  --panelAlt2: #111215;
  --panelAlt3: #16181c;

  --border: #2a2d33;
  --borderSoft: #2a2d3366;

  --text: #ffffff;
  --textMuted: #bfc2c7;
  --textSubtle: #6b6f76;

  --accent: #f5c542;
  --accentSecondary: #e8e8e6;

  --success: #2bc48a;
  --danger: #ff6b7a;
  --warning: #f5c542;

  --menu-accent-1: #f5c542;
  --menu-accent-2: #f1c54d;
  --menu-accent-3: #edc555;
  --menu-accent-4: #eac45d;
  --menu-accent-5: #e7c465;
  --menu-accent-6: #e4c46d;
  --menu-accent-7: #e0c475;
  --menu-accent-8: #ddc47d;
  --menu-accent-9: #dac485;
  --menu-accent-10: #d7c38c;
  --menu-accent-11: #d4c394;
  --menu-accent-12: #d0c39c;
  --menu-accent-13: #cdc3a4;
  --menu-accent-14: #cac3ac;
}

html, body {
  margin: 0;
  min-height: 100%;
  color: #3f4250;
  font-family: "IBM Plex Sans", "Avenir Next", sans-serif;
  background: #f2f2f4;
}

* {
  box-sizing: border-box;
  scrollbar-width: thin;
  scrollbar-color: #b8bfcb transparent;
}

.socialmocial-app {
  min-height: 100vh;
}

.socialmocial-topbar {
  height: 72px;
  background: #ffffff;
  border-bottom: 1px solid #d4d9e2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
}

.socialmocial-topbar-left,
.socialmocial-topbar-right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.socialmocial-topbar-brand {
  color: #57607a;
  font-size: 1.35rem;
}

.socialmocial-icon-btn {
  border: 0;
  background: transparent;
  color: #6f768a;
  font-size: 1.2rem;
  cursor: pointer;
}

.socialmocial-avatar {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  background: #2f9be8;
  color: #ffffff;
  font-weight: 700;
  font-size: 0.78rem;
}

.socialmocial-avatar.small {
  width: 30px;
  height: 30px;
  font-size: 0.72rem;
}

.socialmocial-layout {
  display: grid;
  grid-template-columns: 60px 231px minmax(0, 1fr);
  min-height: calc(100vh - 72px);
  transition: grid-template-columns 0.25s ease;
}

.socialmocial-layout.rail-open {
  grid-template-columns: 220px 231px minmax(0, 1fr);
}

.socialmocial-layout.no-submenu {
  grid-template-columns: 60px 0 minmax(0, 1fr);
}

.socialmocial-layout.rail-open.no-submenu {
  grid-template-columns: 220px 0 minmax(0, 1fr);
}

.socialmocial-rail {
  background: #283342;
  color: #c6cedb;
  border-right: 1px solid #3d4a5c;
  width: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  position: relative;
  z-index: 15;
}

.socialmocial-layout.rail-open .socialmocial-rail {
  box-shadow: 6px 0 20px #00000040;
}

.socialmocial-rail-pin {
  position: absolute;
  top: 12px;
  left: 10px;
  right: auto;
  width: 28px;
  height: 28px;
  border: 1px solid #4a596f;
  border-radius: 8px;
  background: #314052;
  color: #d9e1ee;
  font-size: 0.9rem;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: 0.2s ease;
}

.socialmocial-rail nav {
  padding-top: 8px;
}

.socialmocial-rail-pin:hover,
.socialmocial-rail-pin.active {
  background: #3a4a60;
  border-color: #6b7f9f;
}

.socialmocial-rail ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.socialmocial-rail li {
  height: 44px;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0 18px;
  border-left: 3px solid transparent;
  white-space: nowrap;
}

.socialmocial-rail-icon {
  width: 20px;
  text-align: center;
}

.socialmocial-rail li::after {
  content: attr(data-label);
  color: #d8deea;
  font-size: 0.92rem;
  opacity: 0;
  transform: translateX(6px);
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.socialmocial-rail:hover li::after {
  opacity: 1;
  transform: translateX(0);
}

.socialmocial-layout.rail-open .socialmocial-rail li::after {
  opacity: 1;
  transform: translateX(0);
}

.socialmocial-rail li.active,
.socialmocial-rail li:hover {
  background: #334051;
  border-left-color: #ff5470;
}

.socialmocial-sidebar {
  background: #f8f9fb;
  border-right: 1px solid #d9dde6;
  overflow: auto;
}

.socialmocial-layout.no-submenu .socialmocial-sidebar {
  border-right: 0;
  overflow: hidden;
}

.socialmocial-layout.no-submenu .socialmocial-search-row,
.socialmocial-layout.no-submenu .socialmocial-submenu-area {
  display: none;
}

.socialmocial-search-row {
  height: 62px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  border-bottom: 1px solid #e4e8ee;
}

.socialmocial-search-row input {
  width: 100%;
  border: 1px solid #c9d0dc;
  border-radius: 999px;
  height: 38px;
  padding: 0 14px;
  background: #ffffff;
}

.socialmocial-menu-group {
  padding: 14px 14px 2px;
}

.socialmocial-submenu-area {
  display: block;
}

.socialmocial-submenu-panel {
  display: none;
}

.socialmocial-submenu-panel.is-active {
  display: block;
}

.socialmocial-mini-list {
  list-style: none;
  margin: 4px 0 0;
  padding: 0;
  display: grid;
  gap: 6px;
}

.socialmocial-mini-list li {
  border: 1px solid #d6ddeb;
  background: #f7f9fd;
  border-radius: 8px;
  padding: 8px 10px;
  color: #4f5872;
}

.socialmocial-submenu-feature-list {
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
  display: grid;
  gap: 7px;
}

.socialmocial-submenu-feature-list button {
  width: 100%;
  border: 1px solid #d2daea;
  border-radius: 10px;
  background: #ffffff;
  color: #2f3f5e;
  padding: 10px;
  text-align: left;
  cursor: pointer;
  font-weight: 600;
  transition: 0.2s ease;
}

.socialmocial-submenu-feature-list button:hover,
.socialmocial-submenu-feature-list button.active {
  border-color: #2f9be8;
  background: #eaf4ff;
  box-shadow: 0 8px 20px #2f9be81f;
}

.socialmocial-submenu-feature-list .submenu-group-title {
  margin: 4px 0 0;
  padding: 2px 4px;
  font-size: 0.73rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #425272;
  text-transform: uppercase;
}

.socialmocial-submenu-feature-list .submenu-group-title-muted {
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px solid #dbe3f0;
  color: #6c7b96;
}

.feature-detail {
  display: grid;
  gap: 12px;
}

.feature-detail-card {
  border: 1px solid #d4ddec;
  border-radius: 14px;
  background: #ffffff;
  padding: 14px;
}

.feature-detail-card h3 {
  margin: 0;
  color: #1f2637;
}

.feature-detail-card p {
  margin: 6px 0 0;
  color: #647492;
}

.feature-detail-actions {
  margin-top: 10px;
  display: flex;
  gap: 8px;
}

.feature-metric-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.feature-metric-item {
  border: 1px solid #d6deee;
  border-radius: 10px;
  background: #f8fbff;
  padding: 10px;
}

.feature-metric-item span {
  display: block;
  color: #6d7e9e;
  font-size: 0.76rem;
}

.feature-metric-item strong {
  display: block;
  margin-top: 4px;
  color: #23324f;
  font-size: 1rem;
}

.analytics-landing-head h3 {
  margin: 0;
  color: #1f2637;
}

.analytics-landing-head p {
  margin: 6px 0 0;
  color: #6f7c97;
}

.analytics-module-grid {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.analytics-module-card {
  border: 1px solid #d4ddec;
  border-radius: 12px;
  background: #ffffff;
  padding: 12px;
  text-align: left;
  display: grid;
  gap: 6px;
  cursor: pointer;
  transition: 0.2s ease;
}

.analytics-module-card:hover {
  border-color: #2f9be8;
  background: #f4f9ff;
  box-shadow: 0 8px 20px #2f9be81f;
}

.analytics-module-icon {
  font-size: 1.2rem;
}

.analytics-module-card strong {
  color: #1f2637;
}

.analytics-module-card p {
  margin: 0;
  color: #65728d;
  font-size: 0.88rem;
}

.analytics-shell {
  display: grid;
  gap: 14px;
}

.analytics-shell-head {
  border: 1px solid #d6deed;
  border-radius: 12px;
  background: #ffffff;
  padding: 12px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
}

.analytics-shell-head h3 {
  margin: 8px 0 0;
  color: #1f2637;
}

.analytics-shell-head p {
  margin: 4px 0 0;
  color: #6d7d9a;
}

.analytics-back-btn {
  margin-bottom: 4px;
}

.analytics-head-actions {
  display: grid;
  align-content: start;
  justify-items: end;
  gap: 8px;
}

.analytics-filter-bar {
  border: 1px solid #d6deed;
  border-radius: 12px;
  background: #f9fbff;
  padding: 12px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.analytics-filter-bar label {
  display: grid;
  gap: 6px;
}

.analytics-filter-bar span {
  color: #667692;
  font-size: 0.78rem;
  font-weight: 600;
}

.analytics-filter-bar select,
.analytics-date-placeholder input,
.analytics-filter-bar input[type="text"] {
  width: 100%;
  border: 1px solid #c8d2e4;
  border-radius: 10px;
  background: #ffffff;
  height: 38px;
  padding: 0 10px;
  color: #32435f;
}

.analytics-date-placeholder {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.analytics-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.analytics-kpi-card {
  border: 1px solid #d4ddec;
  border-radius: 12px;
  background: #ffffff;
  padding: 11px;
}

.analytics-kpi-card.premium {
  border-color: rgba(36, 103, 196, 0.22);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.analytics-kpi-card span {
  display: block;
  color: #6f7e9a;
  font-size: 0.78rem;
}

.analytics-kpi-card strong {
  display: block;
  margin-top: 5px;
  color: #1f2637;
  font-size: 1.2rem;
}

.analytics-kpi-card small {
  display: block;
  margin-top: 4px;
  color: #2d9f66;
  font-size: 0.8rem;
}

.analytics-kpi-card.premium span {
  color: #4a5b78;
  letter-spacing: 0.02em;
}

.analytics-kpi-card.premium strong {
  font-size: 1.28rem;
}

.analytics-layout-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
}

.analytics-block {
  border: 1px solid #d4ddec;
  border-radius: 12px;
  background: #ffffff;
  padding: 12px;
}

.analytics-block.premium {
  border-color: rgba(36, 103, 196, 0.2);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
}

.analytics-block.premium header h4 {
  font-size: 1.05rem;
}

.analytics-block header h4 {
  margin: 0;
  color: #1f2637;
  font-size: 1rem;
  font-weight: 700;
}

.analytics-chart-bars {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(26px, 1fr));
  gap: 8px;
  min-height: 180px;
  align-items: end;
}

.analytics-bar-col {
  display: grid;
  gap: 5px;
  justify-items: center;
}

.analytics-bar {
  width: 100%;
  border-radius: 7px 7px 0 0;
  background: linear-gradient(180deg, #2f9be8, #1f74bb);
  min-height: 8px;
}

.analytics-bar-col small {
  color: #6f7f9b;
  font-size: 0.72rem;
}

.analytics-table-wrap {
  margin-top: 10px;
  border: 1px solid #d8dfeb;
  border-radius: 10px;
  overflow: auto;
}

.analytics-table-wrap table {
  width: 100%;
  border-collapse: collapse;
  min-width: 760px;
}

.analytics-table-wrap th,
.analytics-table-wrap td {
  border-bottom: 1px solid #e0e6f1;
  text-align: left;
  padding: 9px 10px;
  color: #44526d;
  font-size: 0.84rem;
}

.analytics-table-wrap th {
  background: #edf2fa;
  color: #2f3f5b;
}

.analytics-table-wrap tr:last-child td {
  border-bottom: 0;
}

.analytics-insights ul {
  margin: 10px 0 0;
  padding-left: 18px;
  color: #495977;
  display: grid;
  gap: 6px;
}

.analytics-special-stack {
  display: grid;
  gap: 12px;
}

.analytics-state {
  border: 1px dashed #ccd6e7;
  border-radius: 12px;
  background: #f9fbff;
  padding: 14px;
  text-align: center;
  color: #5f6f8d;
}

.analytics-state h4 {
  margin: 6px 0;
  color: #2a3955;
}

.analytics-state p {
  margin: 0;
}

.analytics-state-icon {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  margin: 0 auto;
  background: #e9f1ff;
  color: #2f8fda;
  display: grid;
  place-items: center;
  font-weight: 700;
}

.analytics-state-error {
  border-color: #efc8cf;
  background: #fff6f8;
}

.analytics-state-error .analytics-state-icon {
  background: #fbe5e9;
  color: #cb4b63;
}

.analytics-loading-line {
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, #e9eef7, #dce6f4, #e9eef7);
  background-size: 220% 100%;
  animation: analytics-loading 1.2s linear infinite;
  margin: 0 auto 8px;
}

.analytics-loading-line.w-30 {
  width: 30%;
}

.analytics-loading-line.w-60 {
  width: 60%;
}

.analytics-loading-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.analytics-loading-card,
.analytics-loading-block {
  border-radius: 10px;
  background: linear-gradient(90deg, #e9eef7, #dce6f4, #e9eef7);
  background-size: 220% 100%;
  animation: analytics-loading 1.2s linear infinite;
}

.analytics-loading-card {
  height: 72px;
}

.analytics-loading-block {
  margin-top: 8px;
  height: 150px;
}

.analytics-empty-box {
  margin-top: 10px;
  border: 1px dashed #ced9eb;
  border-radius: 10px;
  background: #ffffff;
  padding: 12px;
  color: #6d7e9b;
  font-size: 0.86rem;
}

.monitoring-filter-date {
  grid-column: span 2;
}

.monitoring-submenu-quick {
  margin: 8px 0 12px;
  border: 1px solid #d8e0ec;
  border-radius: 14px;
  background: #ffffff;
  box-shadow: 0 1px 3px #1018280d;
  padding: 12px;
  display: grid;
  gap: 8px;
}

.monitoring-submenu-copy {
  display: grid;
  gap: 4px;
}

.monitoring-submenu-copy strong {
  color: #1f2637;
  font-size: 0.98rem;
  letter-spacing: 0.01em;
}

.monitoring-submenu-copy p {
  margin: 0;
  color: #667692;
  font-size: 0.82rem;
  line-height: 1.4;
}

.monitoring-submenu-competitor-form {
  border: 1px solid #dde4ef;
  border-radius: 12px;
  background: #f8fbff;
  padding: 10px 10px 8px;
  display: grid;
  gap: 7px;
}

.monitoring-submenu-competitor-form.is-open {
  display: grid;
}

.monitoring-submenu-competitor-form input {
  width: 100%;
  height: 46px;
  border: 1px solid #c6d3e6;
  border-radius: 12px;
  background: #ffffff;
  padding: 0 12px;
  color: #2e3d59;
  font-size: 0.95rem;
}

.monitoring-submenu-competitor-form input:focus {
  outline: none;
  border-color: #4b8ff0;
  box-shadow: 0 0 0 3px #4b8ff022;
}

.monitoring-submenu-hint {
  color: #7a889f;
  font-size: 0.74rem;
}

.monitoring-submenu-competitor-status {
  margin: 0;
  min-height: 18px;
  color: #4f6385;
  font-size: 0.8rem;
}

.monitoring-account-setup {
  margin-bottom: 12px;
}

.monitoring-account-setup-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.monitoring-account-setup-head h4 {
  margin: 0;
  color: #1f2637;
}

.monitoring-account-setup-head p {
  margin: 4px 0 0;
  color: #6e7d99;
  font-size: 0.86rem;
}

.monitoring-account-setup-body {
  margin-top: 10px;
  border: 1px solid #d7dfec;
  border-radius: 12px;
  background: #f8fbff;
  padding: 10px;
  display: grid;
  gap: 10px;
}

.monitoring-account-mode {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.monitoring-account-mode button {
  border: 1px solid #c8d4e8;
  background: #ffffff;
  color: #3a4e70;
  border-radius: 999px;
  min-height: 34px;
  padding: 0 12px;
  font-weight: 600;
  cursor: pointer;
}

.monitoring-account-mode button.active {
  border-color: #2f9be8;
  background: #eaf4ff;
  color: #1e5f98;
}

.monitoring-account-badges {
  display: grid;
  gap: 8px;
}

.monitoring-account-badges button {
  border: 1px solid #ccd6e8;
  border-radius: 10px;
  background: #ffffff;
  min-height: 42px;
  padding: 8px 10px;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  color: #2f4263;
  font-weight: 700;
  cursor: pointer;
}

.monitoring-account-badges button.connected {
  border-color: #73c58f;
  background: #eefcf4;
}

.monitoring-account-badges .account-logo {
  width: 28px;
  height: 28px;
}

.monitoring-competitor-input {
  display: grid;
  gap: 6px;
}

.monitoring-competitor-input span {
  color: #667692;
  font-size: 0.78rem;
  font-weight: 600;
}

.monitoring-competitor-input input {
  width: 100%;
  border: 1px solid #c8d2e4;
  border-radius: 10px;
  background: #ffffff;
  height: 38px;
  padding: 0 10px;
  color: #32435f;
}

.monitoring-account-status {
  margin: 0;
  color: #3d5f86;
  font-size: 0.84rem;
}

.monitoring-connected-section {
  margin-top: 10px;
}

.monitoring-connected-section h5 {
  margin: 0;
  color: #2a3b59;
  font-size: 0.88rem;
}

.monitoring-connected-list {
  margin: 8px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.monitoring-connected-list li {
  border: 1px solid #d4ddec;
  border-radius: 10px;
  background: #ffffff;
  padding: 8px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.monitoring-connected-main {
  display: flex;
  align-items: center;
  gap: 8px;
}

.monitoring-connected-main strong {
  display: block;
  color: #1f2f4b;
}

.monitoring-connected-main small {
  display: block;
  color: #6b7a95;
}

.monitoring-connected-actions {
  display: flex;
  align-items: center;
  gap: 7px;
}

.monitoring-connected-actions a {
  color: #2b7bc2;
  font-size: 0.8rem;
  text-decoration: none;
}

.monitoring-detail-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.monitoring-alert-list,
.monitoring-event-feed {
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.monitoring-alert-item,
.monitoring-event-item {
  border: 1px solid #d7deea;
  border-radius: 10px;
  background: #f8fbff;
  padding: 10px;
}

.monitoring-alert-head,
.monitoring-event-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.monitoring-alert-item p,
.monitoring-event-item p {
  margin: 8px 0 6px;
  color: #41506c;
  font-size: 0.85rem;
}

.monitoring-alert-item small,
.monitoring-event-meta span {
  color: #687796;
  font-size: 0.76rem;
}

.monitoring-event-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px;
}

.monitoring-event-platform .account-logo {
  width: 30px;
  height: 30px;
}

.monitoring-event-platform .account-logo img {
  width: 16px;
  height: 16px;
}

.competitor-feed-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 12px;
  margin: 14px 0 6px;
}

.competitor-feed-controls label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.78rem;
  color: #6b7a95;
  min-width: 160px;
}

.competitor-feed-controls select,
.competitor-feed-controls input {
  border: 1px solid #d7deea;
  border-radius: 10px;
  padding: 8px 10px;
  font-size: 0.88rem;
  background: #fff;
  color: #1f2f4b;
}

.competitor-feed-search {
  flex: 1;
  min-width: 220px;
}

.competitor-post-feed {
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.competitor-post-card {
  border: 1px solid #d7deea;
  border-radius: 12px;
  background: #ffffff;
  padding: 16px;
  box-shadow: 0 8px 24px rgba(20, 37, 63, 0.04);
}

.competitor-post-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.competitor-post-meta {
  display: flex;
  align-items: center;
  gap: 10px;
}

.competitor-post-meta strong {
  display: block;
  color: #1f2f4b;
}

.competitor-post-meta small {
  color: #6b7a95;
  font-size: 0.78rem;
}

.competitor-post-meta .account-logo {
  width: 34px;
  height: 34px;
}

.competitor-post-card p {
  margin: 10px 0 0;
  color: #41506c;
}

.competitor-post-metrics {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px 18px;
  font-size: 0.78rem;
  color: #6b7a95;
}

.competitor-post-metrics strong {
  color: #1f2f4b;
  margin-left: 6px;
}

.competitor-post-tags {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.monitoring-event-tags {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.monitoring-sentiment-tag {
  border: 1px solid #c8d5ea;
  border-radius: 999px;
  font-size: 0.72rem;
  padding: 2px 8px;
  text-transform: capitalize;
  background: #f1f4fa;
  color: #53637f;
}

.monitoring-sentiment-tag.sentiment-positive {
  border-color: #8bd1ad;
  color: #1f7f50;
  background: #ecfbf2;
}

.monitoring-sentiment-tag.sentiment-negative {
  border-color: #efbcc6;
  color: #b23752;
  background: #fff0f4;
}

.monitoring-tone-negative {
  border-color: #e9b9c3;
  background: #fff6f8;
}

.monitoring-tone-positive {
  border-color: #b7dfca;
  background: #f4fff8;
}

.monitoring-filter-actions {
  display: flex;
  align-items: flex-end;
  gap: 8px;
}

.monitoring-filter-actions .publish-outline,
.monitoring-filter-actions .publish-primary {
  padding: 9px 12px;
  min-height: 40px;
}

.monitoring-listening-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.monitoring-source-list {
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.monitoring-source-list li {
  border: 1px solid #d7deea;
  border-radius: 10px;
  background: #f9fbff;
  padding: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.monitoring-source-list li strong {
  display: block;
  color: #1f2f4b;
  font-size: 0.9rem;
}

.monitoring-source-list li small {
  color: #6f7e9b;
  font-size: 0.78rem;
}

.monitoring-keyword-grid {
  margin-top: 10px;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.monitoring-keyword-chip {
  border: 1px solid #d5ddeb;
  border-radius: 10px;
  background: #ffffff;
  text-align: left;
  padding: 9px 10px;
  cursor: pointer;
  transition: 0.2s ease;
  display: grid;
  gap: 3px;
}

.monitoring-keyword-chip:hover {
  border-color: #97b6e6;
  background: #edf4ff;
}

.monitoring-keyword-chip strong {
  color: #24406d;
  font-size: 0.84rem;
}

.monitoring-keyword-chip small {
  color: #6d7d9d;
  font-size: 0.74rem;
}

.monitoring-mentions-table {
  min-width: 920px;
}

.monitoring-mentions-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.monitoring-mentions-actions .publish-outline {
  padding: 5px 8px;
  border-radius: 999px;
  font-size: 0.72rem;
}

.monitoring-event-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.monitoring-event-actions .publish-outline {
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 0.72rem;
}

.monitoring-watchlist-block {
  position: relative;
}

.monitoring-watchlist-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px auto;
  gap: 8px;
  align-items: end;
}

.monitoring-watchlist-form label {
  display: grid;
  gap: 6px;
}

.monitoring-watchlist-form label span {
  color: #5f6f8c;
  font-size: 0.78rem;
}

.monitoring-watchlist-form input,
.monitoring-watchlist-form select {
  width: 100%;
  border: 1px solid #c7d2e8;
  border-radius: 10px;
  min-height: 40px;
  padding: 0 12px;
  background: #ffffff;
  color: #2e3c58;
}

.monitoring-watchlist-status {
  margin: 8px 0 0;
  color: #2f6b45;
  font-size: 0.82rem;
}

.monitoring-saved-views {
  margin-top: 8px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.monitoring-watchlist-grid {
  margin-top: 10px;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.monitoring-watchlist-card {
  border: 1px solid #d7dfed;
  border-radius: 12px;
  background: #fbfdff;
  padding: 10px;
  display: grid;
  gap: 7px;
}

.monitoring-watchlist-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px;
}

.monitoring-watchlist-card-head strong {
  color: #203456;
}

.monitoring-watchlist-card p {
  margin: 0;
  color: #6a7893;
  font-size: 0.78rem;
}

.monitoring-watchlist-card dl {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.monitoring-watchlist-card dt {
  color: #7584a0;
  font-size: 0.72rem;
}

.monitoring-watchlist-card dd {
  margin: 2px 0 0;
  color: #223659;
  font-size: 0.86rem;
  font-weight: 600;
}

.monitoring-mention-overlay {
  position: fixed;
  inset: 0;
  background: #1218264f;
  z-index: 130;
}

.monitoring-mention-drawer {
  position: fixed;
  right: 0;
  top: 0;
  width: min(440px, 94vw);
  height: 100vh;
  background: #ffffff;
  border-left: 1px solid #d8e0ef;
  box-shadow: -18px 0 34px #1f2d471a;
  z-index: 140;
  display: grid;
  grid-template-rows: auto 1fr;
}

.monitoring-mention-drawer header {
  padding: 14px 16px;
  border-bottom: 1px solid #e1e7f2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.monitoring-mention-drawer header h4 {
  margin: 0;
  color: #203456;
}

.monitoring-mention-drawer-body {
  padding: 14px 16px 16px;
  overflow-y: auto;
  display: grid;
  gap: 10px;
}

.monitoring-mention-full {
  margin: 0;
  color: #2f3f5d;
  line-height: 1.45;
}

.monitoring-mention-drawer dl {
  margin: 0;
  display: grid;
  gap: 8px;
}

.monitoring-mention-drawer dl div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  border-bottom: 1px solid #eef2f8;
  padding-bottom: 6px;
}

.monitoring-mention-drawer dt {
  color: #6a7a95;
  font-size: 0.78rem;
}

.monitoring-mention-drawer dd {
  margin: 0;
  color: #203456;
  font-weight: 600;
}

.monitoring-mention-keywords {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.monitoring-mention-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.social-inbox-filter-bar {
  align-items: end;
}

.social-inbox-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid #d6dfed;
  border-radius: 10px;
  background: #ffffff;
  min-height: 38px;
  padding: 0 10px;
}

.social-inbox-toggle input {
  margin: 0;
}

.social-inbox-toggle span {
  color: #4c5e7e;
  font-size: 0.8rem;
  font-weight: 600;
}

.social-inbox-filter-actions {
  align-items: flex-end;
}

.social-inbox-workspace {
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 360px) minmax(0, 1fr);
}

.social-inbox-thread-list {
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
  display: grid;
  gap: 8px;
  max-height: 620px;
  overflow: auto;
}

.social-inbox-thread-item {
  width: 100%;
  border: 1px solid #d7deea;
  border-radius: 10px;
  background: #f8fbff;
  padding: 10px;
  text-align: left;
  cursor: pointer;
  transition: 0.15s ease;
}

.social-inbox-thread-item:hover {
  border-color: #9cb8e6;
}

.social-inbox-thread-item.is-active {
  border-color: #3a85dd;
  background: #eef5ff;
}

.social-inbox-thread-main {
  display: grid;
  gap: 6px;
}

.social-inbox-thread-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 8px;
  align-items: center;
}

.social-inbox-thread-head strong {
  color: #1f2f4b;
}

.social-inbox-thread-head small {
  color: #71809a;
  font-size: 0.75rem;
}

.social-inbox-platform .account-logo {
  width: 24px;
  height: 24px;
}

.social-inbox-thread-main p {
  margin: 0;
  color: #3d4f6e;
  font-size: 0.84rem;
}

.social-inbox-thread-detail {
  min-height: 520px;
}

.social-inbox-thread-meta {
  margin-top: 8px;
  display: grid;
  gap: 4px;
}

.social-inbox-thread-meta strong {
  color: #203456;
}

.social-inbox-thread-meta span {
  color: #6f7e9b;
  font-size: 0.8rem;
}

.social-inbox-thread-controls {
  margin-top: 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
}

.social-inbox-thread-controls label {
  display: grid;
  gap: 6px;
}

.social-inbox-thread-controls label span {
  color: #5e6e8b;
  font-size: 0.78rem;
  font-weight: 600;
}

.social-inbox-thread-controls input {
  width: 100%;
  border: 1px solid #c8d2e4;
  border-radius: 10px;
  background: #ffffff;
  min-height: 38px;
  padding: 0 10px;
  color: #32435f;
}

.social-inbox-tags {
  margin-top: 8px;
}

.social-inbox-message-feed {
  margin-top: 10px;
  max-height: 430px;
  overflow: auto;
}

.social-inbox-keyword-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px auto;
  gap: 8px;
  align-items: end;
}

.social-inbox-keyword-form label {
  display: grid;
  gap: 6px;
}

.social-inbox-keyword-form label span {
  color: #5f6f8c;
  font-size: 0.78rem;
  font-weight: 600;
}

.social-inbox-keyword-form input,
.social-inbox-keyword-form select {
  width: 100%;
  border: 1px solid #c7d2e8;
  border-radius: 10px;
  min-height: 40px;
  padding: 0 12px;
  background: #ffffff;
  color: #2e3c58;
}

@keyframes analytics-loading {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -20% 0;
  }
}

.publish-submenu-divider {
  height: 1px;
  background: #d6ddeb;
  margin: 6px 0 8px;
}

.publish-submenu-new-btn {
  width: 100%;
  border: 1px solid #209b63;
  border-radius: 12px;
  padding: 11px 12px;
  background: linear-gradient(180deg, #30b775, #1f995f);
  color: #ffffff;
  font-weight: 700;
  cursor: pointer;
  margin-bottom: 8px;
  transition: 0.2s ease;
}

.publish-submenu-queue-btn {
  width: 100%;
  border: 1px solid #1d57a8;
  border-radius: 12px;
  padding: 11px 12px;
  background: linear-gradient(180deg, #3c86ea, #2b74d7);
  color: #ffffff;
  font-weight: 700;
  cursor: pointer;
  margin-bottom: 8px;
  transition: 0.2s ease;
}

.publish-submenu-queue-btn:hover {
  filter: brightness(1.05);
  box-shadow: 0 8px 18px #2b74d740;
}

.publish-submenu-queue-btn.active,
.publish-submenu-new-btn.active {
  box-shadow: none;
}

.publish-submenu-new-btn:hover {
  filter: brightness(1.05);
  box-shadow: 0 8px 18px #1d8f5940;
}

.publish-submenu-subtitle {
  margin: 10px 0 0;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #65708a;
  text-transform: uppercase;
}

.publish-submenu-form {
  margin-top: 10px;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  transition: max-height 0.28s ease, opacity 0.2s ease, transform 0.2s ease;
}

.publish-submenu-form.is-open {
  max-height: 1200px;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.socialmocial-submenu-panel[data-submenu="publish"] .publisher-connect-panel,
.socialmocial-submenu-panel[data-submenu="publish"] #publisher-status {
  display: none !important;
}

.publish-submenu-form h4 {
  margin: 12px 0 8px;
  color: #27334a;
  font-size: 1.25rem;
}

.publish-submenu-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 6px;
}

.publish-submenu-list .empty {
  border: 1px dashed #cfd8e8;
  border-radius: 10px;
  padding: 10px;
  color: #7a859b;
  font-size: 0.84rem;
  background: #f8fbff;
}

.publish-submenu-list button {
  width: 100%;
  border: 1px solid #d4ddeb;
  background: #f7f9fd;
  border-radius: 10px;
  padding: 9px 10px;
  text-align: left;
  color: #32415f;
  cursor: pointer;
  transition: 0.2s ease;
  display: grid;
  gap: 2px;
}

.publish-submenu-list button strong {
  font-size: 0.9rem;
}

.publish-submenu-list button span {
  font-size: 0.78rem;
  color: #6f7891;
}

.publish-submenu-list button.active,
.publish-submenu-list button:hover {
  background: #eaf1ff;
  border-color: #aec2e8;
}

.socialmocial-menu-group h2 {
  margin: 0 0 8px;
  font-size: 0.88rem;
  color: #51596e;
  letter-spacing: 0.04em;
}

.socialmocial-analytics-account-picker {
  display: grid;
  gap: 12px;
  margin: 12px 0 18px;
}

.socialmocial-analytics-account-picker label {
  display: grid;
  gap: 6px;
  font-size: 0.8rem;
  color: #6b7a93;
}

.socialmocial-analytics-account-picker select {
  width: 100%;
  border-radius: 12px;
  border: 1px solid #d3dced;
  padding: 8px 10px;
  background: #ffffff;
  font-size: 0.85rem;
}

.socialmocial-group-subtitle {
  margin: 0 0 8px;
  font-size: 0.78rem;
  color: #7b849a;
  letter-spacing: 0.06em;
}

.socialmocial-account-form {
  display: grid;
  gap: 7px;
  margin-top: 10px;
  margin-bottom: 12px;
}

.socialmocial-sort-controls {
  display: grid;
  gap: 8px;
  margin-top: 10px;
  margin-bottom: 10px;
}

.socialmocial-sort-controls label {
  display: grid;
  gap: 6px;
  font-size: 0.76rem;
  color: #6a738a;
}

.socialmocial-sort-controls select {
  width: 100%;
  border: 1px solid #c7cfdd;
  border-radius: 8px;
  padding: 7px 9px;
  background: #fff;
  color: #4f5872;
}

.socialmocial-account-form.is-collapsed {
  display: none;
}

.socialmocial-account-form select,
.socialmocial-account-form input {
  width: 100%;
  border: 1px solid #84b6eb;
  border-radius: 8px;
  padding: 8px 10px;
  background: #eaf3ff;
}

.socialmocial-account-form select:focus,
.socialmocial-account-form input:focus {
  outline: none;
  border-color: #2f9be8;
  box-shadow: 0 0 0 2px #2f9be833;
}

.socialmocial-check {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #4f5872;
  font-size: 0.85rem;
}

.socialmocial-btn-small {
  width: 100%;
  padding: 8px 10px;
  font-size: 0.84rem;
}

.follow-competitor-toggle {
  width: 100%;
  border: 1px solid #d4ddeb;
  background: #ffffff;
  border-radius: 14px;
  min-height: 44px;
  padding: 10px 12px;
  color: #334155;
  text-align: left;
  font-weight: 700;
  cursor: pointer;
  transition: 0.2s ease;
}

.follow-competitor-toggle:hover,
.follow-competitor-toggle.is-open {
  border-color: #b6ccf7;
  background: #e8f0fe;
}

.follow-competitor-content {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.follow-competitor-content.is-collapsed {
  display: none;
}

.follow-quick-add {
  display: block;
  margin-bottom: 8px;
}

.follow-quick-add input {
  width: 100%;
  border: 1px solid #c8d3e6;
  border-radius: 10px;
  height: 40px;
  padding: 0 12px;
  color: #304264;
  background: #f9fbff;
  outline: none;
}

.follow-quick-add input:focus {
  border-color: #2f9be8;
  box-shadow: 0 0 0 2px #2f9be833;
}

.follow-competitor-content .follow-quick-add,
.follow-competitor-content #account-toggle,
.follow-competitor-content #account-form,
.follow-competitor-content #account-list {
  display: none !important;
}

.socialmocial-menu,
.socialmocial-contact-list,
.socialmocial-account-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.socialmocial-menu li,
.socialmocial-contact-list li {
  margin-bottom: 4px;
}

.socialmocial-account-list li {
  margin-bottom: 6px;
}

.socialmocial-account-list button {
  width: 100%;
  border: 1px solid #d1d9ea;
  background: #f8faff;
  border-radius: 12px;
  padding: 10px 12px;
  text-align: left;
  color: #33405f;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: 0.2s ease;
}

.account-logo {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: inline-grid;
  place-items: center;
  flex-shrink: 0;
  color: #233049;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  box-shadow: 0 6px 14px #0f14271a;
  background: #ffffff;
  border: 1px solid #d7dfec;
  overflow: hidden;
}

.account-logo img {
  width: 22px;
  height: 22px;
  object-fit: contain;
  display: block;
}

.platform-instagram {
  background: #ffffff;
}

.platform-tiktok {
  background: #ffffff;
}

.platform-youtube {
  background: #ffffff;
}

.platform-x {
  background: #ffffff;
}

.platform-linkedin {
  background: #ffffff;
}

.platform-facebook {
  background: #ffffff;
}

.platform-default {
  background: linear-gradient(145deg, #5a6787, #3a4561);
  color: #fff;
  border-color: #5a6787;
}

.account-name {
  display: block;
  min-width: 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: #32415f;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.socialmocial-account-list button.active,
.socialmocial-account-list button:hover {
  background: #eaf1ff;
  border-color: #aec2e8;
  box-shadow: 0 8px 18px #2a4f9d14;
  transform: translateY(-1px);
}

.socialmocial-account-list .empty {
  font-size: 0.84rem;
  color: #7d8597;
  padding: 6px 2px;
}

.socialmocial-tools-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 6px;
}

.socialmocial-tools-list button {
  width: 100%;
  border: 1px solid #d6ddeb;
  background: #f7f9fd;
  border-radius: 8px;
  padding: 9px 10px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: #4f5872;
  text-align: left;
  cursor: pointer;
  transition: 0.18s ease;
}

.socialmocial-tools-list button:hover,
.socialmocial-tools-list button.active {
  background: #dfe7f7;
  border-color: #bfcbe4;
  color: #2e3850;
}

.socialmocial-tools-list .tool-icon {
  width: 20px;
  text-align: center;
}

.socialmocial-menu a {
  display: block;
  text-decoration: none;
  color: #58607a;
  border-radius: 8px;
  padding: 8px 10px;
}

.socialmocial-menu a:hover {
  background: #e8edf7;
}

.socialmocial-menu a.active {
  background: #dfe7f7;
  color: #2b3347;
  font-weight: 600;
}

.socialmocial-contact-list li {
  display: flex;
  align-items: center;
  gap: 9px;
  color: #606883;
  padding: 7px 4px;
}

.dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #7a8cc4;
}

.socialmocial-main {
  min-width: 0;
  position: relative;
  background:
    linear-gradient(#eceaf2, #eceaf2),
    radial-gradient(circle at 25% 25%, #d5d2de 0 1px, transparent 2px) 0 0 / 140px 140px;
  padding: 26px;
}

.socialmocial-main-panel {
  display: none;
}

.socialmocial-main-panel.is-active {
  display: block;
}

.socialmocial-main[data-active-main="follow"] {
  padding: 0;
}

.socialmocial-main[data-active-main="follow"] .socialmocial-main-panel[data-main="follow"] {
  min-height: calc(100vh - 72px);
}

.socialmocial-main[data-active-main="follow"] .socialmocial-main-panel[data-main="follow"] > .socialmocial-section {
  margin-top: 0;
  min-height: 100%;
  border-radius: 0;
}

.socialmocial-main-panel[data-main="publish"] > .socialmocial-section {
  margin-bottom: 12px;
}

.socialmocial-muted {
  color: #6f7891;
}

.socialmocial-view {
  display: none;
}

.socialmocial-view.active {
  display: block;
}

.socialmocial-empty-state {
  min-height: 300px;
  display: grid;
  place-items: center;
  color: #555d73;
  text-align: center;
}

.socialmocial-empty-icon {
  width: 130px;
  height: 130px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 2.2rem;
  background: #ffffff;
  box-shadow: 0 8px 25px #0000001f;
  margin: 0 auto 16px;
}

.socialmocial-card {
  background: #ffffffcc;
  border: 1px solid #d2d9e3;
  border-radius: 14px;
}

.socialmocial-section {
  margin-top: 14px;
  padding: 16px;
}

.socialmocial-title {
  margin: 0 0 10px;
  color: #2f3647;
}

.socialmocial-account-detail p {
  margin: 0 0 8px;
  color: #4b5468;
}

.insight-block {
  margin-bottom: 20px;
}

.insight-block h3 {
  margin: 0 0 10px;
  color: #2f3647;
}

.account-hub-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: minmax(240px, 320px) 1fr;
}

.account-hub-column {
  border: 1px solid #d5ddeb;
  border-radius: 14px;
  background: #f8faff;
  padding: 14px;
}

.account-hub-column h4 {
  margin: 0 0 10px;
  color: #2f3647;
}

.account-hub-column-main {
  background: #ffffff;
}

.account-hub-form {
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
}

.account-hub-form label {
  display: grid;
  gap: 6px;
  color: #4f5872;
  font-size: 0.9rem;
}

.account-hub-form input,
.account-hub-form select {
  width: 100%;
  border: 1px solid #c7d3e8;
  border-radius: 10px;
  min-height: 38px;
  padding: 8px 10px;
  background: #ffffff;
  color: #32415f;
}

.account-hub-form input:focus,
.account-hub-form select:focus {
  outline: none;
  border-color: #2f9be8;
  box-shadow: 0 0 0 2px #2f9be833;
}

.account-hub-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.account-hub-list-btn {
  width: 100%;
  border: 1px solid #d1d9ea;
  border-radius: 12px;
  background: #ffffff;
  padding: 10px 12px;
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 4px;
}

.account-hub-list-btn:hover,
.account-hub-list-btn.active {
  background: #eaf1ff;
  border-color: #aec2e8;
}

.account-hub-list-name {
  color: #273754;
  font-weight: 700;
}

.account-hub-list-meta {
  color: #637089;
  font-size: 0.83rem;
}

.account-hub-empty-item {
  color: #7d8597;
  font-size: 0.87rem;
  padding: 6px 2px;
}

.account-hub-remove-btn {
  white-space: nowrap;
}

.account-inline-form {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(220px, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}

.account-inline-form label {
  display: grid;
  gap: 6px;
  color: #4f5872;
  font-size: 0.9rem;
}

.account-inline-form input {
  width: 100%;
  border: 1px solid #c7d3e8;
  border-radius: 10px;
  min-height: 40px;
  padding: 8px 10px;
  background: #ffffff;
  color: #32415f;
}

.account-inline-form input:focus {
  outline: none;
  border-color: #2f9be8;
  box-shadow: 0 0 0 2px #2f9be833;
}

.account-social-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.account-social-btn {
  border: 1px solid #cbd8ee;
  border-radius: 12px;
  background: #ffffff;
  min-height: 62px;
  padding: 10px 12px;
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 4px;
}

.account-social-btn strong {
  color: #2f3f5e;
  font-size: 0.95rem;
}

.account-social-btn small {
  color: #66748e;
  font-size: 0.78rem;
}

.account-social-btn:hover {
  border-color: #a8c2ee;
  background: #eef4ff;
}

.account-social-btn.is-connected {
  border-color: #2ea44f;
  background: #d8f5df;
}

.account-social-btn.is-connected strong,
.account-social-btn.is-connected small {
  color: #146c2e;
}

.account-social-btn.is-connecting {
  border-color: #e6b253;
  background: #fff7e6;
  cursor: wait;
}

.account-social-btn.is-connecting strong,
.account-social-btn.is-connecting small {
  color: #8a5b10;
}

.account-social-btn:disabled {
  opacity: 0.95;
}

.account-connect-status {
  margin: 0 0 10px;
  color: #4f5872;
}

.account-social-connected-list {
  list-style: none;
  margin: 0 0 10px;
  padding: 0;
  display: grid;
  gap: 8px;
}

.account-social-connected-list li {
  border: 1px solid #d4ddeb;
  border-radius: 10px;
  padding: 8px 10px;
  background: #fbfdff;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
}

.account-social-avatar {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  background: #f1f5f9;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid #e2e8f0;
}

.account-social-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.account-social-avatar span {
  font-weight: 700;
  color: #475569;
}

.account-social-meta {
  display: grid;
  gap: 2px;
}

.account-social-connected-list li strong {
  color: #2f3f5e;
}

.account-social-connected-list li span,
.account-social-connected-list li small {
  color: #65738c;
}

.account-social-empty {
  color: #7b869c;
  font-size: 0.87rem;
}

.manual-connection-badge {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  border-radius: 999px;
  background: #fff7ed;
  color: #c2410c;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.competitor-profile-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
  margin-bottom: 16px;
}

.competitor-profile-card {
  border: 1px solid #dbe4f0;
  border-radius: 16px;
  background: #ffffff;
  padding: 16px;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
}

.competitor-profile-card.premium {
  border-color: rgba(36, 103, 196, 0.22);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}

.competitor-profile-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.competitor-profile-head h4 {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: #24324a;
}

.competitor-profile-head p {
  margin: 4px 0 0;
  color: #6b7280;
  font-size: 0.85rem;
}

.competitor-avatar {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: #f3f4f6;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}

.competitor-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.competitor-profile-bio {
  margin: 8px 0 12px;
  color: #4b5563;
  font-size: 0.88rem;
}

.competitor-profile-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  font-size: 0.82rem;
  color: #6b7280;
}

.competitor-profile-metrics strong {
  color: #111827;
}

.competitor-profile-metrics.premium {
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
}

.competitor-profile-metrics.premium div {
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid #e2e8f3;
  background: #f8fafc;
}

.competitor-profile-metrics.premium small {
  display: block;
  font-size: 0.7rem;
  color: #7a859d;
}

.competitor-profile-metrics.premium strong {
  display: block;
  font-size: 0.92rem;
  color: #1f2a44;
}

.competitor-mini-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid #dbe4f0;
  background: #f8fafc;
  margin-bottom: 14px;
}

.competitor-mini-summary small {
  display: block;
  font-size: 0.72rem;
  color: #7a859d;
  margin-bottom: 4px;
}

.competitor-mini-summary strong {
  font-size: 0.95rem;
  color: #1f2a44;
}

.analytics-block.premium {
  border-color: rgba(36, 103, 196, 0.2);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
}

.analytics-block.premium header h4 {
  font-size: 1.05rem;
}

.competitor-top-post {
  margin-top: 10px;
  padding: 8px 10px;
  border-radius: 12px;
  background: #f8fafc;
  color: #374151;
  font-size: 0.82rem;
}

.competitor-mini-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid #dbe4f0;
  background: #f8fafc;
  margin-bottom: 14px;
}

.competitor-mini-summary small {
  display: block;
  font-size: 0.72rem;
  color: #7a859d;
  margin-bottom: 4px;
}

.competitor-mini-summary strong {
  font-size: 0.95rem;
  color: #1f2a44;
}

.account-inline-hint small {
  color: #6f7891;
}

.platform-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 12px;
}

.platform-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 20px;
  background: #ffffff;
  border: 1px solid #dbe4f0;
  border-radius: 18px;
  transition: 0.2s ease;
}

.platform-card:hover {
  border-color: #c4d2e3;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.05);
}

.platform-card.connected {
  background: #f0fdf4;
  border-color: #86efac;
}

.platform-card.connecting {
  background: #eff6ff;
  border-color: #93c5fd;
}

.platform-left {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.platform-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.platform-icon img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.platform-icon.instagram {
  background: #fff1f2;
  color: #e11d48;
}

.platform-icon.threads {
  background: #f5f3ff;
  color: #4c1d95;
}

.platform-icon.facebook {
  background: #eff6ff;
  color: #2563eb;
}

.platform-icon.x {
  background: #f1f5f9;
  color: #0f172a;
}

.platform-icon.linkedin {
  background: #ecfeff;
  color: #0e7490;
}

.platform-icon.tiktok {
  background: #f8fafc;
  color: #0f172a;
}

.platform-icon.youtube {
  background: #fef2f2;
  color: #dc2626;
}

.platform-title {
  font-size: 18px;
  font-weight: 700;
  color: #24324a;
}

.platform-subtitle {
  margin-top: 6px;
  font-size: 14px;
  color: #64748b;
}

.connect-btn {
  border: 0;
  border-radius: 999px;
  background: #0f172a;
  color: #ffffff;
  padding: 10px 16px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
}

.connect-btn:hover {
  background: #1e293b;
}

.connect-btn.is-loading {
  background: #e2e8f0;
  color: #64748b;
  cursor: wait;
}

.connected-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid #bbf7d0;
  background: #ffffff;
  color: #15803d;
  font-weight: 600;
  cursor: pointer;
}

.tool-transcribe-card {
  border: 1px solid #d7deec;
  border-radius: 14px;
  background: linear-gradient(180deg, #fcfdff, #f6f9ff);
  padding: 16px;
}

.tool-audio-hero {
  border: 1px solid #d7deec;
  border-radius: 18px;
  background: linear-gradient(180deg, #fcfdff, #f5f8ff);
  padding: 28px 22px;
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 14px;
}

.tool-audio-icons {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.tool-audio-tile {
  width: 58px;
  height: 58px;
  border: 2px solid #273147;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: #ffffff;
  color: #202b41;
  font-size: 1.7rem;
  transform: rotate(-6deg);
  box-shadow: 3px 4px 0 #0d111a;
}

.tool-audio-tile.active {
  transform: rotate(0deg);
  color: #667de8;
}

.tool-audio-hero h3 {
  margin: 0;
  color: #111827;
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: 1.03;
  letter-spacing: -0.02em;
}

.tool-audio-options {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 24px;
}

.tool-audio-options label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #2a3349;
  font-size: 1rem;
}

.tool-audio-options input {
  width: 18px;
  height: 18px;
}

.tool-audio-record-btn {
  margin-top: 2px;
  width: min(520px, 100%);
  border: 0;
  border-radius: 16px;
  padding: 18px 22px;
  background: linear-gradient(180deg, #f15a4a, #e54f40);
  color: #ffffff;
  font-size: 1.7rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  cursor: pointer;
  box-shadow: 0 16px 30px #db4f4738;
}

.tool-audio-record-btn.is-recording {
  background: linear-gradient(180deg, #161f31, #0d1422);
}

.tool-audio-record-btn:disabled {
  cursor: not-allowed;
  opacity: 0.7;
}

.tool-audio-timer {
  margin: -8px 0 0;
  color: #6a7690;
  font-weight: 700;
  letter-spacing: 0.08em;
  font-variant-numeric: tabular-nums;
}

.tool-transcribe-subtitle {
  margin: 0 0 12px;
  color: #64718b;
}

.tool-transcribe-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
}

.tool-transcribe-form input {
  width: 100%;
  border: 1px solid #c7d1e4;
  border-radius: 12px;
  padding: 11px 12px;
  background: #ffffff;
  color: #2d3a54;
}

.tool-transcribe-platforms {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.tool-transcribe-platforms span {
  border: 1px solid #d4ddeb;
  border-radius: 999px;
  background: #f2f6ff;
  color: #4a5a79;
  font-size: 0.76rem;
  padding: 4px 9px;
}

.tool-transcribe-status {
  margin: 10px 0 0;
  color: #61708d;
  font-size: 0.86rem;
}

.tool-transcribe-status.success {
  color: #0a8c5f;
}

.tool-transcribe-status.error {
  color: #c43a55;
}

.tool-transcribe-meta {
  margin-top: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: center;
  color: #4f5b74;
  font-size: 0.84rem;
}

.tool-transcribe-meta a {
  color: #2f74d0;
  text-decoration: none;
  border-bottom: 1px dashed #2f74d0aa;
}

.tool-transcribe-output {
  margin-top: 10px;
  display: grid;
  gap: 6px;
}

.tool-transcribe-output span {
  font-size: 0.84rem;
  color: #59657f;
}

.tool-transcribe-output textarea {
  width: 100%;
  border: 1px solid #cfd8e8;
  border-radius: 12px;
  background: #ffffff;
  color: #2f3950;
  padding: 12px;
  resize: vertical;
  min-height: 220px;
}

.tool-transcribe-actions {
  margin-top: 8px;
  display: flex;
  justify-content: flex-end;
}

.tool-download-link {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}

.tool-meeting-card {
  border: 1px solid #d7deec;
  border-radius: 16px;
  background: linear-gradient(180deg, #fcfdff, #f6f9ff);
  padding: 16px;
}

.tool-meeting-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.tool-meeting-form {
  display: grid;
  gap: 10px;
}

.tool-meeting-field {
  display: grid;
  gap: 6px;
}

.tool-meeting-field span {
  color: #56637e;
  font-size: 0.84rem;
}

.tool-meeting-field input,
.tool-meeting-field textarea {
  width: 100%;
  border: 1px solid #cfd8e8;
  border-radius: 12px;
  background: #ffffff;
  color: #2f3950;
  padding: 11px 12px;
}

.tool-meeting-field textarea {
  min-height: 220px;
  resize: vertical;
}

.tool-meeting-options {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
}

.tool-meeting-options label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #2d3851;
  font-size: 0.88rem;
}

.tool-meeting-result {
  border: 1px solid #d6deed;
  border-radius: 12px;
  background: #ffffff;
  min-height: 100%;
  padding: 12px;
}

.tool-meeting-block {
  margin-top: 12px;
}

.tool-meeting-block h4 {
  margin: 0 0 8px;
  color: #2b354d;
}

.tool-meeting-block p {
  margin: 0;
  color: #4a556f;
  line-height: 1.5;
}

.tool-meeting-block ul {
  margin: 0;
  padding-left: 18px;
  color: #4a556f;
  display: grid;
  gap: 6px;
}

.account-sync-row {
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.account-sync-message {
  margin: 0;
  font-size: 0.82rem;
  color: #61708d;
}

.account-sync-message.is-success {
  color: #0a8c5f;
}

.account-sync-message.is-error {
  color: #c43a55;
}

.account-sync-btn {
  white-space: nowrap;
}

.summary-single-card {
  border: 1px solid #d7deec;
  border-radius: 14px;
  background: linear-gradient(180deg, #fcfdff, #f6f9ff);
  padding: 14px;
}

.summary-single-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.summary-single-head h3 {
  margin: 0;
}

.summary-single-grid {
  display: grid;
  grid-template-columns: 1.35fr 1fr;
  gap: 14px;
}

.summary-analysis-list {
  padding: 0;
}

.summary-stats {
  margin-top: 14px;
}

.summary-stats h4 {
  margin: 0 0 10px;
  color: #2f3647;
  font-size: 1.4rem;
}

.metric-grid-minimal article {
  background: #ffffffcf;
}

.insight-top-grid {
  display: grid;
  grid-template-columns: 1.45fr 1fr;
  gap: 14px;
  margin-bottom: 18px;
}

.insight-top-left,
.insight-top-right {
  border: 1px solid #d6ddeb;
  border-radius: 12px;
  padding: 14px;
  background: #f8fafd;
  margin-bottom: 0;
}

.insight-subtitle {
  margin-top: 14px !important;
}

.analysis-list {
  display: grid;
  gap: 10px;
}

.analysis-list p {
  margin: 0;
  color: #4b5468;
  line-height: 1.35;
}

.kv-grid {
  display: grid;
  gap: 8px;
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.metric-grid article {
  border: 1px solid #d6ddeb;
  border-radius: 10px;
  background: #f7f9fd;
  padding: 10px;
}

.metric-grid span {
  display: block;
  color: #6f7891;
  font-size: 0.8rem;
}

.metric-grid strong {
  display: block;
  margin-top: 4px;
  color: #2e3850;
  font-size: 1.1rem;
}

.table-wrap {
  overflow: auto;
  border: 1px solid #d6ddeb;
  border-radius: 10px;
  background: #ffffff;
}

.table-wrap table {
  width: 100%;
  border-collapse: collapse;
  min-width: 920px;
}

.table-wrap-scroll table {
  min-width: 1320px;
}

.table-wrap th,
.table-wrap td {
  border-bottom: 1px solid #e4e8ef;
  text-align: left;
  padding: 8px 10px;
  font-size: 0.84rem;
  color: #4a5368;
  vertical-align: top;
}

.table-wrap th {
  background: #eef3fc;
  color: #33405a;
}

.table-wrap tr:last-child td {
  border-bottom: 0;
}

.note {
  margin: 0;
  color: #6f7891;
  font-size: 0.82rem;
}

.publish-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
}

.publish-top-nav {
  border: 1px solid #d6deec;
  border-radius: 14px;
  background: #eef3fb;
  padding: 5px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 5px;
}

.publish-top-nav button {
  border: 1px solid transparent;
  border-radius: 10px;
  background: transparent;
  color: #60708d;
  font-size: 0.84rem;
  font-weight: 700;
  padding: 9px 12px;
  min-height: 38px;
  cursor: pointer;
  transition: 0.18s ease;
}

.publish-top-nav button:hover {
  background: #f8fbff;
  color: #2f3d58;
}

.publish-top-nav button.active {
  background: #ffffff;
  border-color: #c6d5ec;
  color: #1f2637;
  box-shadow: 0 1px 2px #2a355212;
}

.publish-queue {
  padding: 14px;
}

.publish-queue.is-hidden {
  display: none;
}

.publish-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.publish-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.publish-header h2 {
  margin: 0;
  color: #1f2637;
  font-size: 2rem;
}

.publish-header p {
  margin: 4px 0 0;
  color: #8a94aa;
}

.publish-primary {
  border: 0;
  border-radius: 10px;
  padding: 11px 14px;
  background: #060d22;
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.publish-tabs {
  margin-top: 12px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  background: #dfe4ec;
  border-radius: 10px;
  padding: 6px;
}

.publish-tabs button {
  border: 0;
  background: transparent;
  border-radius: 8px;
  padding: 8px 10px;
  color: #54607a;
  font-weight: 600;
  cursor: pointer;
}

.publish-tabs button.active {
  background: #fff;
  color: #1f2637;
}

.publish-badge {
  margin-left: 8px;
  background: #ef4d4d;
  color: #fff;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 0.72rem;
}

.publish-filter-row {
  margin-top: 16px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
}

.publish-chip {
  border: 1px solid #a6bbe0;
  background: #eff4ff;
  color: #2b3856;
  border-radius: 10px;
  padding: 9px 12px;
  font-weight: 600;
}

.publish-filter-row p {
  margin: 0;
  color: #8c95ab;
  font-size: 0.9rem;
}

.publish-outline {
  border: 1px solid #c8d1e2;
  border-radius: 999px;
  background: #f9fbff;
  color: #606e8a;
  padding: 8px 13px;
}

.publish-outline.danger {
  border-color: rgba(220, 38, 38, 0.25);
  color: #b42318;
  background: #fff5f5;
}

.publish-outline.danger:hover {
  border-color: rgba(220, 38, 38, 0.5);
  color: #991b1b;
}

.publish-view-toggle {
  margin-top: 12px;
  display: inline-grid;
  grid-auto-flow: column;
  gap: 6px;
  border: 1px solid #d6deec;
  border-radius: 11px;
  background: #eef3fb;
  padding: 4px;
}

.publish-view-toggle button {
  border: 1px solid transparent;
  background: transparent;
  color: #617191;
  font-weight: 700;
  font-size: 0.82rem;
  border-radius: 8px;
  padding: 8px 12px;
  min-width: 118px;
  cursor: pointer;
  transition: 0.16s ease;
}

.publish-view-toggle button:hover {
  background: #f9fbff;
  color: #2f3f5f;
}

.publish-view-toggle button.active {
  background: #ffffff;
  color: #1f2637;
  border-color: #c7d5eb;
}

.publish-schedule-view {
  display: none;
  margin-top: 12px;
}

.publish-schedule-view.is-active {
  display: block;
}

.publish-tab-panel {
  display: none;
  margin-top: 14px;
}

.publish-tab-panel.is-active {
  display: block;
}

.publish-day {
  margin-bottom: 18px;
}

.publish-day-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

.publish-day h3 {
  margin: 0;
  color: #1f2637;
}

.publish-day-head small {
  color: #7081a3;
  font-size: 0.78rem;
  font-weight: 600;
}

.publish-day ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 7px;
}

.publish-day li {
  border: 1px solid #d8dfeb;
  background: #edf2f9;
  border-radius: 12px;
  min-height: 38px;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0 12px;
}

.publish-day li span {
  min-width: 70px;
  color: #1f2637;
}

.publish-slot-time-btn {
  min-width: 70px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 2px 6px;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  color: #1f2637;
  font: inherit;
  line-height: 1.2;
  text-align: left;
  cursor: pointer;
}

.publish-slot-time-btn:hover {
  color: #2b5dbc;
  border-color: #c7d8f4;
  background: #f8fbff;
}

.publish-slot-time-btn:focus-visible {
  outline: 2px solid #9abcf4;
  outline-offset: 2px;
  border-radius: 8px;
}

.publish-slot-time-btn small {
  font-size: 0.68rem;
  font-weight: 700;
  color: #6e7f9f;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.publish-slot-time-input {
  min-width: 110px;
  max-width: 128px;
  border: 1px solid #9abcf4;
  border-radius: 9px;
  background: #ffffff;
  color: #1f2637;
  font: inherit;
  padding: 5px 8px;
}

.publish-slot {
  transition: border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease;
}

.publish-slot.is-drop-target {
  border-color: #4e8eea;
  background: #e6f0ff;
  box-shadow: inset 0 0 0 1px rgba(78, 142, 234, 0.28);
}

.publish-day li em {
  color: #8a94aa;
  font-size: 0.9rem;
}

.publish-slot.has-posts {
  align-items: flex-start;
  padding: 10px 12px;
}

.publish-slot-posts {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 8px;
  width: auto;
  flex: 1 1 auto;
  max-width: min(100%, 460px);
}

.publish-calendar-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 10px;
}

.publish-schedule-view[data-queue-view-panel="calendar"] {
  overflow-x: auto;
}

.publish-calendar-month-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.publish-calendar-month-head h4 {
  margin: 0;
  color: #1f2637;
  font-size: 1.02rem;
}

.publish-calendar-nav {
  border: 1px solid #cfd9ea;
  background: #ffffff;
  color: #2f4672;
  border-radius: 10px;
  width: 32px;
  height: 32px;
  display: inline-grid;
  place-items: center;
  font-size: 0.95rem;
  cursor: pointer;
}

.publish-calendar-nav:hover {
  background: #f4f8ff;
  border-color: #a9c0e6;
}

.publish-calendar-weekdays {
  min-width: 860px;
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 8px;
}

.publish-calendar-weekdays span {
  text-align: center;
  color: #6c7d9d;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.publish-calendar-month-grid {
  min-width: 860px;
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

.publish-calendar-cell {
  border: 1px solid #dbe3f0;
  border-radius: 10px;
  background: #ffffff;
  min-height: 122px;
  padding: 8px;
  display: grid;
  align-content: start;
  gap: 6px;
}

.publish-calendar-cell.is-outside {
  background: #f7f9fc;
}

.publish-calendar-cell.is-today {
  border-color: #8eb1ea;
  box-shadow: inset 0 0 0 1px rgba(98, 149, 226, 0.2);
}

.publish-calendar-cell header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}

.publish-calendar-cell header strong {
  color: #24304a;
  font-size: 0.86rem;
}

.publish-calendar-cell header span {
  color: #6783b3;
  background: #ecf3ff;
  border: 1px solid #d4e1f7;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 1px 6px;
}

.publish-calendar-cell-posts {
  display: grid;
  gap: 5px;
}

.publish-calendar-item {
  border: 1px solid #d5deed;
  background: #f7faff;
  color: #25314b;
  border-radius: 8px;
  padding: 4px 6px;
  display: grid;
  gap: 2px;
  text-align: left;
  cursor: pointer;
}

.publish-calendar-item:hover {
  background: #edf4ff;
  border-color: #b8ccec;
}

.publish-calendar-item small {
  color: #5470a2;
  font-size: 0.66rem;
  font-weight: 700;
}

.publish-calendar-item span {
  color: #283246;
  font-size: 0.72rem;
  font-weight: 600;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.publish-calendar-empty-mini {
  margin: 0;
  color: #90a0bb;
  font-size: 0.72rem;
}

.publish-calendar-more {
  margin: 0;
  color: #5f74a0;
  font-size: 0.7rem;
  font-weight: 700;
}

.publish-calendar-day {
  border: 1px solid #d7dfeb;
  border-radius: 12px;
  background: #ffffff;
  padding: 10px;
  display: grid;
  gap: 8px;
}

.publish-calendar-day header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}

.publish-calendar-day h4 {
  margin: 0;
  color: #1f2637;
  font-size: 1rem;
}

.publish-calendar-day header span {
  color: #7183a6;
  font-size: 0.78rem;
  font-weight: 700;
}

.publish-calendar-posts {
  display: grid;
  gap: 8px;
}

.publish-calendar-post {
  position: relative;
  border: 1px solid #dbe4f2;
  border-radius: 10px;
  background: #f8fbff;
  padding: 8px 10px;
  display: grid;
  gap: 2px;
}

.publish-calendar-post small {
  color: #5470a2;
  font-size: 0.74rem;
  font-weight: 700;
}

.publish-calendar-post strong {
  color: #25314a;
  font-size: 0.9rem;
}

.publish-calendar-post span,
.publish-calendar-post em {
  color: #65718a;
  font-size: 0.76rem;
  font-style: normal;
}

.publish-calendar-edit {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 24px;
  height: 24px;
  border: 1px solid #c8d5ec;
  border-radius: 8px;
  background: #ffffff;
  color: #35558f;
  font-size: 0.9rem;
  line-height: 1;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
}

.publish-calendar-edit:hover {
  background: #f0f6ff;
  border-color: #9fb8e3;
}

.publish-calendar-empty {
  margin: 0;
  border: 1px dashed #d8e1f0;
  border-radius: 10px;
  background: #fbfdff;
  color: #8a95ac;
  padding: 14px 10px;
  text-align: center;
  font-size: 0.86rem;
}

.queue-mini-post {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  border: 1px solid #d2dbee;
  background: #ffffff;
  border-radius: 12px;
  padding: 8px;
  position: relative;
  width: min(100%, 320px);
  max-width: 320px;
}

.queue-mini-post[draggable="true"] {
  cursor: grab;
}

.queue-mini-post.is-dragging {
  opacity: 0.55;
  border-style: dashed;
}

.queue-mini-edit {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 24px;
  height: 24px;
  border: 1px solid #c8d5ec;
  border-radius: 8px;
  background: #ffffff;
  color: #35558f;
  font-size: 0.9rem;
  line-height: 1;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
}

.queue-mini-edit:hover {
  background: #f0f6ff;
  border-color: #9fb8e3;
}

.queue-mini-edit:focus-visible {
  outline: 2px solid #9abcf4;
  outline-offset: 1px;
}

.queue-mini-thumb {
  width: 52px;
  height: 52px;
  border-radius: 10px;
  overflow: hidden;
  background: #e8eef8;
  border: 1px solid #d2dbea;
  display: grid;
  place-items: center;
  position: relative;
}

.queue-mini-thumb img,
.queue-mini-thumb video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.queue-mini-fallback {
  color: #5a6a89;
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.queue-mini-type {
  position: absolute;
  right: 4px;
  bottom: 4px;
  border-radius: 999px;
  padding: 1px 5px;
  font-size: 0.58rem;
  font-weight: 700;
  color: #ffffff;
  background: #1b2a46;
}

.queue-mini-meta {
  min-width: 0;
  display: grid;
  gap: 2px;
  padding-right: 24px;
}

.queue-mini-meta strong {
  color: #24314b;
  font-size: 0.92rem;
  line-height: 1.2;
}

.queue-mini-meta small {
  color: #62708c;
  font-size: 0.74rem;
  line-height: 1.2;
}

.publish-past-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}

.publish-past-list li {
  border: 1px solid #d6ddeb;
  border-radius: 12px;
  background: #f8fbff;
  padding: 12px;
  display: grid;
  gap: 4px;
}

.publish-past-list strong {
  color: #1f2637;
}

.publish-past-list span {
  color: #6e7892;
  font-size: 0.88rem;
}

.publish-side {
  padding: 14px;
  position: relative;
}

.publish-side-close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 32px;
  height: 32px;
  border: 1px solid #c5cfde;
  border-radius: 8px;
  background: #ecf1f8;
  color: #5e6a84;
}

.publish-side h3 {
  margin: 0 0 10px;
  color: #1f2637;
}

.publish-side-note {
  margin: 0 0 12px;
  color: #6f7891;
  font-size: 0.9rem;
}

.publisher-field {
  display: grid;
  gap: 6px;
  margin-bottom: 12px;
}

.publisher-field span {
  font-size: 0.82rem;
  color: #61708d;
}

.publisher-field input {
  border: 1px solid #c9d3e4;
  border-radius: 10px;
  height: 40px;
  padding: 0 11px;
  color: #2f3f5f;
  background: #f9fbff;
}

.publish-dropzone {
  border: 1px dashed #c8d2e4;
  border-radius: 10px;
  min-height: 84px;
  padding: 10px;
  display: grid;
  place-items: center;
  text-align: center;
  color: #7a849b;
  background: #f7faff;
}

.publish-side h4 {
  margin: 16px 0 10px;
  color: #1f2637;
}

.publisher-channel-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.publisher-channel-pills button {
  border: 1px solid #c6d3e7;
  background: #eff4ff;
  color: #2f4468;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 0.82rem;
  cursor: pointer;
}

.publisher-channel-pills button.active {
  border-color: #2f9be8;
  background: #2f9be8;
  color: #fff;
}

.publisher-connect-panel {
  border: 1px dashed #c7d3e8;
  border-radius: 12px;
  padding: 10px;
  margin-top: 10px;
  margin-bottom: 10px;
  background: #f8fbff;
  display: grid;
  gap: 9px;
}

.publisher-connect-panel.is-collapsed {
  display: none;
}

.publisher-connect-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.publisher-connect-head strong {
  color: #243555;
  font-size: 0.95rem;
}

.publisher-connect-head button {
  border: 1px solid #d2dbee;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: #fff;
  color: #6f7891;
  cursor: pointer;
}

.publisher-connect-note {
  margin: 0;
  color: #64718b;
  font-size: 0.82rem;
}

.publisher-connect-permissions {
  display: grid;
  gap: 6px;
}

.publisher-connect-permissions label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #4a5876;
  font-size: 0.82rem;
}

.publisher-connect-actions {
  display: flex;
  justify-content: flex-start;
}

.publisher-pending-accounts {
  border: 1px dashed #cfd8e8;
  border-radius: 10px;
  padding: 10px;
  background: #ffffff;
  display: grid;
  gap: 8px;
}

.publisher-pending-accounts.is-empty {
  color: #7a859b;
  font-size: 0.84rem;
}

.publisher-pending-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 6px;
}

.publisher-pending-list li label {
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid #d5dceb;
  border-radius: 10px;
  padding: 8px;
  cursor: pointer;
  background: #f8fbff;
}

.publisher-pending-list li label:hover {
  border-color: #b6c6e1;
}

.publisher-pending-list li input[type="radio"] {
  margin: 0;
}

.publisher-pending-account-meta {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.publisher-pending-account-meta strong,
.publisher-pending-account-meta small {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.publisher-pending-account-meta small {
  color: #6f7891;
}

.publisher-channel-list {
  list-style: none;
  margin: 12px 0 8px;
  padding: 0;
  display: grid;
  gap: 8px;
}

.publisher-channel-list .empty {
  border: 1px dashed #cfd8e8;
  border-radius: 10px;
  padding: 10px;
  color: #7a859b;
  font-size: 0.85rem;
  background: #f8fbff;
}

.publisher-channel-item {
  border: 1px solid #d4ddeb;
  border-radius: 10px;
  padding: 9px;
  display: grid;
  gap: 8px;
  background: #f8fbff;
}

.publisher-channel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: #2f3f5f;
  font-weight: 600;
}

.publisher-channel-main {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.publisher-channel-title {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.publisher-channel-title strong,
.publisher-channel-title small {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.publisher-channel-title small {
  color: #6f7891;
  font-weight: 500;
}

.publisher-channel-actions {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.publisher-channel-reconnect {
  border: 1px solid #c7d3e8;
  border-radius: 999px;
  background: #ffffff;
  color: #3f557c;
  font-size: 0.74rem;
  font-weight: 600;
  padding: 4px 8px;
  cursor: pointer;
}

.publisher-channel-head button[data-remove-channel] {
  border: 0;
  background: transparent;
  color: #8c98b0;
  font-size: 1.1rem;
  cursor: pointer;
}

.publisher-channel-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.publisher-channel-badge {
  border: 1px solid #cbd5e6;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 0.72rem;
  color: #587096;
  background: #ffffff;
}

.publisher-channel-badge.success {
  border-color: #86c89a;
  color: #1f6a37;
  background: #ebf8ee;
}

.publisher-channel-note {
  margin: 0;
  color: #697792;
  font-size: 0.78rem;
  line-height: 1.35;
}

.publisher-status {
  margin: 0;
  min-height: 20px;
  color: #6f7891;
  font-size: 0.84rem;
}

.publisher-status.success {
  color: #0a8c5f;
}

.publisher-status.error {
  color: #d22f52;
}

#compose-status {
  display: none;
  min-height: 0;
  border-radius: 12px;
  border: 1px solid transparent;
  padding: 10px 12px;
  font-size: 0.86rem;
  line-height: 1.4;
  font-weight: 600;
  color: #53617d;
  background: #f3f6fb;
}

#compose-status:not(:empty) {
  display: block;
}

#compose-status.success {
  color: #1e6a3b;
  background: #edf9f2;
  border-color: #b8e3c7;
}

#compose-status.error {
  color: #b32345;
  background: #fff1f4;
  border-color: #f3c1ce;
}

.socialmocial-toast {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 2500;
  width: min(440px, calc(100vw - 28px));
  border-radius: 14px;
  border: 1px solid #b8e3c7;
  background: #edf9f2;
  color: #1f6a37;
  box-shadow: 0 14px 34px rgba(34, 57, 93, 0.2);
  padding: 12px 14px;
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.35;
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  transition: opacity 0.22s ease, transform 0.22s ease;
}

.socialmocial-toast.error {
  border-color: #f3c1ce;
  background: #fff1f4;
  color: #b32345;
}

.socialmocial-toast.is-show {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 720px) {
  .socialmocial-toast {
    right: 12px;
    bottom: 12px;
    width: calc(100vw - 24px);
  }
}

.publisher-save {
  width: 100%;
  margin-top: 4px;
}

.export-card {
  border: 1px solid #d6ddeb;
  border-radius: 12px;
  background: #fbfdff;
  padding: 10px;
  margin-bottom: 10px;
  display: grid;
  gap: 8px;
}

.export-card img {
  width: 100%;
  border-radius: 10px;
  object-fit: cover;
}

.export-card strong {
  color: #1f2637;
}

.export-card span {
  color: #6e7892;
  font-size: 0.86rem;
}

.export-card button {
  border: 1px solid #c3d0e8;
  background: #eff5ff;
  color: #2f4061;
  border-radius: 10px;
  padding: 8px 10px;
  font-weight: 600;
}

.publish-side.is-collapsed {
  display: none;
}

.publish-composer-modal {
  position: relative;
  inset: auto;
  z-index: 1;
  display: none;
  margin-top: 14px;
}

.publish-composer-modal.is-open {
  display: block;
}

.publish-composer-backdrop {
  display: none;
}

.publish-composer-dialog {
  position: relative;
  width: 100%;
  max-height: none;
  margin: 0;
  border: 1px solid #cfd8e8;
  border-radius: 18px;
  background: #f6f9ff;
  box-shadow: 0 32px 76px #00000040;
  overflow: visible;
}

.publish-composer-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 18px 12px;
  border-bottom: 1px solid #d7dfee;
  background: linear-gradient(180deg, #ffffff, #f7f9ff);
}

.publish-composer-header h3 {
  margin: 0;
  color: #1f2637;
  font-size: 1.8rem;
}

.publish-composer-header p {
  margin: 4px 0 0;
  color: #6e7992;
}

.publish-composer-grid {
  padding: 16px;
  display: grid;
  grid-template-columns: 380px minmax(0, 1fr);
  gap: 14px;
}

.publish-composer-left,
.publish-composer-right {
  border: 1px solid #d4ddec;
  border-radius: 16px;
  background: #ffffff;
  padding: 14px;
}

.compose-dropzone {
  position: relative;
  border: 1px dashed #a9b9d8;
  border-radius: 16px;
  min-height: 540px;
  background: linear-gradient(180deg, #f8fbff, #f0f5ff);
  display: grid;
  place-items: center;
  text-align: center;
  padding: 14px;
  cursor: pointer;
}

.compose-clear-asset {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 38px;
  height: 38px;
  border: 1px solid #c4d4f0;
  border-radius: 999px;
  background: #ffffffd9;
  color: #465777;
  font-size: 1rem;
  display: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 2;
}

.compose-clear-asset:hover {
  background: #eef4ff;
  border-color: #9ab5e9;
  color: #2c4268;
}

.compose-clear-asset:focus-visible {
  outline: 2px solid #8db4ff;
  outline-offset: 2px;
}

.compose-dropzone.has-asset .compose-clear-asset {
  display: inline-flex;
}

.compose-dropzone.is-dragging {
  border-color: #2f9be8;
  background: #e8f2ff;
}

.compose-drop-placeholder {
  display: grid;
  gap: 6px;
  color: #61708d;
}

.compose-drop-placeholder strong {
  color: #27334a;
  font-size: 1.2rem;
}

.compose-preview {
  width: 100%;
  display: none;
}

.compose-preview.is-ready {
  display: block;
}

.compose-preview img,
.compose-preview video {
  width: 100%;
  border-radius: 12px;
  border: 1px solid #d4ddec;
  object-fit: cover;
  max-height: 640px;
  background: #0b1020;
}

.compose-asset-meta {
  margin-top: 10px;
}

.compose-asset-meta strong {
  color: #1f2637;
  font-size: 1rem;
}

.compose-asset-meta p {
  margin: 5px 0 0;
  color: #6b7690;
}

.compose-field-grid {
  display: grid;
  grid-template-columns: minmax(170px, 220px) minmax(0, 1fr);
  gap: 10px;
}

.compose-field-grid label,
.compose-field {
  display: grid;
  gap: 6px;
}

.compose-field-grid span,
.compose-field span {
  font-size: 0.8rem;
  color: #61708d;
  font-weight: 600;
}

.compose-field-grid select,
.compose-field-grid input,
.compose-field select,
.compose-field input,
.compose-field textarea,
.platform-setting-card input,
.platform-setting-card select,
.platform-setting-card textarea {
  width: 100%;
  border: 1px solid #c8d3e6;
  border-radius: 10px;
  padding: 10px 12px;
  color: #304264;
  background: #f9fbff;
  outline: none;
}

.compose-field-grid select:focus,
.compose-field-grid input:focus,
.compose-field select:focus,
.compose-field input:focus,
.compose-field textarea:focus,
.platform-setting-card input:focus,
.platform-setting-card select:focus,
.platform-setting-card textarea:focus {
  border-color: #2f9be8;
  box-shadow: 0 0 0 2px #2f9be82f;
}

.compose-section {
  margin-top: 14px;
  border: 1px solid #d7e0ee;
  border-radius: 12px;
  padding: 12px;
  background: #f8fbff;
}

.compose-network-section {
  margin-top: 0;
}

.compose-section-head h4,
.compose-section h4 {
  margin: 0;
  color: #1f2637;
}

.compose-section-head p {
  margin: 4px 0 0;
  color: #71809c;
  font-size: 0.84rem;
}

.compose-channel-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.compose-channel-empty {
  margin-top: 10px;
  border: 1px dashed #c8d2e3;
  border-radius: 10px;
  padding: 10px;
  color: #6f7891;
  font-size: 0.86rem;
  background: #fff;
}

.compose-channel-item {
  border: 1px solid #c9d4e8;
  border-radius: 12px;
  background: #fff;
  padding: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: 0.2s ease;
  text-align: left;
}

.compose-channel-item strong {
  display: block;
  color: #253149;
  font-size: 0.9rem;
}

.compose-channel-text {
  min-width: 0;
}

.compose-channel-handle {
  display: block;
  color: #77839d;
  font-size: 0.77rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.compose-channel-item.active {
  border-color: #2f9be8;
  background: #eaf4ff;
  box-shadow: 0 8px 20px #2f9be81f;
}

.compose-platform-tabs {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.compose-platform-tab {
  border: 1px solid #c9d4e8;
  border-radius: 12px;
  background: #ffffff;
  color: #324667;
  min-height: 56px;
  padding: 8px 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  cursor: pointer;
  transition: 0.2s ease;
  text-align: center;
}

.compose-platform-tab .account-logo {
  width: 24px;
  height: 24px;
}

.compose-platform-tab-name {
  font-weight: 600;
  font-size: 0.86rem;
}

.compose-platform-tab.is-selected {
  border-color: #2f9e44;
  color: #1b5e20;
}

.compose-platform-tab.is-active {
  background: #e8f7ec;
  box-shadow: 0 8px 20px #2f9e441f;
}

.compose-platform-tab.is-unavailable {
  border-style: dashed;
  border-color: #cfd8e8;
  background: #f8fbff;
  color: #637391;
}

.compose-platform-tab.is-unavailable:hover {
  border-color: #b8c6df;
  background: #f3f7fd;
}

.compose-platform-note {
  margin: 0;
  border: 1px dashed #c8d2e3;
  border-radius: 10px;
  padding: 10px;
  color: #5f6f8c;
  font-size: 0.83rem;
  background: #fff;
}

.compose-platform-settings {
  margin-top: 10px;
  display: grid;
  gap: 9px;
}

.platform-setting-card {
  border: 1px solid #ced9eb;
  border-radius: 12px;
  padding: 10px;
  background: #fff;
  display: grid;
  gap: 9px;
}

.platform-setting-head {
  display: flex;
  align-items: center;
  gap: 8px;
}

.platform-setting-head strong {
  color: #1f2637;
}

.platform-setting-head small {
  margin-left: auto;
  color: #7484a0;
  font-size: 0.76rem;
  font-weight: 600;
}

.platform-setting-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.platform-switch-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.platform-switch-row label {
  border: 1px solid #ccd7ea;
  border-radius: 999px;
  background: #f7faff;
  color: #42516e;
  padding: 6px 10px;
  font-size: 0.8rem;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.platform-thumbnail-field {
  display: grid;
  gap: 8px;
}

.platform-thumbnail-title {
  font-size: 0.9rem;
  color: #1f2637;
  font-weight: 700;
}

.platform-thumbnail-grid {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 10px;
}

.platform-thumbnail-preview {
  min-height: 122px;
  border: 1px dashed #c8d2e3;
  border-radius: 10px;
  background: #f8fbff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #8a98b1;
  font-size: 0.86rem;
  padding: 10px;
}

.platform-thumbnail-preview img {
  width: 100%;
  max-height: 118px;
  border-radius: 8px;
  object-fit: cover;
}

.platform-thumbnail-upload {
  min-height: 122px;
  border: 1px dashed #c8d2e3;
  border-radius: 10px;
  background: #f8fbff;
  color: #657693;
  font-size: 0.9rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px;
  text-align: center;
  cursor: pointer;
}

.platform-thumbnail-upload input[type="file"] {
  display: none;
}

.platform-thumbnail-upload strong {
  color: #324d74;
}

.platform-thumbnail-upload:hover {
  border-color: #a7bfdc;
  background: #f3f8ff;
}

.platform-thumbnail-upload-icon {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: #e3f4e9;
  color: #24a55d;
  font-size: 1.15rem;
  line-height: 32px;
  font-weight: 800;
}

.platform-thumb-note {
  margin: 0;
  color: #6f7f9a;
  font-size: 0.82rem;
}

.platform-thumb-warning {
  margin: 0;
  color: #7b6a23;
  font-size: 0.82rem;
}

.platform-setting-copy {
  margin: 0;
  color: #6e7f9d;
  font-size: 0.84rem;
  line-height: 1.45;
}

.platform-setting-copy strong {
  color: #2f4364;
}

.platform-inline-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.platform-inline-head span {
  font-size: 0.94rem;
  font-weight: 700;
  color: #1f2637;
}

.platform-ghost-btn {
  border: 1px solid #cad6ea;
  border-radius: 10px;
  background: #f8fbff;
  color: #344869;
  font-weight: 700;
  font-size: 0.8rem;
  line-height: 1;
  padding: 8px 11px;
  cursor: pointer;
}

.platform-ghost-btn:hover {
  border-color: #a9c0e8;
  background: #eef4ff;
}

.platform-allow-users {
  display: grid;
  gap: 8px;
}

.platform-allow-users > span {
  font-size: 0.95rem;
  font-weight: 700;
  color: #1f2637;
}

.platform-toggle-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.platform-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #5a6b89;
  font-size: 0.88rem;
}

.platform-toggle input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.platform-toggle-ui {
  width: 42px;
  height: 24px;
  border-radius: 999px;
  background: #d3dceb;
  border: 1px solid #ccd5e6;
  position: relative;
  transition: background 0.2s ease, border-color 0.2s ease;
}

.platform-toggle-ui::after {
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #ffffff;
  position: absolute;
  top: 2px;
  left: 2px;
  box-shadow: 0 1px 3px #00000024;
  transition: transform 0.2s ease;
}

.platform-toggle input:checked + .platform-toggle-ui {
  background: #34b56d;
  border-color: #34b56d;
}

.platform-toggle input:checked + .platform-toggle-ui::after {
  transform: translateX(18px);
}

.platform-toggle-compact {
  margin-left: 10px;
}

.platform-feature-row {
  border: 1px solid #dde4f1;
  border-radius: 12px;
  background: #f9fbff;
  padding: 10px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.platform-feature-copy {
  display: grid;
  gap: 4px;
}

.platform-feature-copy strong {
  color: #1f2637;
  font-size: 0.95rem;
}

.platform-feature-copy p {
  margin: 0;
  color: #7a89a4;
  font-size: 0.8rem;
  line-height: 1.4;
}

.platform-setting-note {
  margin: 0;
  color: #7a89a4;
  font-size: 0.79rem;
  line-height: 1.45;
}

.platform-cover-frame {
  display: grid;
  gap: 8px;
}

.platform-cover-frame > span {
  color: #1f2637;
  font-size: 0.92rem;
  font-weight: 700;
}

.platform-cover-frame-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
}

.platform-cover-frame-row input[type="range"] {
  accent-color: #34b56d;
  padding: 0;
}

.platform-cover-frame-row output {
  min-width: 48px;
  text-align: right;
  color: #55709c;
  font-size: 0.82rem;
  font-weight: 700;
}

.publish-composer-actions {
  margin-top: 12px;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.queue-modal {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: none;
}

.queue-modal.is-open {
  display: block;
}

.queue-modal-backdrop {
  position: absolute;
  inset: 0;
  background: #101722b3;
  backdrop-filter: blur(2px);
}

.queue-modal-dialog {
  position: relative;
  width: min(1120px, calc(100% - 40px));
  max-height: calc(100vh - 40px);
  overflow: auto;
  margin: 20px auto;
  border: 1px solid #cfd7e5;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 26px 70px #0000003d;
  padding: 18px;
}

.queue-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}

.queue-modal-header h3 {
  margin: 0;
  font-size: 2rem;
  color: #1f2637;
}

.queue-modal-header p {
  margin: 4px 0 0;
  color: #72819a;
}

.queue-close-btn {
  width: 36px;
  height: 36px;
  border: 1px solid #ccd5e4;
  border-radius: 10px;
  background: #f3f6fc;
  color: #5a6783;
  font-size: 1.05rem;
  cursor: pointer;
}

.queue-toolbar {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: end;
  margin-bottom: 12px;
}

.queue-timezone {
  display: grid;
  gap: 6px;
}

.queue-timezone label {
  font-size: 0.78rem;
  color: #6c7891;
}

.queue-timezone select {
  max-width: 280px;
  border: 1px solid #c4cede;
  border-radius: 10px;
  height: 38px;
  padding: 0 10px;
  color: #465069;
}

.queue-presets {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.queue-presets button {
  border: 1px solid #c7d3e6;
  background: #edf3ff;
  color: #314468;
  border-radius: 10px;
  padding: 7px 10px;
  font-weight: 600;
  cursor: pointer;
}

.queue-table-wrap {
  border: 1px solid #d8dfeb;
  border-radius: 12px;
  overflow: auto;
}

.queue-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 820px;
}

.queue-table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: #edf2fa;
  color: #2f3d59;
  font-size: 0.9rem;
  text-align: center;
  padding: 10px;
  border-bottom: 1px solid #d6ddeb;
}

.queue-table thead th:first-child {
  text-align: left;
  padding-left: 14px;
}

.queue-table tbody td {
  border-bottom: 1px solid #e0e6f0;
  padding: 10px;
  text-align: center;
}

.queue-table tbody tr:last-child td {
  border-bottom: 0;
}

.queue-slot-time {
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: space-between;
  color: #1f2637;
  font-weight: 600;
}

.queue-slot-remove {
  border: 0;
  background: transparent;
  color: #9aa5bb;
  font-size: 1.35rem;
  cursor: pointer;
  line-height: 1;
}

.queue-slot-checkbox {
  width: 18px;
  height: 18px;
}

.queue-add-slot {
  display: flex;
  gap: 10px;
  margin-top: 12px;
}

.queue-add-slot input {
  border: 1px solid #c7d1e0;
  border-radius: 10px;
  padding: 0 10px;
  height: 40px;
  color: #2c3a55;
}

.queue-add-slot button {
  border: 1px solid #c8d3e6;
  background: #eef4ff;
  color: #304264;
  border-radius: 10px;
  padding: 0 14px;
  height: 40px;
  font-weight: 700;
  cursor: pointer;
}

.queue-modal-footer {
  margin-top: 14px;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.socialmocial-stack {
  display: grid;
  gap: 10px;
}

.socialmocial-feed-card {
  background: #f7f9fd;
  border: 1px solid #d7dfec;
  border-radius: 10px;
  padding: 10px;
}

.socialmocial-feed-card strong {
  color: #2f3647;
}

.socialmocial-feed-card p {
  margin: 6px 0 0;
  color: #4c5467;
}

.socialmocial-form {
  display: flex;
  gap: 10px;
}

.socialmocial-form-vertical {
  flex-direction: column;
}

.socialmocial-form input,
.socialmocial-form textarea {
  width: 100%;
  border: 1px solid #c7cfdd;
  border-radius: 10px;
  padding: 10px 12px;
}

.socialmocial-btn {
  border: 1px solid #2f9be8;
  background: #2f9be8;
  color: #fff;
  border-radius: 10px;
  padding: 10px 14px;
  font-weight: 600;
  cursor: pointer;
}

.socialmocial-follow-list {
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.socialmocial-follow-list li {
  border: 1px solid #d7dfec;
  background: #f7f9fd;
  border-radius: 10px;
  padding: 8px 10px;
}

.socialmocial-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.socialmocial-stat {
  border: 1px solid #d7dfec;
  border-radius: 10px;
  background: #f8fafd;
  padding: 12px;
}

.socialmocial-stat span {
  color: #66708a;
}

.socialmocial-stat strong {
  display: block;
  margin-top: 6px;
  font-size: 1.3rem;
  color: #283246;
}

.socialmocial-status {
  min-height: 20px;
  margin-top: 12px;
  color: #5f6981;
}

.socialmocial-status.success {
  color: #008d5c;
}

.socialmocial-status.error {
  color: #d22f52;
}

@media (max-width: 980px) {
  .socialmocial-topbar-right {
    gap: 10px;
    font-size: 0.9rem;
  }

  .socialmocial-layout {
    grid-template-columns: 60px 1fr;
  }

  .socialmocial-main {
    grid-column: span 2;
  }

  .metric-grid {
    grid-template-columns: 1fr;
  }

  .insight-top-grid {
    grid-template-columns: 1fr;
  }

  .publish-shell {
    grid-template-columns: 1fr;
  }

  .publish-composer-grid {
    grid-template-columns: 1fr;
  }

  .compose-dropzone {
    min-height: 300px;
  }

  .account-sync-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .summary-single-grid {
    grid-template-columns: 1fr;
  }

  .feature-metric-grid {
    grid-template-columns: 1fr;
  }

  .analytics-module-grid,
  .analytics-kpi-grid {
    grid-template-columns: 1fr 1fr;
  }

  .monitoring-detail-grid {
    grid-template-columns: 1fr;
  }

  .monitoring-listening-grid,
  .monitoring-watchlist-grid {
    grid-template-columns: 1fr 1fr;
  }

  .social-inbox-workspace {
    grid-template-columns: 1fr;
  }

  .social-inbox-keyword-form {
    grid-template-columns: 1fr 1fr;
  }

  .analytics-filter-bar {
    grid-template-columns: 1fr 1fr;
  }

  .analytics-shell-head {
    grid-template-columns: 1fr;
  }

  .analytics-head-actions {
    justify-items: start;
  }

  .summary-single-head {
    flex-direction: column;
  }

  .tool-transcribe-form {
    grid-template-columns: 1fr;
  }

  .tool-audio-options {
    flex-direction: column;
    align-items: flex-start;
    justify-self: stretch;
  }

  .tool-audio-record-btn {
    font-size: 1.3rem;
    padding: 14px 16px;
  }

  .tool-meeting-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .socialmocial-topbar {
    padding: 0 10px;
  }

  .socialmocial-topbar-left,
  .socialmocial-topbar-right {
    gap: 8px;
  }

  .socialmocial-topbar-brand {
    font-size: 0;
    gap: 0;
  }

  .socialmocial-topbar-logo {
    width: clamp(132px, 42vw, 180px);
    height: 42px;
  }

  .socialmocial-topbar-right strong {
    display: none;
  }

  .socialmocial-layout {
    grid-template-columns: 1fr;
  }

  .socialmocial-rail {
    display: none;
  }

  .socialmocial-sidebar {
    border-right: 0;
    border-bottom: 1px solid #d9dde6;
  }

  .socialmocial-main {
    padding: 14px;
  }

  .socialmocial-stats-grid {
    grid-template-columns: 1fr;
  }

  .compose-field-grid,
  .platform-setting-grid,
  .compose-channel-grid,
  .compose-platform-tabs {
    grid-template-columns: 1fr;
  }

  .platform-thumbnail-grid {
    grid-template-columns: 1fr;
  }

  .publish-view-toggle {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .publish-view-toggle button {
    min-width: 0;
  }

  .publish-calendar-grid {
    grid-template-columns: 1fr;
  }

  .publish-calendar-weekdays,
  .publish-calendar-month-grid {
    min-width: 700px;
  }

  .publish-slot-posts {
    max-width: 100%;
  }

  .queue-mini-post {
    width: 100%;
    max-width: 100%;
  }

  .analytics-module-grid,
  .analytics-kpi-grid,
  .analytics-filter-bar {
    grid-template-columns: 1fr;
  }

  .monitoring-filter-date {
    grid-column: auto;
  }

  .monitoring-filter-actions {
    grid-column: auto;
    justify-content: flex-start;
  }

  .monitoring-watchlist-form,
  .monitoring-keyword-grid,
  .monitoring-listening-grid,
  .monitoring-watchlist-grid,
  .social-inbox-keyword-form {
    grid-template-columns: 1fr;
  }

  .social-inbox-workspace {
    grid-template-columns: 1fr;
  }

  .social-inbox-thread-controls {
    grid-template-columns: 1fr;
  }

  .analytics-date-placeholder {
    grid-template-columns: 1fr;
  }

  .monitoring-mentions-table {
    min-width: 680px;
  }

  .monitoring-mention-drawer {
    width: 100%;
  }

  .publish-composer-dialog {
    width: 100%;
    margin: 0;
    max-height: none;
  }

  .publish-composer-header h3 {
    font-size: 1.3rem;
  }

  .publish-top-nav button {
    font-size: 0.74rem;
    line-height: 1.15;
    min-height: 42px;
    padding: 7px 8px;
  }

  .platform-inline-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .platform-feature-row {
    flex-direction: column;
  }

  .platform-toggle-compact {
    margin-left: 0;
  }
}

/* Gmail-inspired visual system overrides (structure untouched) */
:root {
  --bg: #f6f8fc;
  --panel: #ffffff;
  --panelMuted: #f1f3f4;
  --panelAlt: #fafbff;
  --panelAlt2: #f7f9fc;
  --panelAlt3: #eef2f8;
  --border: #d8dee8;
  --borderSoft: #e7ebf2;
  --text: #202124;
  --textMuted: #5f6368;
  --textSubtle: #80868b;
  --accent: #1a73e8;
  --accentSecondary: #1967d2;
  --success: #188038;
  --danger: #d93025;
  --warning: #f9ab00;
}

html,
body {
  color: var(--text);
  font-family: "Inter", "Google Sans", "IBM Plex Sans", "Avenir Next", sans-serif;
  background: #f1f3f4;
}

.socialmocial-topbar {
  height: 72px;
  background: #f8fafd;
  border-bottom: 1px solid var(--borderSoft);
  padding: 0 18px;
}

.socialmocial-topbar-brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  line-height: 0;
  color: #3c4043;
  font-weight: 600;
  font-size: 0;
}

.socialmocial-topbar-logo {
  display: block;
  width: auto;
  height: 54px;
  max-width: 260px;
  object-fit: contain;
}

.socialmocial-topbar-brand-text {
  display: none;
}

.socialmocial-topbar-left,
.socialmocial-topbar-right {
  gap: 12px;
}

.socialmocial-topbar-pin {
  border: 1px solid #d7deec;
  background: #f8fafc;
  color: #2f3a4a;
}

.socialmocial-icon-btn {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  color: #5f6368;
  transition: background 0.18s ease;
}

.socialmocial-icon-btn:hover {
  background: #e9eef6;
}

.socialmocial-avatar {
  width: 36px;
  height: 36px;
  background: #1a73e8;
  box-shadow: none;
}

.socialmocial-layout {
  grid-template-columns: 64px 231px minmax(0, 1fr);
  min-height: calc(100vh - 72px);
}

.socialmocial-layout.rail-open {
  grid-template-columns: 232px 231px minmax(0, 1fr);
}

.socialmocial-layout.no-submenu {
  grid-template-columns: 64px 0 minmax(0, 1fr);
}

.socialmocial-layout.rail-open.no-submenu {
  grid-template-columns: 232px 0 minmax(0, 1fr);
}

.socialmocial-layout.publish-submenu-right {
  grid-template-columns: 64px minmax(0, 1fr) 231px;
}

.socialmocial-layout.rail-open.publish-submenu-right {
  grid-template-columns: 232px minmax(0, 1fr) 231px;
}

.socialmocial-layout.publish-submenu-right .socialmocial-main {
  order: 2;
}

.socialmocial-layout.publish-submenu-right .socialmocial-sidebar {
  order: 3;
  border-right: 0;
  border-left: 1px solid var(--borderSoft);
}

.socialmocial-layout.publish-submenu-right.publish-submenu-hidden {
  grid-template-columns: 64px minmax(0, 1fr) 0;
}

.socialmocial-layout.rail-open.publish-submenu-right.publish-submenu-hidden {
  grid-template-columns: 232px minmax(0, 1fr) 0;
}

.socialmocial-layout.publish-submenu-right.publish-submenu-hidden .socialmocial-sidebar {
  display: none;
}

.socialmocial-layout.follow-secondary-open {
  grid-template-columns: 64px 231px 236px minmax(0, 1fr);
}

.socialmocial-layout.rail-open.follow-secondary-open {
  grid-template-columns: 232px 231px 236px minmax(0, 1fr);
}

.socialmocial-layout.no-submenu.follow-secondary-open {
  grid-template-columns: 64px 236px minmax(0, 1fr);
}

.socialmocial-layout.rail-open.no-submenu.follow-secondary-open {
  grid-template-columns: 232px 236px minmax(0, 1fr);
}

.socialmocial-layout.accounts-competitors-no-submenu {
  grid-template-columns: 64px minmax(0, 1fr);
}

.socialmocial-layout.rail-open.accounts-competitors-no-submenu {
  grid-template-columns: 232px minmax(0, 1fr);
}

.socialmocial-layout.accounts-competitors-no-submenu .socialmocial-sidebar {
  display: none;
}

.socialmocial-layout.accounts-competitors-no-submenu.follow-secondary-open {
  grid-template-columns: 64px 236px minmax(0, 1fr);
}

.socialmocial-layout.rail-open.accounts-competitors-no-submenu.follow-secondary-open {
  grid-template-columns: 232px 236px minmax(0, 1fr);
}

.socialmocial-secondary-submenu {
  display: none;
  background: #f8f9fb;
  border-right: 1px solid var(--borderSoft);
  overflow-y: auto;
  min-width: 0;
}

.socialmocial-layout.follow-secondary-open .socialmocial-secondary-submenu {
  display: block;
}

.socialmocial-secondary-submenu.is-collapsed {
  display: none;
}

.socialmocial-secondary-submenu-head {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 12px;
  border-bottom: 1px solid var(--borderSoft);
  background: #f8f9fb;
}

.socialmocial-secondary-submenu-head h3 {
  margin: 0;
  font-size: 1rem;
  color: #2f3d58;
}

.socialmocial-secondary-submenu-head button {
  width: 28px;
  height: 28px;
  border: 1px solid #cfd8e8;
  border-radius: 8px;
  background: #ffffff;
  color: #5d6780;
  cursor: pointer;
}

.socialmocial-secondary-submenu-head button:hover {
  border-color: #b2c6ee;
  background: #eef4ff;
}

.socialmocial-secondary-submenu-list {
  list-style: none;
  margin: 0;
  padding: 10px;
  display: grid;
  gap: 8px;
}

.socialmocial-secondary-submenu-actions {
  padding: 10px;
  border-bottom: 1px solid var(--borderSoft);
}

.socialmocial-secondary-submenu-actions button {
  width: 100%;
  min-height: 40px;
  border: 1px solid #2f77dc;
  border-radius: 10px;
  background: #2f77dc;
  color: #ffffff;
  font-weight: 700;
  cursor: pointer;
}

.socialmocial-secondary-submenu-actions {
  display: grid;
  gap: 8px;
}

.socialmocial-secondary-submenu-actions button:hover {
  background: #2467c4;
  border-color: #2467c4;
}

.socialmocial-secondary-submenu-actions button.is-hidden {
  display: none;
}

.socialmocial-secondary-submenu-actions.is-hidden {
  display: none;
}

.socialmocial-secondary-submenu-list button {
  width: 100%;
  border: 1px solid #d3dced;
  border-radius: 12px;
  background: #ffffff;
  padding: 10px;
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 4px;
}

.follow-secondary-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.follow-secondary-row > button[data-follow-secondary-item] {
  flex: 1;
}

.follow-secondary-remove {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  border: 1px solid #dbe4f0;
  background: #ffffff;
  color: #64748b;
  font-size: 16px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: 0.2s ease;
}

.follow-secondary-remove:hover {
  border-color: #cbd5f5;
  color: #1f2937;
  background: #f8fafc;
}

.follow-secondary-remove {
  position: relative;
}

.follow-secondary-remove[data-tooltip]:hover::after {
  content: attr(data-tooltip);
  position: absolute;
  right: 36px;
  top: 50%;
  transform: translateY(-50%);
  background: #1f2937;
  color: #ffffff;
  font-size: 0.72rem;
  padding: 6px 8px;
  border-radius: 8px;
  white-space: nowrap;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.2);
}

.socialmocial-secondary-submenu-list button strong {
  color: #2e3d5a;
  font-size: 0.94rem;
}

.socialmocial-secondary-submenu-list button small {
  color: #687690;
  font-size: 0.78rem;
}

.follow-secondary-platform-icons {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

.follow-secondary-platform-icon {
  width: 22px;
  height: 22px;
  border-radius: 7px;
  border: 1px solid #cfd9eb;
  background: #ffffff;
  display: inline-grid;
  place-items: center;
  overflow: hidden;
  font-size: 0.62rem;
  font-weight: 700;
  color: #334155;
}

.follow-secondary-platform-icon img {
  width: 14px;
  height: 14px;
  object-fit: contain;
}

.follow-secondary-meta {
  margin-top: 6px;
}

.follow-secondary-platform-icons.is-empty {
  font-size: 0.72rem;
  color: #8a94a8;
}

.competitor-filter-head {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid #dbe4f0;
  background: #f8fafc;
}

.competitor-filter-head span {
  display: block;
  font-size: 0.78rem;
  color: #7a859d;
  margin-bottom: 4px;
}

.competitor-filter-head strong {
  font-size: 1rem;
  color: #1f2a44;
}

.competitor-platform-selector {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.competitor-platform-selector button {
  border-radius: 999px;
  border: 1px solid #d3dced;
  background: #ffffff;
  padding: 6px 12px;
  font-size: 0.82rem;
  color: #445068;
  cursor: pointer;
  transition: 0.2s ease;
}

.competitor-platform-selector button.active,
.competitor-platform-selector button:hover {
  border-color: #aec2e8;
  background: #eaf1ff;
  color: #1f2a44;
}

.monitoring-filter-static .monitoring-filter-value {
  margin-top: 6px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid #dbe4f0;
  background: #f8fafc;
  color: #334155;
  font-weight: 600;
  min-height: 42px;
  display: flex;
  align-items: center;
}

.competitor-platform-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
}

.competitor-platform-field,
.competitor-name-field {
  display: grid;
  gap: 6px;
  font-size: 0.86rem;
  color: #64748b;
}

.competitor-platform-field input,
.competitor-name-field input {
  width: 100%;
  border-radius: 12px;
  border: 1px solid #d3dced;
  padding: 10px 12px;
  background: #ffffff;
  font-size: 0.9rem;
}

.socialmocial-secondary-submenu-list button:hover,
.socialmocial-secondary-submenu-list button.active {
  background: #eaf1ff;
  border-color: #aec2e8;
}

.socialmocial-secondary-submenu-empty {
  padding: 8px 4px;
  color: #7a859d;
  font-size: 0.85rem;
}

.socialmocial-rail {
  background: #f8fafd;
  color: #3c4043;
  border-right: 1px solid var(--borderSoft);
}

.socialmocial-layout.rail-open .socialmocial-rail {
  box-shadow: none;
}

.socialmocial-rail-pin {
  top: 10px;
  left: 12px;
  right: auto;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #eef3fb;
  color: #3c4043;
}

.socialmocial-rail-pin:hover,
.socialmocial-rail-pin.active {
  background: #e3ecfa;
  border-color: #b8cbef;
}

.socialmocial-rail ul {
  margin-top: 8px;
}

.socialmocial-rail nav {
  padding-top: 52px;
}

.socialmocial-rail li {
  height: 40px;
  margin: 2px 6px;
  border-left: 0;
  border-radius: 0 18px 18px 0;
  padding: 0 14px;
  color: #3c4043;
}

.socialmocial-rail li::after {
  color: #3c4043;
  font-weight: 500;
  font-size: 0.9rem;
}

.socialmocial-rail li.active,
.socialmocial-rail li:hover {
  background: #e8f0fe;
  border-left-color: transparent;
  color: #1967d2;
}

.socialmocial-sidebar {
  background: #f8fafd;
  border-right: 1px solid var(--borderSoft);
}

.socialmocial-search-row {
  height: 64px;
  padding: 0 14px;
  border-bottom: 1px solid var(--borderSoft);
}

.socialmocial-search-row input {
  border: 1px solid #d3dae6;
  border-radius: 22px;
  height: 40px;
  padding: 0 16px;
  background: #ffffff;
  color: #3c4043;
}

.socialmocial-search-row input:focus {
  outline: none;
  border-color: #a8c7fa;
  box-shadow: 0 0 0 3px #1a73e81a;
}

.socialmocial-menu-group {
  padding: 14px 12px 4px;
}

.socialmocial-menu-group h2 {
  color: #5f6368;
  letter-spacing: 0.06em;
}

.socialmocial-muted {
  color: #80868b;
}

.socialmocial-mini-list li,
.socialmocial-submenu-feature-list button,
.socialmocial-account-list button,
.socialmocial-tools-list button,
.publish-submenu-list button {
  border: 1px solid var(--borderSoft);
  background: #ffffff;
  border-radius: 14px;
  box-shadow: none;
}

.socialmocial-submenu-feature-list button:hover,
.socialmocial-submenu-feature-list button.active,
.socialmocial-account-list button.active,
.socialmocial-account-list button:hover,
.publish-submenu-list button.active,
.publish-submenu-list button:hover {
  border-color: #b6ccf7;
  background: #e8f0fe;
  box-shadow: none;
  transform: none;
}

.account-name {
  color: #334155;
}

.socialmocial-tools-list button:hover,
.socialmocial-tools-list button.active {
  border-color: #b6ccf7;
  background: #e8f0fe;
  color: #1f4f9e;
}

.follow-quick-add input,
.socialmocial-sort-controls select,
.socialmocial-account-form select,
.socialmocial-account-form input,
.publisher-field input,
.publisher-channel-item input,
.tool-transcribe-form input,
.tool-meeting-field input,
.tool-meeting-field textarea,
.compose-field-grid select,
.compose-field-grid input,
.compose-field textarea,
.platform-setting-card input,
.platform-setting-card select,
.platform-setting-card textarea,
.queue-timezone select,
.queue-add-slot input,
.analytics-filter-bar select,
.analytics-date-placeholder input {
  border: 1px solid #d3dae6;
  background: #ffffff;
  color: #3c4043;
  border-radius: 12px;
}

.follow-quick-add input:focus,
.socialmocial-account-form select:focus,
.socialmocial-account-form input:focus,
.compose-field-grid select:focus,
.compose-field-grid input:focus,
.compose-field textarea:focus,
.platform-setting-card input:focus,
.platform-setting-card select:focus,
.platform-setting-card textarea:focus,
.analytics-filter-bar select:focus,
.analytics-date-placeholder input:focus {
  outline: none;
  border-color: #a8c7fa;
  box-shadow: 0 0 0 3px #1a73e81a;
}

.socialmocial-main {
  background: #f1f3f4;
  padding: 18px;
}

.socialmocial-card {
  background: #ffffff;
  border: 1px solid var(--borderSoft);
  border-radius: 18px;
  box-shadow: 0 1px 2px #0f172a12;
}

.socialmocial-section {
  margin-top: 10px;
  padding: 16px;
}

.socialmocial-title {
  color: #202124;
}

.feature-detail-card,
.summary-single-card,
.tool-transcribe-card,
.tool-meeting-card,
.publisher-connect-panel,
.analytics-shell-head,
.analytics-filter-bar,
.analytics-kpi-card,
.analytics-block,
.metric-grid article,
.insight-top-left,
.insight-top-right,
.publish-past-list li,
.publisher-channel-item,
.queue-modal-dialog,
.publish-composer-left,
.publish-composer-right,
.platform-setting-card,
.compose-section,
.publish-day li {
  border-color: var(--borderSoft);
  background: #ffffff;
  box-shadow: none;
}

.table-wrap,
.analytics-table-wrap,
.queue-table-wrap {
  border: 1px solid var(--borderSoft);
  border-radius: 14px;
  background: #ffffff;
}

.table-wrap th,
.analytics-table-wrap th,
.queue-table thead th {
  background: #f5f8ff;
  color: #374151;
}

.table-wrap td,
.analytics-table-wrap td,
.queue-table tbody td {
  border-bottom-color: #edf1f7;
  color: #4b5563;
}

.publish-primary,
.socialmocial-btn {
  border: 1px solid #1a73e8;
  border-radius: 12px;
  padding: 10px 14px;
  background: #1a73e8;
  color: #ffffff;
  font-weight: 600;
  box-shadow: none;
}

.publish-primary:hover,
.socialmocial-btn:hover {
  background: #1967d2;
  border-color: #1967d2;
}

.publish-outline {
  border: 1px solid #cad2e1;
  background: #ffffff;
  color: #4b5563;
}

.publish-chip,
.queue-presets button,
.publisher-channel-pills button,
.publisher-channel-badge,
.platform-switch-row label {
  border: 1px solid #d3dae6;
  background: #f6f8fc;
  color: #4b5563;
}

.publisher-channel-pills button.active,
.compose-channel-item.active,
.compose-platform-tab.is-active,
.compose-platform-tab.is-selected {
  border-color: #7ecb8d;
  background: #e8f7ec;
  color: #1b5e20;
  box-shadow: none;
}

.publish-tabs {
  background: #eef3fb;
  border-radius: 12px;
}

.publish-tabs button.active {
  background: #ffffff;
  color: #1f2937;
}

.socialmocial-empty-state,
.analytics-state {
  border: 1px dashed #d8dee8;
  border-radius: 14px;
  background: #fafcff;
  color: #6b7280;
}

.analytics-state-error {
  border-color: #f4c7c3;
  background: #fef7f6;
}

.publish-composer-backdrop,
.queue-modal-backdrop {
  background: #1f293740;
  backdrop-filter: blur(1px);
}

.publish-composer-dialog {
  border: 1px solid var(--borderSoft);
  background: #f8fafd;
  box-shadow: 0 12px 30px #0f172a2b;
}

.publish-composer-header {
  border-bottom: 1px solid var(--borderSoft);
  background: #ffffff;
}

.queue-close-btn,
.publish-side-close {
  border: 1px solid #d3dae6;
  background: #ffffff;
  color: #5f6368;
}

@media (max-width: 980px) {
  .socialmocial-main {
    padding: 12px;
  }

  .socialmocial-layout {
    grid-template-columns: 64px 1fr;
  }
}

/* Analytics: engagement history module */
.analytics-line-chart-wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
}

.analytics-line-chart-wrap svg {
  width: 100%;
  height: 260px;
  border: 1px solid #e3e7ee;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcff 100%);
}

.analytics-line-guides line {
  stroke: #e9edf4;
  stroke-width: 1;
}

.analytics-line-path {
  fill: none;
  stroke: #1a73e8;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.analytics-line-area {
  fill: url(#analytics-line-fill);
  stroke: none;
}

.analytics-line-chart-wrap circle {
  fill: #1a73e8;
}

.analytics-line-axis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(50px, 1fr));
  gap: 8px;
  font-size: 11px;
  color: #6b7280;
}

.analytics-line-axis span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.analytics-comparison .analytics-comparison-content {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.analytics-comparison .analytics-comparison-content strong {
  font-size: 28px;
  line-height: 1.1;
  color: #1f2937;
}

.analytics-comparison .analytics-comparison-content p {
  margin: 0;
  color: #6b7280;
}

/* Analytics: worst post finder */
.analytics-badge-low {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 12px;
  font-weight: 700;
  color: #b42318;
  background: #fee4e2;
  border: 1px solid #fecdca;
}

.analytics-row-low td {
  background: #fff7f7;
}

.analytics-action-link {
  color: #1a73e8;
  font-weight: 600;
  text-decoration: underline;
}

.content-report-filter-bar {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid #e3ecf8;
  background: #ffffff;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.content-report-filter-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  flex: 1;
  min-width: 560px;
}

.content-report-filter-bar label {
  display: grid;
  gap: 6px;
  font-size: 12px;
  color: #6b7a99;
}

.content-report-filter-bar select,
.content-report-filter-bar input[type="text"],
.content-report-filter-bar input[type="date"] {
  border: 1px solid #d7e3f4;
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 13px;
  color: #1f2937;
  background: #f8fbff;
}

.content-report-filter-bar input[type="text"]:focus,
.content-report-filter-bar select:focus,
.content-report-filter-bar input[type="date"]:focus {
  outline: none;
  border-color: #8cb7ff;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
  background: #fff;
}

.content-report-filter-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.content-report-search {
  grid-column: span 2;
}

.content-report-date-inputs {
  display: flex;
  gap: 8px;
}

.content-report-export {
  display: flex;
  align-items: center;
  gap: 8px;
}

.content-report-columns {
  position: relative;
}

.content-report-columns-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 280px;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid #dbe7f5;
  background: #ffffff;
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.12);
  display: none;
  z-index: 20;
}

.content-report-columns-panel.open {
  display: block;
}

.content-report-columns-panel strong {
  display: block;
  font-size: 13px;
  color: #1f2937;
  margin-bottom: 10px;
}

.content-report-columns-grid {
  display: grid;
  gap: 8px;
  max-height: 240px;
  overflow-y: auto;
}

.content-report-columns-grid label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: #42526b;
}

.content-report-table-card header p {
  font-size: 12px;
  color: #7a8aa5;
}

.content-report-table-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.content-report-table-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: #64748b;
}

.content-report-table-wrap {
  border: 1px solid #e5edf9;
  border-radius: 16px;
  overflow: auto;
  max-height: 520px;
}

.content-report-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 1200px;
}

.content-report-table th,
.content-report-table td {
  padding: 12px 14px;
  font-size: 12px;
  border-bottom: 1px solid #edf2fb;
  color: #1f2937;
  vertical-align: middle;
}

.content-report-table th {
  position: sticky;
  top: 0;
  background: #f8fbff;
  z-index: 5;
  text-align: left;
  font-weight: 600;
}

.content-report-table tr:hover {
  background: #f5f9ff;
}

.content-report-table th button {
  border: none;
  background: transparent;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: #334155;
  cursor: pointer;
}

.content-report-sort {
  font-size: 11px;
  color: #9ca3af;
}

.content-report-sort.active {
  color: #2563eb;
}

.content-report-checkbox {
  width: 36px;
}

.content-report-thumb {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: #edf2ff;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.content-report-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.content-report-caption {
  display: block;
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.content-report-chip {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid #cfe0fb;
  background: #f1f6ff;
  font-size: 11px;
  font-weight: 600;
}

.content-report-status {
  display: inline-flex;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid #e5e7eb;
  background: #f8fafc;
}

.content-report-status.status-published {
  border-color: #bbf7d0;
  color: #15803d;
  background: #f0fdf4;
}

.content-report-status.status-scheduled {
  border-color: #bfdbfe;
  color: #1d4ed8;
  background: #eff6ff;
}

.content-report-status.status-archived {
  border-color: #e2e8f0;
  color: #64748b;
  background: #f8fafc;
}

.content-report-type {
  font-weight: 600;
  color: #334155;
}

.content-report-na {
  color: #94a3b8;
}

.content-report-pagination {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  padding: 14px 2px 0;
  font-size: 12px;
  color: #64748b;
}

.content-report-drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.35);
  z-index: 60;
}

.content-report-drawer {
  position: fixed;
  top: 80px;
  right: 32px;
  width: 360px;
  height: calc(100% - 120px);
  background: #ffffff;
  border-radius: 20px;
  border: 1px solid #e5edf9;
  box-shadow: 0 24px 60px rgba(15, 23, 42, 0.2);
  z-index: 61;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.content-report-drawer header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid #edf2fb;
}

.content-report-drawer header h4 {
  margin: 0;
  font-size: 16px;
  color: #0f172a;
}

.content-report-drawer header p {
  margin: 4px 0 0;
  font-size: 12px;
  color: #64748b;
}

.content-report-drawer-close {
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
}

.content-report-drawer-body {
  padding: 16px 20px 20px;
  overflow-y: auto;
}

.content-report-drawer-media img {
  width: 100%;
  border-radius: 14px;
  border: 1px solid #e5edf9;
}

.content-report-drawer-section {
  margin-top: 16px;
}

.content-report-drawer-section strong {
  display: block;
  font-size: 12px;
  color: #64748b;
  margin-bottom: 6px;
}

.content-report-drawer-section p {
  margin: 0;
  font-size: 13px;
  color: #1f2937;
}

.content-report-metrics-grid {
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.content-report-metrics-grid span {
  display: block;
  font-size: 11px;
  color: #64748b;
}

.content-report-metrics-grid strong {
  font-size: 14px;
  color: #0f172a;
}

.content-report-drawer-actions {
  margin-top: 18px;
}

@media (max-width: 1200px) {
  .content-report-filter-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .content-report-filter-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .content-report-drawer {
    right: 16px;
    width: calc(100% - 32px);
  }
}

/* Analytics: growth comparison tool */
.analytics-kpi-card.analytics-delta-up small {
  color: #027a48;
}

.analytics-kpi-card.analytics-delta-down small {
  color: #b42318;
}

.analytics-kpi-card.analytics-delta-flat small {
  color: #667085;
}

.analytics-summary-sentence p {
  margin: 0;
  color: #344054;
  font-weight: 500;
}

/* Analytics: platform comparison dashboard */
.analytics-platform-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
}

.analytics-platform-card {
  border: 1px solid #d9e2f1;
  background: #ffffff;
  border-radius: 16px;
  padding: 12px;
}

.analytics-platform-card header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.analytics-platform-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 30px;
  border-radius: 10px;
  background: #eef3ff;
  border: 1px solid #dbe5ff;
  color: #1a3d7c;
  font-size: 12px;
  font-weight: 700;
}

.analytics-platform-card header strong {
  display: block;
  color: #101828;
  line-height: 1.2;
}

.analytics-platform-card header small {
  display: block;
  color: #667085;
  font-size: 12px;
}

.analytics-platform-card dl {
  margin: 0;
  display: grid;
  gap: 8px;
}

.analytics-platform-card dl div {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}

.analytics-platform-card dt {
  color: #667085;
  font-size: 12px;
}

.analytics-platform-card dd {
  margin: 0;
  color: #111827;
  font-weight: 700;
}

.analytics-platform-card.tone-strong {
  border-color: #86efac;
  background: #f0fdf4;
}

.analytics-platform-card.tone-weak {
  border-color: #fecaca;
  background: #fef2f2;
}

.analytics-platform-card.tone-missing {
  border-style: dashed;
  background: #f8fafc;
}

.analytics-row-strong td {
  background: #f0fdf4;
}

.analytics-row-weak td {
  background: #fef2f2;
}

.analytics-row-muted td {
  background: #f8fafc;
  color: #64748b;
}

.analytics-badge-strong,
.analytics-badge-weak,
.analytics-badge-muted,
.analytics-badge-neutral {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 12px;
  font-weight: 700;
}

.analytics-badge-strong {
  color: #166534;
  background: #dcfce7;
  border: 1px solid #bbf7d0;
}

.analytics-badge-weak {
  color: #b42318;
  background: #fee4e2;
  border: 1px solid #fecdca;
}

.analytics-badge-muted {
  color: #475467;
  background: #f2f4f7;
  border: 1px solid #eaecf0;
}

.analytics-badge-neutral {
  color: #1a3d7c;
  background: #eaf2ff;
  border: 1px solid #d8e7ff;
}

.analytics-badge-severity-high,
.analytics-badge-severity-medium,
.analytics-badge-severity-low {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 12px;
  font-weight: 700;
}

.analytics-badge-severity-high {
  color: #b42318;
  background: #fee4e2;
  border: 1px solid #fecdca;
}

.analytics-badge-severity-medium {
  color: #b54708;
  background: #fffaeb;
  border: 1px solid #fedf89;
}

.analytics-badge-severity-low {
  color: #175cd3;
  background: #eff8ff;
  border: 1px solid #b2ddff;
}

.analytics-line-point-spike {
  fill: #f97316;
  stroke: #ffffff;
  stroke-width: 1.5;
}

.analytics-line-point-drop {
  fill: #ef4444;
  stroke: #ffffff;
  stroke-width: 1.5;
}

.analytics-line-point-drop.severity-medium {
  fill: #f59e0b;
}

.analytics-line-point-drop.severity-low {
  fill: #3b82f6;
}

.analytics-milestone-layout {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.analytics-milestone-progress p {
  margin: 0 0 8px;
  font-size: 24px;
  font-weight: 700;
  color: #101828;
}

.analytics-progress-track {
  height: 10px;
  border-radius: 999px;
  background: #e5e7eb;
  border: 1px solid #d0d5dd;
  overflow: hidden;
}

.analytics-progress-fill {
  display: block;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #2563eb 0%, #60a5fa 100%);
}

.analytics-milestone-progress small {
  display: inline-block;
  margin-top: 8px;
  color: #667085;
}

.analytics-milestone-next dl {
  margin: 0;
  display: grid;
  gap: 8px;
}

.analytics-milestone-next dl div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.analytics-milestone-next dt {
  color: #667085;
  font-size: 12px;
}

.analytics-milestone-next dd {
  margin: 0;
  color: #111827;
  font-weight: 700;
}

.analytics-milestone-timeline ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.analytics-milestone-timeline li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid #e4e7ec;
  border-radius: 10px;
  padding: 8px 10px;
  background: #fff;
}

.analytics-milestone-timeline li strong {
  color: #111827;
  font-size: 13px;
}

.analytics-milestone-timeline li span {
  color: #667085;
  font-size: 12px;
}

.analytics-milestone-timeline li.status-achieved {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.analytics-milestone-timeline li.status-next {
  border-color: #bfdbfe;
  background: #eff6ff;
}

.analytics-weekly-report {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.analytics-report-col {
  min-height: 100%;
}

.analytics-weekly-report > .analytics-block:not(.analytics-report-col) {
  grid-column: 1 / -1;
}

.analytics-report-post-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.analytics-report-post-list li {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid #e4e7ec;
  border-radius: 10px;
  padding: 10px;
  background: #ffffff;
}

.analytics-report-post-list strong {
  color: #111827;
  font-size: 13px;
}

.analytics-report-post-list p {
  margin: 2px 0;
  color: #344054;
  font-size: 13px;
}

.analytics-report-post-list small {
  color: #667085;
  font-size: 12px;
}

.analytics-report-post-list li > span {
  font-weight: 700;
  color: #1f2937;
  font-size: 13px;
  white-space: nowrap;
}

.affiliate-funnel-card {
  grid-column: 1 / -1;
}

.affiliate-funnel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}

.affiliate-funnel-step {
  border: 1px solid #d0d5dd;
  border-radius: 12px;
  background: #ffffff;
  padding: 10px 12px;
  display: grid;
  gap: 4px;
}

.affiliate-funnel-step span {
  color: #667085;
  font-size: 12px;
}

.affiliate-funnel-step strong {
  color: #111827;
  font-size: 18px;
  line-height: 1.2;
}

.affiliate-funnel-step small {
  color: #475467;
  font-size: 12px;
}

.affiliate-top-posts {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.affiliate-top-posts li {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid #e4e7ec;
  border-radius: 10px;
  background: #fff;
  padding: 10px;
}

.affiliate-top-posts strong {
  color: #111827;
  font-size: 13px;
}

.affiliate-top-posts p {
  margin: 2px 0 0;
  color: #344054;
  font-size: 13px;
}

.affiliate-top-posts li > span {
  font-weight: 700;
  color: #1f2937;
  font-size: 13px;
  white-space: nowrap;
}

.analytics-report-alert-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.analytics-report-alert-grid strong {
  color: #111827;
}

.analytics-report-alert-grid ul {
  margin: 8px 0 0;
  padding-left: 18px;
  color: #344054;
}

.analytics-report-alert-grid p {
  margin: 8px 0 0;
  color: #667085;
}

.analytics-report-platform-mini {
  display: grid;
  gap: 6px;
  color: #344054;
}

.analytics-report-reco-list {
  margin: 0;
  padding-left: 18px;
  color: #344054;
}

.analytics-weekly-export p {
  margin: 0 0 10px;
  color: #667085;
}

.analytics-weekly-export-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

@media print {
  .analytics-weekly-export-actions {
    display: none;
  }

  .analytics-shell {
    box-shadow: none;
    border-color: #d0d5dd;
  }
}

.analytics-compare-bars {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.analytics-compare-row {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 10px;
  align-items: center;
}

.analytics-compare-label {
  font-size: 12px;
  color: #475467;
  font-weight: 600;
}

.analytics-compare-track {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  align-items: center;
}

.analytics-compare-bar {
  display: inline-flex;
  align-items: center;
  height: 24px;
  min-width: 34px;
  border-radius: 8px;
  padding: 0 8px;
  font-size: 11px;
  font-weight: 600;
  color: #1f2937;
  white-space: nowrap;
  overflow: hidden;
}

.analytics-compare-bar.left {
  background: #dbeafe;
  border: 1px solid #bfdbfe;
}

.analytics-compare-bar.right {
  background: #e5e7eb;
  border: 1px solid #d1d5db;
}

@media (max-width: 980px) {
  .socialmocial-layout.accounts-competitors-no-submenu,
  .socialmocial-layout.rail-open.accounts-competitors-no-submenu,
  .socialmocial-layout.accounts-competitors-no-submenu.follow-secondary-open,
  .socialmocial-layout.rail-open.accounts-competitors-no-submenu.follow-secondary-open {
    grid-template-columns: 64px minmax(0, 1fr);
  }

  .socialmocial-layout.follow-secondary-open {
    grid-template-columns: 64px 231px minmax(0, 1fr);
  }

  .socialmocial-layout.rail-open.follow-secondary-open {
    grid-template-columns: 232px 231px minmax(0, 1fr);
  }

  .socialmocial-secondary-submenu {
    display: none !important;
  }

  .account-hub-grid {
    grid-template-columns: 1fr;
  }

  .account-inline-form {
    grid-template-columns: 1fr;
  }

  .account-social-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .platform-grid {
    grid-template-columns: 1fr;
  }

  .analytics-platform-grid {
    grid-template-columns: 1fr;
  }

  .analytics-milestone-layout {
    grid-template-columns: 1fr;
  }

  .analytics-weekly-report {
    grid-template-columns: 1fr;
  }

  .analytics-report-alert-grid {
    grid-template-columns: 1fr;
  }

  .analytics-compare-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .account-social-grid {
    grid-template-columns: 1fr;
  }

  .platform-card {
    flex-direction: column;
    align-items: stretch;
  }

  .socialmocial-topbar-brand {
    font-size: 0;
    gap: 0;
  }

  .socialmocial-topbar-logo {
    width: clamp(132px, 42vw, 180px);
    height: 42px;
  }
}

.auth-overlay {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(15, 23, 42, 0.45);
  padding: 24px;
}

.auth-overlay.is-hidden {
  display: none;
}

.auth-card {
  width: min(1100px, 100%);
  background: #f8fafc;
  border-radius: 24px;
  padding: 28px;
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(320px, 1.2fr);
  gap: 24px;
  box-shadow: 0 28px 60px rgba(15, 23, 42, 0.25);
}

.auth-side {
  background: linear-gradient(140deg, #1d4ed8 0%, #2563eb 35%, #38bdf8 100%);
  color: white;
  border-radius: 18px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.auth-side h2 {
  font-size: 28px;
  margin: 0;
}

.auth-side p {
  opacity: 0.9;
  line-height: 1.5;
}

.auth-plan-card {
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.25);
  border-radius: 14px;
  padding: 16px;
}

.auth-main {
  background: white;
  border-radius: 18px;
  padding: 24px;
}

.auth-tabs {
  display: flex;
  gap: 10px;
  margin-bottom: 20px;
}

.auth-tabs button {
  border: 1px solid #d7deec;
  background: #f8fafc;
  border-radius: 999px;
  padding: 8px 16px;
  font-weight: 600;
}

.auth-tabs button.active {
  background: #0f172a;
  color: white;
  border-color: #0f172a;
}

.auth-heading {
  margin-bottom: 16px;
}

.auth-heading h3 {
  margin: 0;
  font-size: 22px;
  color: #0f172a;
}

.auth-heading p {
  margin: 6px 0 0;
  font-size: 13px;
  color: #64748b;
}

.auth-form {
  display: grid;
  gap: 14px;
}

.auth-form label {
  display: grid;
  gap: 6px;
  font-size: 13px;
  color: #475467;
}

.auth-form input {
  border: 1px solid #d7deec;
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 14px;
}

.auth-form .auth-actions {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.auth-form .auth-actions button {
  border-radius: 999px;
  padding: 10px 18px;
  font-weight: 600;
  border: none;
  background: #0f172a;
  color: white;
}

.auth-form .auth-actions button.secondary {
  background: #e2e8f0;
  color: #0f172a;
}

.auth-links {
  display: flex;
  gap: 16px;
  margin-top: -2px;
}

.auth-link {
  background: none;
  border: none;
  padding: 0;
  color: #2563eb;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
}

.auth-link:hover {
  text-decoration: underline;
}

.auth-helper {
  font-size: 13px;
  color: #64748b;
}

.auth-error {
  background: #fef2f2;
  color: #b91c1c;
  border: 1px solid #fecaca;
  padding: 10px 12px;
  border-radius: 12px;
  font-size: 13px;
}

.auth-success {
  background: #ecfdf3;
  color: #166534;
  border: 1px solid #bbf7d0;
  padding: 10px 12px;
  border-radius: 12px;
  font-size: 13px;
}

.socialmocial-credit-pill {
  background: #e2e8f0;
  color: #0f172a;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 600;
}

.socialmocial-credit-pill.is-hidden {
  display: none;
}

@media (max-width: 900px) {
  .auth-card {
    grid-template-columns: 1fr;
  }
}

.billing-summary-grid {
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
}

.billing-plan-grid {
  margin-top: 20px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}

.billing-plan-card {
  border: 1px solid #dbe4f0;
  border-radius: 16px;
  padding: 16px;
  background: #fff;
}

.billing-plan-card.active {
  border-color: #2563eb;
  box-shadow: 0 8px 24px rgba(37, 99, 235, 0.12);
}

.billing-plan-card h4 {
  margin: 0 0 6px;
}

.billing-plan-card ul {
  margin: 8px 0 12px;
  padding-left: 18px;
  font-size: 13px;
  color: #475467;
}

.billing-plan-price {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 4px;
}

.billing-credit-packs {
  margin-top: 24px;
}

.billing-credit-grid {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px;
}

.credit-pack {
  border: 1px solid #dbe4f0;
  border-radius: 14px;
  padding: 12px;
  background: #f8fafc;
  display: grid;
  gap: 6px;
  text-align: left;
  font-weight: 600;
}

.credit-pack:hover {
  border-color: #94a3b8;
}
