.client-portal-page {
  padding: 3.4rem 0 4.8rem;
  background:
    radial-gradient(circle at top right, rgba(148, 163, 184, 0.08), transparent 24%),
    linear-gradient(180deg, #f8fafc 0%, #ffffff 34%, #f8f5f0 100%);
}

.client-portal-shell {
  max-width: 1360px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.client-portal-shell--narrow {
  max-width: 1080px;
}

.client-portal-topbar,
.client-portal-hero {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  margin: 0 0 1.5rem;
}

.client-portal-topbar--premium {
  padding: 1.5rem;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 34px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.96));
  box-shadow: 0 28px 70px rgba(15, 23, 42, 0.08);
}

.client-portal-profile-hero {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  flex: 1 1 auto;
}

.client-portal-profile-avatar,
.client-portal-mini-profile__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f172a, #334155);
  color: #ffffff;
  font-weight: 800;
  letter-spacing: 0.08em;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.18);
}

.client-portal-profile-avatar {
  width: 5rem;
  height: 5rem;
  font-size: 1.28rem;
  flex: 0 0 auto;
}

.client-portal-profile-copy {
  min-width: 0;
}

.client-portal-eyebrow {
  margin: 0 0 0.6rem;
  font-size: 0.79rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #64748b;
}

.client-portal-title {
  margin: 0 0 0.75rem;
  font-size: clamp(2rem, 4vw, 3.1rem);
  line-height: 1.04;
  color: #0f172a;
}

.client-portal-intro {
  margin: 0;
  max-width: 58rem;
  color: #475569;
  line-height: 1.8;
}

.client-portal-profile-meta {
  display: flex;
  gap: 0.7rem;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 1rem;
}

.client-portal-topbar__actions {
  display: flex;
  gap: 0.7rem;
  align-items: center;
  flex-wrap: wrap;
}

.client-portal-topbar__actions--stack {
  flex-direction: column;
  align-items: stretch;
  min-width: 280px;
}

.client-portal-chip {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(148, 163, 184, 0.24);
  padding: 0.7rem 1rem;
  border-radius: 999px;
  background: #ffffff;
  color: #334155;
}

.client-portal-account-card {
  display: grid;
  gap: 0.25rem;
  padding: 1rem 1.05rem;
  border-radius: 24px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(255, 255, 255, 0.92);
}

.client-portal-account-card strong {
  font-size: 1.3rem;
  color: #0f172a;
}

.client-portal-account-card small,
.client-portal-account-card__label {
  color: #64748b;
  line-height: 1.6;
}

.client-portal-quick-actions {
  display: flex;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.client-portal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

.client-portal-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  gap: 1rem;
  margin-bottom: 1rem;
}

.client-portal-card {
  background: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 28px;
  padding: 1.2rem 1.2rem 1.3rem;
  box-shadow: 0 24px 60px rgba(15, 23, 42, 0.06);
}

.client-portal-card--overview,
.client-portal-card--message,
.client-portal-card--profile {
  min-height: 100%;
}

.client-portal-card__head {
  display: flex;
  gap: 0.9rem;
  align-items: flex-start;
  margin-bottom: 1rem;
}

.client-portal-card__head h2 {
  margin: 0 0 0.25rem;
  color: #0f172a;
  font-size: 1.08rem;
}

.client-portal-card__head p {
  margin: 0;
  color: #64748b;
  line-height: 1.7;
}

.client-portal-card__step {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: #0f172a;
  color: #ffffff;
  font-weight: 700;
  flex: 0 0 auto;
}

.client-portal-form {
  display: grid;
  gap: 0.9rem;
}

.client-portal-field {
  display: flex;
  flex-direction: column;
  gap: 0.42rem;
}

.client-portal-field label {
  font-weight: 600;
  color: #0f172a;
}

.client-portal-field input {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid rgba(148, 163, 184, 0.26);
  border-radius: 16px;
  padding: 0.86rem 0.95rem;
  font: inherit;
  color: #0f172a;
  background: #ffffff;
}

.client-portal-field input:focus {
  outline: none;
  border-color: rgba(15, 23, 42, 0.35);
  box-shadow: 0 0 0 4px rgba(15, 23, 42, 0.06);
}

.client-portal-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.9rem 1.2rem;
  border-radius: 999px;
  border: 1px solid #0f172a;
  background: #ffffff;
  color: #0f172a;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}

.client-portal-btn--dark {
  background: #0f172a;
  color: #ffffff;
}

.client-portal-btn--ghost {
  background: transparent;
  border-color: rgba(148, 163, 184, 0.28);
  color: #334155;
}

.client-portal-alert {
  margin: 0 0 1rem;
  border-radius: 18px;
  padding: 1rem 1.1rem;
  border: 1px solid rgba(148, 163, 184, 0.18);
}

.client-portal-alert--success {
  background: linear-gradient(135deg, rgba(236, 253, 245, 0.98), rgba(255, 255, 255, 0.98));
  border-color: rgba(16, 185, 129, 0.2);
  color: #065f46;
}

.client-portal-alert--error {
  background: linear-gradient(135deg, rgba(254, 242, 242, 0.98), rgba(255, 255, 255, 0.98));
  border-color: rgba(239, 68, 68, 0.18);
  color: #991b1b;
}

.client-portal-benefits {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.client-portal-benefit {
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(148, 163, 184, 0.16);
  border-radius: 24px;
  padding: 1rem 1.05rem;
}

.client-portal-benefit strong {
  display: block;
  margin: 0 0 0.35rem;
  color: #0f172a;
}

.client-portal-benefit p {
  margin: 0;
  color: #64748b;
  line-height: 1.7;
}

.client-portal-stats {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.95rem;
  margin: 0 0 1rem;
}

.client-portal-stat {
  background: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 24px;
  padding: 1rem 1.05rem;
  box-shadow: 0 18px 50px rgba(15, 23, 42, 0.05);
}

.client-portal-stat span {
  display: block;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #94a3b8;
  margin-bottom: 0.45rem;
}

.client-portal-stat strong {
  font-size: 1.6rem;
  color: #0f172a;
}

.client-portal-progress-list {
  display: grid;
  gap: 1rem;
}

.client-portal-progress-item {
  display: grid;
  gap: 0.45rem;
}

.client-portal-progress-item--project {
  margin-top: 0.75rem;
}

.client-portal-progress-head {
  display: flex;
  justify-content: space-between;
  gap: 0.8rem;
  align-items: center;
}

.client-portal-progress-head strong {
  color: #0f172a;
  font-size: 0.96rem;
}

.client-portal-progress-head span {
  color: #475569;
  font-weight: 700;
}

.client-portal-progress-bar {
  position: relative;
  overflow: hidden;
  height: 10px;
  border-radius: 999px;
  background: #e2e8f0;
}

.client-portal-progress-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #0f172a, #475569);
}

.client-portal-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(320px, 0.78fr);
  gap: 1rem;
  align-items: start;
}

.client-portal-main,
.client-portal-side {
  display: grid;
  gap: 1rem;
}

.client-portal-empty {
  padding: 1rem 1.05rem;
  border-radius: 20px;
  background: #f8fafc;
  color: #64748b;
}

.client-portal-note {
  margin: 0;
  color: #334155;
  line-height: 1.8;
}

.client-portal-projects,
.client-portal-gallery-grid,
.client-portal-notifications,
.client-portal-payments {
  display: grid;
  gap: 0.9rem;
}

.client-portal-project,
.client-portal-gallery,
.client-portal-payment {
  padding: 1rem;
  border-radius: 22px;
  background: #f8fafc;
  border: 1px solid rgba(148, 163, 184, 0.16);
}

.client-portal-project__top,
.client-portal-gallery__top {
  display: flex;
  justify-content: space-between;
  gap: 0.8rem;
  align-items: flex-start;
  margin-bottom: 0.55rem;
}

.client-portal-project strong,
.client-portal-gallery strong,
.client-portal-payment strong {
  color: #0f172a;
}

.client-portal-project p,
.client-portal-gallery p {
  margin: 0.2rem 0 0;
  color: #64748b;
  line-height: 1.6;
}

.client-portal-project__text {
  margin: 0.7rem 0 0;
  color: #334155;
  line-height: 1.7;
}

.client-portal-project-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 0.95rem;
}

.client-portal-project-kpis span {
  display: grid;
  gap: 0.15rem;
  padding: 0.8rem 0.85rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.92);
  color: #64748b;
  line-height: 1.5;
}

.client-portal-project-kpis strong {
  color: #0f172a;
  font-size: 1rem;
}

.client-portal-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 0.8rem;
  margin-top: 0.5rem;
}

.client-portal-meta span {
  font-size: 0.9rem;
  color: #475569;
}

.client-portal-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.4rem 0.7rem;
  border-radius: 999px;
  background: #0f172a;
  color: #ffffff;
  font-size: 0.78rem;
  font-weight: 700;
}

.client-portal-badge--light {
  background: #e2e8f0;
  color: #0f172a;
}

.client-portal-badge--success {
  background: #ecfdf5;
  color: #065f46;
}

.client-portal-actions {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  margin-top: 0.85rem;
}

.client-portal-table-wrap {
  overflow: auto;
}

.client-portal-table {
  width: 100%;
  border-collapse: collapse;
}

.client-portal-table th,
.client-portal-table td {
  padding: 0.85rem 0.7rem;
  border-bottom: 1px solid rgba(148, 163, 184, 0.15);
  text-align: left;
  vertical-align: top;
}

.client-portal-table th {
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #94a3b8;
}

.client-portal-table__sub {
  font-size: 0.88rem;
  color: #64748b;
  margin-top: 0.25rem;
}

.client-portal-link {
  display: inline-flex;
  margin-right: 0.7rem;
  color: #0f172a;
  text-decoration: none;
  font-weight: 600;
}

.client-portal-notification {
  padding: 0.95rem 1rem;
  border-radius: 20px;
  border: 1px solid rgba(148, 163, 184, 0.16);
  background: #ffffff;
}

.client-portal-notification strong {
  display: block;
  margin: 0 0 0.25rem;
  color: #0f172a;
}

.client-portal-notification p {
  margin: 0;
  color: #475569;
  line-height: 1.65;
}

.client-portal-notification--success {
  background: linear-gradient(135deg, rgba(236, 253, 245, 0.98), rgba(255, 255, 255, 0.98));
}

.client-portal-notification--warning {
  background: linear-gradient(135deg, rgba(255, 251, 235, 0.98), rgba(255, 255, 255, 0.98));
}

.client-portal-notification--info {
  background: linear-gradient(135deg, rgba(248, 250, 252, 0.98), rgba(255, 255, 255, 0.98));
}

.client-portal-timeline {
  position: relative;
  display: grid;
  gap: 0.95rem;
}

.client-portal-timeline__item {
  position: relative;
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 0.8rem;
}

.client-portal-timeline__item::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 0.8rem;
  bottom: -1.15rem;
  width: 2px;
  background: rgba(148, 163, 184, 0.25);
}

.client-portal-timeline__item:last-child::before {
  display: none;
}

.client-portal-timeline__dot {
  position: relative;
  margin-top: 0.35rem;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #cbd5e1;
  box-shadow: inset 0 0 0 4px #ffffff;
  z-index: 1;
}

.client-portal-timeline__item--info .client-portal-timeline__dot {
  background: #0f172a;
}

.client-portal-timeline__item--success .client-portal-timeline__dot {
  background: #10b981;
}

.client-portal-timeline__item--warning .client-portal-timeline__dot {
  background: #f59e0b;
}

.client-portal-timeline__item--muted .client-portal-timeline__dot {
  background: #94a3b8;
}

.client-portal-timeline__item small {
  display: block;
  margin-bottom: 0.18rem;
  color: #94a3b8;
}

.client-portal-timeline__item strong {
  display: block;
  color: #0f172a;
}

.client-portal-timeline__item p {
  margin: 0.22rem 0 0;
  color: #475569;
  line-height: 1.6;
}

.client-portal-deadlines {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.75rem;
}

.client-portal-deadlines li {
  padding: 0.95rem 1rem;
  border-radius: 20px;
  background: #f8fafc;
  border: 1px solid rgba(148, 163, 184, 0.15);
}

.client-portal-deadlines span {
  display: block;
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #94a3b8;
  margin-bottom: 0.2rem;
}

.client-portal-deadlines strong {
  display: block;
  color: #0f172a;
}

.client-portal-deadlines small {
  display: block;
  margin-top: 0.25rem;
  color: #64748b;
}

.client-portal-payment span {
  display: block;
  margin-top: 0.22rem;
  color: #334155;
  font-weight: 600;
}

.client-portal-payment small {
  display: block;
  margin-top: 0.25rem;
  color: #64748b;
  line-height: 1.6;
}

.client-portal-mini-profile {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  margin-bottom: 1rem;
}

.client-portal-mini-profile__avatar {
  width: 3.15rem;
  height: 3.15rem;
  font-size: 0.95rem;
  flex: 0 0 auto;
}

.client-portal-mini-profile strong {
  display: block;
  color: #0f172a;
}

.client-portal-mini-profile small {
  display: block;
  margin-top: 0.2rem;
  color: #64748b;
}

.client-portal-profile-list {
  display: grid;
  gap: 0.75rem;
  margin: 0;
}

.client-portal-profile-list div {
  display: grid;
  gap: 0.16rem;
  padding: 0.8rem 0.85rem;
  border-radius: 18px;
  background: #f8fafc;
}

.client-portal-profile-list dt {
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #94a3b8;
}

.client-portal-profile-list dd {
  margin: 0;
  color: #0f172a;
}

#client-dashboard,
#client-projects,
#client-documents,
#client-galleries {
  scroll-margin-top: 7.5rem;
}

@media (max-width: 1180px) {
  .client-portal-layout,
  .client-portal-overview-grid {
    grid-template-columns: 1fr;
  }

  .client-portal-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .client-portal-grid,
  .client-portal-benefits,
  .client-portal-project-kpis {
    grid-template-columns: 1fr;
  }

  .client-portal-topbar,
  .client-portal-hero,
  .client-portal-profile-hero {
    flex-direction: column;
  }

  .client-portal-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .client-portal-topbar__actions--stack {
    min-width: 0;
    width: 100%;
  }
}

@media (max-width: 640px) {
  .client-portal-page {
    padding: 2.4rem 0 3rem;
  }

  .client-portal-shell {
    padding: 0 1rem;
  }

  .client-portal-card,
  .client-portal-topbar--premium {
    padding: 1rem;
  }

  .client-portal-stats {
    grid-template-columns: 1fr;
  }

  .client-portal-quick-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .client-portal-table th,
  .client-portal-table td {
    white-space: nowrap;
  }
}

.client-portal-alert{padding:.9rem 1rem;border-radius:18px;margin-bottom:1rem;border:1px solid transparent;font-weight:600}.client-portal-alert--success{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.client-portal-alert--error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.client-portal-conversation{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:1rem}.client-portal-thread{display:grid;gap:.85rem;max-height:38rem;overflow:auto;padding-right:.2rem}.client-portal-message{padding:1rem 1.05rem;border-radius:24px;border:1px solid rgba(148,163,184,.18);box-shadow:0 16px 40px rgba(15,23,42,.05)}.client-portal-message--studio{background:linear-gradient(180deg,#fff,#f8fafc);border-left:4px solid #0f172a}.client-portal-message--self{background:linear-gradient(180deg,#fff,#eff6ff);border-left:4px solid #3b82f6}.client-portal-message__meta{display:flex;gap:.45rem;flex-wrap:wrap;align-items:center;margin-bottom:.55rem;color:#64748b;font-size:.86rem}.client-portal-message__meta strong{color:#0f172a}.client-portal-message__meta em{font-style:normal;padding:.2rem .5rem;border-radius:999px;background:#fff;border:1px solid rgba(148,163,184,.22);color:#334155}.client-portal-message__meta time{margin-left:auto}.client-portal-message__body{color:#334155;line-height:1.8}.client-portal-message-form{display:grid;gap:.95rem;padding:1rem;border-radius:24px;border:1px solid rgba(148,163,184,.18);background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,252,.95))}.client-portal-message-form textarea,.client-portal-select{width:100%;box-sizing:border-box;border:1px solid rgba(148,163,184,.26);border-radius:16px;padding:.86rem .95rem;font:inherit;color:#0f172a;background:#fff}.client-portal-message-form textarea{resize:vertical;min-height:160px}.client-portal-message-form textarea:focus,.client-portal-select:focus{outline:none;border-color:rgba(15,23,42,.35);box-shadow:0 0 0 4px rgba(15,23,42,.06)}@media (max-width: 1024px){.client-portal-conversation{grid-template-columns:1fr}.client-portal-thread{max-height:none}.client-portal-message__meta time{margin-left:0;width:100%}}

.client-portal-profile-avatar,
.client-portal-mini-profile__avatar {
  overflow: hidden;
}

.client-portal-profile-avatar img,
.client-portal-mini-profile__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.client-portal-field textarea,
.client-portal-field input[type="text"],
.client-portal-field input[type="email"],
.client-portal-field input[type="file"] {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid rgba(148, 163, 184, 0.26);
  border-radius: 16px;
  padding: 0.86rem 0.95rem;
  font: inherit;
  color: #0f172a;
  background: #ffffff;
}

.client-portal-field textarea {
  resize: vertical;
  min-height: 120px;
}

.client-portal-field textarea:focus,
.client-portal-field input[type="text"]:focus,
.client-portal-field input[type="email"]:focus,
.client-portal-field input[type="file"]:focus {
  outline: none;
  border-color: rgba(15, 23, 42, 0.35);
  box-shadow: 0 0 0 4px rgba(15, 23, 42, 0.06);
}

.client-portal-field__hint {
  color: #64748b;
  line-height: 1.6;
}

.client-portal-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  color: #334155;
  font-weight: 500;
}

.client-portal-inline-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.35rem;
  height: 1.35rem;
  margin-left: 0.6rem;
  padding: 0 0.42rem;
  border-radius: 999px;
  background: #ef4444;
  color: #fff;
  font-size: 0.76rem;
  font-weight: 800;
  vertical-align: middle;
}

.client-portal-project-form {
  display: grid;
  gap: 0.9rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px dashed rgba(148, 163, 184, 0.24);
}

.client-portal-attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 0.9rem;
}

.client-portal-attachments--message {
  margin-top: 0.75rem;
}

.client-portal-attachment {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.62rem 0.86rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(148, 163, 184, 0.24);
  color: #0f172a;
  text-decoration: none;
  font-size: 0.9rem;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.client-portal-attachment:hover {
  border-color: rgba(15, 23, 42, 0.22);
  transform: translateY(-1px);
}

.client-portal-inline-form{display:inline-flex;align-items:center;margin:0}
.client-portal-notification.is-read{opacity:.84}
.client-portal-notification__head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;margin-bottom:.35rem}
.client-portal-notification__actions{display:flex;gap:.65rem;flex-wrap:wrap;align-items:center;margin-top:.75rem}


.client-portal-chat-drawer{position:sticky;bottom:1.25rem;z-index:20;display:grid;gap:.9rem;margin-bottom:1.15rem}
.client-portal-chat-drawer__toggle{display:flex;align-items:center;gap:.9rem;width:100%;padding:1rem 1.1rem;border:none;border-radius:24px;background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff;box-shadow:0 18px 45px rgba(15,23,42,.18);cursor:pointer;text-align:left}
.client-portal-chat-drawer__toggle-icon{display:inline-flex;align-items:center;justify-content:center;width:2.8rem;height:2.8rem;border-radius:18px;background:rgba(255,255,255,.14);flex-shrink:0}.client-portal-chat-drawer__toggle-icon svg{width:1.4rem;height:1.4rem;display:block}
.client-portal-chat-drawer__toggle-copy{display:grid;gap:.15rem;min-width:0}.client-portal-chat-drawer__toggle-copy strong{font-size:1rem}.client-portal-chat-drawer__toggle-copy span{font-size:.88rem;color:rgba(255,255,255,.78);line-height:1.5}
.client-portal-chat-drawer__badge{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;min-width:2rem;height:2rem;padding:0 .5rem;border-radius:999px;background:#fff;color:#0f172a;font-weight:800;font-size:.88rem;box-shadow:0 10px 28px rgba(15,23,42,.18)}
.client-portal-chat-drawer__panel{position:fixed;right:1.5rem;bottom:1.4rem;width:min(28rem,calc(100vw - 2rem));max-height:min(78vh,50rem);display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:.95rem;padding:1rem;border-radius:28px;border:1px solid rgba(148,163,184,.18);background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,252,.98));box-shadow:0 28px 70px rgba(15,23,42,.22);backdrop-filter:blur(16px)}
.client-portal-chat-drawer.is-open .client-portal-chat-drawer__toggle{box-shadow:0 24px 60px rgba(15,23,42,.24)}
.client-portal-chat-drawer__head{display:flex;gap:1rem;justify-content:space-between;align-items:flex-start}.client-portal-chat-drawer__head strong{display:block;color:#0f172a;font-size:1rem}.client-portal-chat-drawer__head span{display:block;margin-top:.18rem;color:#64748b;font-size:.87rem;line-height:1.55}
.client-portal-chat-drawer__actions{display:flex;align-items:center;gap:.6rem}.client-portal-chat-drawer__close{display:inline-flex;align-items:center;justify-content:center;width:2.4rem;height:2.4rem;border-radius:999px;border:1px solid rgba(148,163,184,.25);background:#fff;color:#0f172a;font-size:1.45rem;line-height:1;cursor:pointer}
.client-portal-chat-drawer__thread{display:grid;gap:.8rem;overflow:auto;padding-right:.2rem;max-height:18rem}.client-portal-message--drawer{padding:.85rem .95rem;border-radius:22px;box-shadow:0 10px 26px rgba(15,23,42,.05)}
.client-portal-chat-drawer__grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.client-portal-message-form--drawer{padding:0;border:none;background:transparent;gap:.75rem}.client-portal-message-form--drawer textarea{min-height:110px}.client-portal-actions--drawer{justify-content:flex-end}
@media (max-width: 1024px){.client-portal-chat-drawer__panel{right:1rem;bottom:1rem;width:min(30rem,calc(100vw - 1.2rem));max-height:76vh}}
@media (max-width: 720px){.client-portal-chat-drawer{position:sticky;bottom:.8rem}.client-portal-chat-drawer__toggle{padding:.95rem 1rem;border-radius:22px}.client-portal-chat-drawer__panel{right:.6rem;left:.6rem;bottom:.7rem;width:auto;border-radius:24px;padding:.9rem}.client-portal-chat-drawer__grid{grid-template-columns:1fr}.client-portal-chat-drawer__actions{gap:.45rem}.client-portal-chat-drawer__head{gap:.75rem}.client-portal-chat-drawer__head span{font-size:.84rem}}


.client-portal-chat-open {
  overflow: hidden;
}

.client-portal-chat-drawer__backdrop {
  position: fixed;
  inset: 0;
  border: 0;
  background: rgba(15, 23, 42, 0.32);
  backdrop-filter: blur(2px);
  z-index: 18;
}

.client-portal-chat-drawer__panel {
  z-index: 19;
}

.client-portal-chat-drawer__note {
  display: inline-flex;
  align-items: center;
  padding: 0.55rem 0.8rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.06);
  color: #334155;
  font-size: 0.8rem;
  line-height: 1.45;
  max-width: 22rem;
}

.client-portal-emoji-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0.15rem 0 0.55rem;
}

.client-portal-emoji-bar__button {
  border: 1px solid rgba(148, 163, 184, 0.25);
  background: #fff;
  color: #0f172a;
  border-radius: 999px;
  min-width: 2.4rem;
  height: 2.4rem;
  padding: 0 0.55rem;
  font-size: 1rem;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.client-portal-emoji-bar__button:hover {
  transform: translateY(-1px);
  border-color: rgba(15, 23, 42, 0.18);
}

.client-portal-chat-context{display:grid;gap:.7rem;padding:.9rem 1rem;border:1px solid rgba(148,163,184,.18);border-radius:20px;background:linear-gradient(180deg,rgba(248,250,252,.96),rgba(241,245,249,.92));box-shadow:inset 0 1px 0 rgba(255,255,255,.65)}
.client-portal-chat-context__head{display:grid;gap:.18rem}.client-portal-chat-context__head strong{font-size:.9rem;color:#0f172a}.client-portal-chat-context__head span{font-size:.8rem;line-height:1.6;color:#64748b}
.client-portal-chat-projects{display:flex;flex-wrap:wrap;gap:.55rem}.client-portal-chat-project-pill{display:inline-flex;align-items:center;justify-content:center;padding:.5rem .8rem;border-radius:999px;border:1px solid rgba(15,23,42,.08);background:#fff;color:#0f172a;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .18s ease;box-shadow:0 8px 18px rgba(15,23,42,.04)}
.client-portal-chat-project-pill:hover,.client-portal-chat-project-pill.is-active{border-color:rgba(15,23,42,.26);background:#0f172a;color:#fff;transform:translateY(-1px)}
.client-portal-field__hint--muted{opacity:.78}.client-portal-message-form--drawer textarea{resize:none;overflow:hidden}
.client-portal-message--drawer .client-portal-attachments{margin-top:.7rem}
.client-portal-chat-drawer__thread{scroll-behavior:smooth}

.client-portal-chat-drawer__context-pill{display:inline-flex;align-items:center;justify-content:center;padding:.45rem .75rem;border-radius:999px;background:rgba(255,255,255,.14);color:#fff;font-weight:700;font-size:.78rem;white-space:nowrap;max-width:14rem;overflow:hidden;text-overflow:ellipsis}
.client-portal-chat-drawer__head--rich{gap:1.2rem}
.client-portal-chat-drawer__priority-row{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin-top:.65rem}.client-portal-chat-drawer__priority-label{display:inline-flex;align-items:center;padding:.28rem .6rem;border-radius:999px;background:rgba(15,23,42,.06);color:#475569;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.client-portal-chat-drawer__priority-project{font-size:.88rem;color:#0f172a}
.client-portal-chat-date-separator{display:flex;justify-content:center;margin:.1rem 0}.client-portal-chat-date-separator span{display:inline-flex;align-items:center;justify-content:center;padding:.28rem .75rem;border-radius:999px;background:rgba(226,232,240,.72);color:#475569;font-size:.72rem;font-weight:700;letter-spacing:.02em}
.client-portal-chat-route-badge{display:inline-flex;align-items:center;justify-content:center;padding:.45rem .75rem;border-radius:999px;background:rgba(15,23,42,.92);color:#fff;font-size:.78rem;font-weight:700;box-shadow:0 10px 24px rgba(15,23,42,.12)}.client-portal-chat-route-badge.is-email{background:#fff;color:#0f172a;border:1px solid rgba(15,23,42,.14)}
.client-portal-quick-replies{display:flex;flex-wrap:wrap;gap:.55rem}.client-portal-quick-replies__button{display:inline-flex;align-items:center;justify-content:center;padding:.48rem .78rem;border-radius:999px;border:1px solid rgba(148,163,184,.22);background:#fff;color:#0f172a;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .18s ease;box-shadow:0 8px 18px rgba(15,23,42,.04)}.client-portal-quick-replies__button:hover{transform:translateY(-1px);border-color:rgba(15,23,42,.24);background:#f8fafc}
.client-portal-chat-meta-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.85rem}.client-portal-chat-counter{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .55rem;border-radius:999px;background:rgba(15,23,42,.06);color:#475569;font-size:.72rem;font-weight:700;white-space:nowrap}
.client-portal-attachment-preview{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.55rem}.client-portal-attachment-preview__summary{width:100%;font-size:.76rem;color:#475569;font-weight:700}.client-portal-attachment-preview__item,.client-portal-attachment-preview__empty{display:inline-flex;align-items:center;max-width:100%;padding:.42rem .7rem;border-radius:999px;background:#fff;border:1px solid rgba(148,163,184,.2);color:#334155;font-size:.76rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.client-portal-message--drawer{position:relative}.client-portal-message--drawer:before{content:'';position:absolute;top:1rem;left:.7rem;width:.35rem;height:calc(100% - 2rem);border-radius:999px;background:rgba(15,23,42,.05)}.client-portal-message--self.client-portal-message--drawer:before{background:rgba(59,130,246,.18)}
.client-portal-emoji-bar--expanded{gap:.48rem}
@media (max-width: 720px){.client-portal-chat-drawer__context-pill{display:none}.client-portal-chat-meta-row{flex-direction:column;align-items:flex-start}.client-portal-chat-counter{margin-top:.2rem}}


.client-portal-profile-avatar.has-image,
.client-portal-mini-profile__avatar.has-image {
  background: rgba(226, 232, 240, 0.9);
  color: transparent;
}

.client-portal-form-section {
  display: grid;
  gap: 0.9rem;
  padding: 1rem 1.05rem;
  border: 1px solid rgba(148, 163, 184, 0.16);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.96));
}

.client-portal-form-section h3 {
  margin: 0;
  font-size: 0.98rem;
  color: #0f172a;
}

.client-portal-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

.client-portal-field--wide {
  grid-column: 1 / -1;
}

.client-portal-field input[readonly] {
  background: rgba(248, 250, 252, 0.94);
  color: #64748b;
}

.client-portal-field input[type="date"],
.client-portal-field input[type="tel"] {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid rgba(148, 163, 184, 0.26);
  border-radius: 16px;
  padding: 0.86rem 0.95rem;
  font: inherit;
  color: #0f172a;
  background: #ffffff;
}

.client-portal-field input[type="date"]:focus,
.client-portal-field input[type="tel"]:focus {
  outline: none;
  border-color: rgba(15, 23, 42, 0.35);
  box-shadow: 0 0 0 4px rgba(15, 23, 42, 0.06);
}

.client-portal-chat-drawer__panel {
  width: min(34rem, calc(100vw - 2rem));
  max-height: min(84vh, 58rem);
  grid-template-rows: auto minmax(22rem, 1fr) auto;
}

.client-portal-chat-drawer__head--compact {
  align-items: center;
  gap: 0.75rem;
}

.client-portal-chat-toolbar {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
  margin-top: 0.45rem;
}

.client-portal-chat-toolbar__pill {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.06);
  color: #334155;
  font-size: 0.76rem;
  font-weight: 700;
}

.client-portal-chat-drawer__head strong {
  font-size: 1.05rem;
}

.client-portal-chat-drawer__thread {
  min-height: 24rem;
  max-height: none;
  padding-right: 0.1rem;
}

.client-portal-chat-composer-head {
  display: grid;
  gap: 0.75rem;
}

.client-portal-field--compact label {
  margin-bottom: 0.15rem;
}

.client-portal-chat-composer-meta {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

.client-portal-chat-composer-meta label {
  margin: 0;
}

.client-portal-chat-attachments-row {
  display: grid;
  gap: 0.6rem;
}

.client-portal-btn--compact {
  padding: 0.75rem 1rem;
  justify-self: start;
}

.client-portal-attachment-preview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 0.6rem;
}

.client-portal-attachment-preview__summary {
  grid-column: 1 / -1;
}

.client-portal-attachment-preview__card {
  display: grid;
  gap: 0.45rem;
  padding: 0.55rem;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: #fff;
  min-width: 0;
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.04);
}

.client-portal-attachment-preview__card img,
.client-portal-attachment-preview__card video {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 14px;
  background: #e2e8f0;
}

.client-portal-attachment-preview__card strong {
  font-size: 1.1rem;
}

.client-portal-attachment-preview__card span {
  font-size: 0.76rem;
  line-height: 1.45;
  color: #334155;
  overflow: hidden;
  text-overflow: ellipsis;
}

.client-portal-message-attachments {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 0.65rem;
  margin-top: 0.7rem;
}

.client-portal-message-attachment {
  display: grid;
  gap: 0.45rem;
  padding: 0.55rem;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.16);
  background: rgba(255,255,255,0.96);
}

.client-portal-message-attachment__media {
  display: block;
  border-radius: 14px;
  overflow: hidden;
  background: #e2e8f0;
}

.client-portal-message-attachment__media img,
.client-portal-message-attachment__media video,
.client-portal-message-attachment video.client-portal-message-attachment__media {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
}

.client-portal-message-attachment__file {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.8rem;
  border-radius: 14px;
  background: rgba(248, 250, 252, 0.98);
  text-decoration: none;
  color: #0f172a;
}

.client-portal-message-attachment__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.55rem;
  min-width: 0;
}

.client-portal-message-attachment__meta span {
  font-size: 0.75rem;
  color: #475569;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.client-portal-message-attachment__meta a {
  font-size: 0.75rem;
  font-weight: 700;
  color: #0f172a;
  text-decoration: none;
}

@media (max-width: 900px) {
  .client-portal-form-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .client-portal-chat-drawer__panel {
    right: 0.5rem;
    left: 0.5rem;
    width: auto;
    max-height: 86vh;
    padding: 0.85rem;
  }

  .client-portal-chat-drawer__thread {
    min-height: 18rem;
  }

  .client-portal-chat-composer-meta {
    flex-direction: column;
    align-items: flex-start;
  }
}


.client-portal-avatar.has-image,
.client-portal-avatar--large.has-image,
.client-portal-mini-profile__avatar.has-image,
.client-portal-profile-avatar.has-image{background-color:#e2e8f0;background-position:center;background-repeat:no-repeat;background-size:cover;color:transparent}
.client-portal-avatar.has-image img,.client-portal-avatar--large.has-image img,.client-portal-mini-profile__avatar.has-image img,.client-portal-profile-avatar.has-image img{opacity:1;display:block}


.client-portal-shell--single{grid-template-columns:minmax(0,1fr)}
.client-portal-card--management .client-portal-manage-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(14rem,1fr));gap:1rem}
.client-portal-manage-card{display:grid;gap:.45rem;padding:1rem 1.1rem;border-radius:22px;border:1px solid rgba(148,163,184,.18);background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,252,.96));box-shadow:0 12px 28px rgba(15,23,42,.06);text-decoration:none;color:#0f172a;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.client-portal-manage-card:hover{transform:translateY(-2px);border-color:rgba(15,23,42,.16);box-shadow:0 18px 34px rgba(15,23,42,.1)}
.client-portal-manage-card span{color:#475569;font-size:.92rem}
.client-portal-card--profile-page .client-portal-card__head h1{margin:0;font-size:1.55rem}.client-portal-page-actions{display:flex;gap:.7rem;flex-wrap:wrap}
.client-portal-mini-profile--page{margin-bottom:1rem}.client-portal-settings-layout{display:grid;grid-template-columns:14rem minmax(0,1fr);gap:1.2rem}.client-portal-settings-avatar-card{display:grid;gap:.7rem;align-content:start;padding:1rem;border-radius:24px;border:1px solid rgba(148,163,184,.18);background:rgba(248,250,252,.9);text-align:center}.client-portal-settings-avatar-card span{color:#64748b;font-size:.9rem}.client-portal-settings-main{display:grid;gap:1rem}.client-portal-settings-hints{display:grid;gap:.8rem}.client-portal-settings-hints div{display:grid;gap:.2rem;padding:.9rem 1rem;border-radius:18px;background:rgba(248,250,252,.92);border:1px solid rgba(148,163,184,.16)}.client-portal-settings-hints span{color:#64748b;font-size:.92rem}
.client-portal-chat-drawer__panel{z-index:120;gap:.7rem;padding:.9rem .9rem .85rem;width:min(27rem,calc(100vw - 1rem));max-height:min(84vh,48rem)}
.client-portal-chat-drawer__head--compact{display:flex;align-items:flex-start;justify-content:space-between;gap:.8rem}.client-portal-chat-toolbar--compact{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin-top:.35rem}
.client-portal-chat-drawer__close{position:relative;z-index:3}
.client-portal-chat-drawer__thread{max-height:42vh;min-height:16rem;padding-right:.1rem;scrollbar-gutter:stable both-edges}
.client-portal-message--drawer{padding:.68rem .8rem;border-radius:18px;gap:.35rem}.client-portal-message__meta{gap:.4rem;font-size:.76rem}.client-portal-message__meta strong{font-size:.8rem}.client-portal-message__body{font-size:.9rem;line-height:1.52}
.client-portal-message__actions{display:flex;justify-content:flex-end;margin-top:.35rem}
.client-portal-chat-composer-head--compact{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.7rem;align-items:end}.client-portal-chat-tools{display:flex;align-items:center;gap:.45rem}.client-portal-field--grow{min-width:0}
.client-portal-icon-button{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:999px;border:1px solid rgba(148,163,184,.2);background:#fff;color:#0f172a;cursor:pointer;font-size:1.05rem;box-shadow:0 8px 18px rgba(15,23,42,.05)}
.client-portal-emoji-bar--compact{display:flex;align-items:center;gap:.32rem;flex-wrap:wrap;max-width:13rem}.client-portal-emoji-bar--compact .client-portal-emoji-bar__button{padding:.25rem .42rem;border-radius:12px;font-size:1rem}
.client-portal-chat-projects--compact{gap:.45rem;max-height:4.7rem;overflow:auto;padding-bottom:.1rem}.client-portal-chat-project-pill{padding:.4rem .68rem;font-size:.75rem}
.client-portal-field--message-box textarea{min-height:74px;max-height:148px;border-radius:18px}
.client-portal-chat-meta-row{margin-top:.4rem}.client-portal-chat-dropzone{display:flex;align-items:center;gap:.55rem;justify-content:center;padding:.7rem .85rem;border:1px dashed rgba(148,163,184,.36);border-radius:18px;background:rgba(248,250,252,.94);color:#475569;font-size:.84rem;cursor:pointer;transition:all .18s ease}.client-portal-chat-dropzone:hover,.client-portal-chat-dropzone.is-dragover{border-color:rgba(14,165,233,.46);background:rgba(224,242,254,.58);color:#0f172a}.client-portal-chat-dropzone__icon{font-size:1rem}
.client-portal-attachment-preview--compact{margin-top:0;max-height:7.2rem;overflow:auto;padding-right:.1rem}.client-portal-attachment-preview__card{max-width:7.4rem;padding:.35rem;border-radius:14px;background:#fff;border:1px solid rgba(148,163,184,.16);display:grid;gap:.3rem}.client-portal-attachment-preview__card img,.client-portal-attachment-preview__card video{width:100%;height:4.2rem;object-fit:cover;border-radius:10px;background:#e2e8f0}.client-portal-attachment-preview__card span{font-size:.72rem;color:#334155;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.client-portal-message-attachments{gap:.45rem}.client-portal-message-attachment{padding:.35rem;border-radius:16px}.client-portal-message-attachment__meta{font-size:.72rem}.client-portal-message-attachment__media img,.client-portal-message-attachment__media video,.client-portal-message-attachment--video .client-portal-message-attachment__media{max-height:11rem}
@media (max-width: 900px){.client-portal-settings-layout{grid-template-columns:1fr}.client-portal-chat-drawer__panel{right:.5rem;bottom:.5rem;width:min(100vw - 1rem,27rem)}.client-portal-chat-drawer__thread{max-height:38vh}}
