/* =====================================================================
   ORBIT — SCREENS LAYOUT
   Layouts compartilhados entre Dashboard, Board, Timeline.
   ===================================================================== */


/* ─────────────────────────────────────────────────────────────────────
   APP SHELL — sidebar + main column
   ───────────────────────────────────────────────────────────────────── */

.app-shell {
  display: flex;
  min-height: 100vh;
  background-color: var(--color-bg-primary);
  color: var(--color-text-primary);
}

.app-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0; /* permite content shrink */
}

.app-content {
  flex: 1;
  padding: var(--spacing-8) var(--spacing-10);
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-8);
}

@media (max-width: 900px) {
  .sidebar { display: none; }
  .app-content { padding: var(--spacing-6) var(--spacing-5); }
}


/* ─────────────────────────────────────────────────────────────────────
   DASHBOARD — page-specific layout
   ───────────────────────────────────────────────────────────────────── */

.dashboard-greeting {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--spacing-4);
  flex-wrap: wrap;
}
.dashboard-greeting__text {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
}
.dashboard-greeting__eyebrow {
  color: var(--color-text-tertiary);
}
.dashboard-greeting__title {
  color: var(--color-text-primary);
}
.dashboard-greeting__actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-2);
}


/* ─────────────────────────────────────────────────────────────────────
   STATS GRID — 4 KPI cards
   ───────────────────────────────────────────────────────────────────── */

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-4);
}
@media (max-width: 900px) { .stats-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .stats-grid { grid-template-columns: 1fr; } }

.kpi-card {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3);
  padding: var(--spacing-5) var(--spacing-6);
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl);
  transition: border-color 200ms ease, transform 200ms ease;
}
.kpi-card:hover {
  border-color: var(--color-border-default);
  transform: translateY(-1px);
}

.kpi-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.kpi-card__label {
  color: var(--color-text-secondary);
}
.kpi-card__icon {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  background-color: var(--color-bg-secondary);
  color: var(--color-text-tertiary);
}

.kpi-card__value {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: 36px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--color-text-primary);
}

.kpi-card__delta {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-1);
  font-size: 12px;
}
.kpi-card__delta--up   { color: var(--color-feedback-success); }
.kpi-card__delta--down { color: var(--color-feedback-error);   }
.kpi-card__delta--flat { color: var(--color-text-tertiary);    }


/* ─────────────────────────────────────────────────────────────────────
   SECTION block — recurring "Active projects" / "Recent activity"
   ───────────────────────────────────────────────────────────────────── */

.block {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5);
}
.block__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--spacing-4);
}
.block__title {
  color: var(--color-text-primary);
}
.block__action {
  color: var(--color-text-secondary);
  font-size: 14px;
  text-decoration: none;
}
.block__action:hover { color: var(--color-text-primary); }


/* ─────────────────────────────────────────────────────────────────────
   PROJECT CARD — grid de projetos
   ───────────────────────────────────────────────────────────────────── */

.projects-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-4);
}
@media (max-width: 800px) { .projects-grid { grid-template-columns: 1fr; } }

.project-card {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
  padding: var(--spacing-5) var(--spacing-6);
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl);
  cursor: pointer;
  transition: border-color 200ms ease, transform 200ms ease;
}
.project-card:hover {
  border-color: var(--color-border-default);
  transform: translateY(-2px);
}

.project-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--spacing-3);
}
.project-card__head-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1);
  min-width: 0;
}
.project-card__name {
  color: var(--color-text-primary);
  /* clamp 1 line */
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.project-card__client {
  color: var(--color-text-secondary);
}

.project-card__tags {
  display: flex;
  gap: var(--spacing-2);
  flex-wrap: wrap;
}

.project-card__progress-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
}
.project-card__progress-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.project-card__progress-label {
  color: var(--color-text-secondary);
}
.project-card__progress-value {
  color: var(--color-text-primary);
  font-weight: 500;
}

.project-card__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-3);
  padding-top: var(--spacing-3);
  border-top: 1px solid var(--color-border-subtle);
}


/* ─────────────────────────────────────────────────────────────────────
   ACTIVITY FEED — timeline vertical
   ───────────────────────────────────────────────────────────────────── */

.activity-feed {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1);
}

.activity-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-3);
  padding: var(--spacing-3) var(--spacing-4);
  border-radius: var(--radius-md);
  transition: background-color 150ms ease;
}
.activity-item:hover {
  background-color: var(--color-bg-secondary);
}

.activity-item__text {
  flex: 1;
  color: var(--color-text-secondary);
  font-size: 14px;
}
.activity-item__text strong {
  color: var(--color-text-primary);
  font-weight: 500;
}

.activity-item__time {
  color: var(--color-text-tertiary);
  font-size: 12px;
  white-space: nowrap;
  flex-shrink: 0;
}


/* ─────────────────────────────────────────────────────────────────────
   BOARD — tela de aprovações com peça + pins de comentários
   ───────────────────────────────────────────────────────────────────── */

.board-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-4);
  flex-wrap: wrap;
}
.board-header__info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
}
.board-header__meta {
  display: flex;
  align-items: center;
  gap: var(--spacing-3);
  color: var(--color-text-secondary);
  font-size: 13px;
}
.board-header__meta-dot {
  width: 3px;
  height: 3px;
  border-radius: var(--radius-full);
  background-color: var(--color-text-tertiary);
  display: inline-block;
}
.board-header__actions {
  display: flex;
  gap: var(--spacing-2);
}

/* Layout 2 colunas: preview + thread panel */
.board-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: var(--spacing-6);
  align-items: start;
}
@media (max-width: 1100px) {
  .board-layout { grid-template-columns: 1fr; }
}

/* Preview area — onde a peça vive, com pins por cima */
.preview-area {
  position: relative;
  aspect-ratio: 3 / 4;
  max-width: 720px;
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-2xl);
  overflow: hidden;
  user-select: none;
}

/* ── POSTER ── peça mockup (vive dentro de preview-area)
   Grid de 4 rows: top (auto) | hero (1fr, centralizado) | lineup (auto) | foot (auto).
   Lineup cola natural no foot. Hero vive no espaço expansível (1fr) e se centraliza. */
.poster {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-rows: auto 1fr auto auto;
  padding: clamp(28px, 6%, 56px);
  background:
    radial-gradient(circle at 80% 8%, rgba(245, 176, 138, 0.18), transparent 50%),
    linear-gradient(180deg, var(--color-terracotta-700) 0%, var(--color-terracotta-900) 100%);
  color: var(--color-neutral-50);
  font-family: 'Space Grotesk', sans-serif;
}

.poster__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(250, 250, 248, 0.65);
}
.poster__top strong { color: var(--color-neutral-50); font-weight: 500; }

.poster__hero {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-self: center; /* centraliza no espaço 1fr da row 2 */
}

.poster__lineup {
  /* row 3 do grid — cola natural no foot, sem auto margin */
}
.poster__title {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: clamp(54px, 11vw, 96px);
  line-height: 0.95;
  letter-spacing: -0.04em;
  color: var(--color-neutral-50);
}
.poster__subtitle {
  font-family: 'Instrument Sans', sans-serif;
  font-weight: 500;
  font-size: clamp(15px, 2.4vw, 22px);
  line-height: 1.3;
  color: rgba(250, 250, 248, 0.85);
  max-width: 80%;
}

.poster__lineup {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4px 24px;
  font-family: 'Instrument Sans', sans-serif;
  font-size: clamp(13px, 1.7vw, 16px);
  font-weight: 500;
  color: var(--color-neutral-50);
}

.poster__foot {
  margin-top: clamp(20px, 3%, 32px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-family: 'Instrument Sans', sans-serif;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(250, 250, 248, 0.65);
}
.poster__brand {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--color-neutral-50);
  font-weight: 500;
}

/* ── PIN ── círculo de feedback posicionado sobre a peça */
.pin {
  position: absolute;
  transform: translate(-50%, -50%);
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-action-primary);
  color: var(--color-text-on-action);
  border: 2px solid var(--color-neutral-0);
  border-radius: var(--radius-full);
  font-family: 'Instrument Sans', sans-serif;
  font-weight: 600;
  font-size: 12px;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
  transition: transform 200ms var(--ease-out-expo), box-shadow 200ms ease;
  z-index: 5;
}
.pin:hover,
.pin.is-active {
  transform: translate(-50%, -50%) scale(1.1);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.35);
}

/* Pulse ring no pin ativo */
.pin::after {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: var(--radius-full);
  background-color: var(--color-action-primary);
  opacity: 0;
  z-index: -1;
}
.pin.is-active::after {
  animation: pinPulse 1.4s ease-out infinite;
}
@keyframes pinPulse {
  0%   { transform: scale(1);   opacity: 0.4; }
  100% { transform: scale(2.2); opacity: 0;   }
}

/* ── PIN BUBBLE ── popup que aparece ao lado quando pin tá ativo */
.pin-bubble {
  position: absolute;
  transform: translate(0, -50%);
  min-width: 220px;
  max-width: 260px;
  padding: var(--spacing-3) var(--spacing-4);
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
  opacity: 0;
  transform-origin: left center;
  transform: translate(0, -50%) scale(0.92);
  transition: opacity 240ms var(--ease-out-expo),
              transform 280ms var(--ease-out-expo);
  pointer-events: none;
  z-index: 6;
}
.pin-bubble.is-active {
  opacity: 1;
  transform: translate(0, -50%) scale(1);
  pointer-events: auto;
}
/* Variants pra bubbles que abrem pra esquerda */
.pin-bubble--left {
  transform: translate(-100%, -50%) scale(0.92);
  transform-origin: right center;
}
.pin-bubble--left.is-active {
  transform: translate(-100%, -50%) scale(1);
}

.pin-bubble__author {
  display: flex;
  align-items: center;
  gap: var(--spacing-2);
}
.pin-bubble__author-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-primary);
}
.pin-bubble__author-time {
  font-size: 11px;
  color: var(--color-text-tertiary);
  margin-left: auto;
}
.pin-bubble__text {
  font-size: 13px;
  line-height: 1.5;
  color: var(--color-text-secondary);
}

/* ── DEMO CURSOR ── cursor animado que percorre os pins */
.demo-cursor {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 22px;
  height: 22px;
  transform: translate(-30%, -10%);
  pointer-events: none;
  z-index: 10;
  transition: left 850ms var(--ease-out-expo),
              top 850ms var(--ease-out-expo);
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.35));
}
.demo-cursor svg { display: block; width: 100%; height: 100%; }
.demo-cursor.is-clicking {
  animation: cursorClick 220ms ease-out;
}
@keyframes cursorClick {
  0%   { transform: translate(-30%, -10%) scale(1); }
  50%  { transform: translate(-30%, -10%) scale(0.78); }
  100% { transform: translate(-30%, -10%) scale(1); }
}

/* "Marina" tag flutuando junto do cursor — dá identidade humana à demo */
.demo-cursor__label {
  position: absolute;
  top: 22px;
  left: 16px;
  padding: 2px 8px;
  background-color: var(--color-action-primary);
  color: var(--color-text-on-action);
  border-radius: var(--radius-sm);
  font-family: 'Instrument Sans', sans-serif;
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
}

/* ── COMMENTS PANEL ── lateral com lista expandida de comentários */
.comments-panel {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
  padding: var(--spacing-5);
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl);
  position: sticky;
  top: 80px;
  max-height: calc(100vh - 100px);
  overflow-y: auto;
}
.comments-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: var(--spacing-3);
  border-bottom: 1px solid var(--color-border-subtle);
}
.comments-panel__title {
  color: var(--color-text-primary);
}
.comments-panel__count {
  font-size: 12px;
  color: var(--color-text-tertiary);
}

.comment-thread {
  display: flex;
  gap: var(--spacing-3);
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid var(--color-border-subtle);
}
.comment-thread:last-child { border-bottom: none; }

.comment-thread__pin {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-action-primary);
  color: var(--color-text-on-action);
  border-radius: var(--radius-full);
  font-size: 11px;
  font-weight: 600;
  margin-top: 2px;
}
.comment-thread.is-resolved .comment-thread__pin {
  background-color: var(--color-feedback-success);
}

.comment-thread__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
  min-width: 0;
}
.comment-thread__header {
  display: flex;
  align-items: center;
  gap: var(--spacing-2);
}
.comment-thread__author {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-primary);
}
.comment-thread__time {
  font-size: 11px;
  color: var(--color-text-tertiary);
}
.comment-thread__text {
  font-size: 13px;
  line-height: 1.55;
  color: var(--color-text-secondary);
}
.comment-thread__replies {
  font-size: 12px;
  color: var(--color-text-tertiary);
  cursor: pointer;
}
.comment-thread__replies:hover { color: var(--color-text-primary); }

/* ─────────────────────────────────────────────────────────────────────
   TIMELINE — kanban com card "voador" entre colunas
   ───────────────────────────────────────────────────────────────────── */

.timeline-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--spacing-4);
  flex-wrap: wrap;
}
.timeline-header__text {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
}
.timeline-header__actions {
  display: flex;
  gap: var(--spacing-2);
  align-items: center;
}

.kanban {
  position: relative; /* anchor pro flying card */
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-4);
  min-height: 580px;
}
@media (max-width: 1100px) {
  .kanban { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .kanban { grid-template-columns: 1fr; }
}

.kanban-column {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3);
  padding: var(--spacing-4);
  background-color: var(--color-bg-secondary);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl);
  min-height: 480px;
}

.kanban-column__head {
  display: flex;
  align-items: center;
  gap: var(--spacing-2);
  padding-bottom: var(--spacing-3);
  border-bottom: 1px solid var(--color-border-subtle);
}
.kanban-column__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  flex-shrink: 0;
}
.kanban-column[data-col="briefing"] .kanban-column__dot { background-color: var(--color-accent-info); }
.kanban-column[data-col="design"]   .kanban-column__dot { background-color: var(--color-text-tertiary); }
.kanban-column[data-col="review"]   .kanban-column__dot { background-color: var(--color-action-primary); }
.kanban-column[data-col="done"]     .kanban-column__dot { background-color: var(--color-feedback-success); }

.kanban-column__title {
  color: var(--color-text-primary);
  font-weight: 500;
}
.kanban-column__count {
  margin-left: auto;
  color: var(--color-text-tertiary);
  font-size: 12px;
}

.kanban-column__cards {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3);
  flex: 1;
}

/* Card individual no kanban (mais compacto que .project-card) */
.kanban-card {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
  padding: var(--spacing-3) var(--spacing-4);
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: border-color 180ms ease, transform 180ms ease;
}
.kanban-card:hover {
  border-color: var(--color-border-default);
  transform: translateY(-1px);
}

.kanban-card__tags {
  display: flex;
  gap: var(--spacing-2);
  flex-wrap: wrap;
}

.kanban-card__title {
  color: var(--color-text-primary);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
}
.kanban-card__client {
  color: var(--color-text-secondary);
  font-size: 12px;
}

.kanban-card__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-2);
  margin-top: var(--spacing-1);
}

/* Card "voador" — anima entre 2 colunas em loop infinito.
   Position absolute relative à .kanban; JS atualiza left/top com getBoundingClientRect. */
.kanban-card--flying {
  position: absolute;
  /* width inicial — JS pode ajustar pra match column width */
  width: calc(25% - var(--spacing-3));
  /* Default position (vai ser override pelo JS antes da animação começar) */
  left: 0;
  top: 0;
  z-index: 10;
  pointer-events: none;
  border-color: var(--color-action-primary);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
  transition:
    left 1100ms cubic-bezier(0.16, 1, 0.3, 1),
    top  1100ms cubic-bezier(0.16, 1, 0.3, 1),
    transform 600ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 400ms ease;
  transform: scale(1) rotate(-2deg); /* slight tilt enquanto "voa" */
}

/* Placeholder ghost no slot onde o card original "vive" — fade in/out conforme o flying está no source ou no destino */
.kanban-card--ghost {
  background-color: transparent;
  border: 1px dashed var(--color-border-default);
  color: var(--color-text-tertiary);
  cursor: default;
  opacity: 0.6;
  pointer-events: none;
}

@media (max-width: 1100px) {
  .kanban-card--flying { width: calc(50% - var(--spacing-3)); }
}
@media (max-width: 640px) {
  .kanban-card--flying { width: calc(100% - 32px); }
}

/* ─────────────────────────────────────────────────────────────────────
   FILTER BAR — usada na lista de projetos pra tabs/filtros
   ───────────────────────────────────────────────────────────────────── */

.filter-tabs {
  display: flex;
  gap: var(--spacing-1);
  align-items: center;
}
.filter-tab {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2);
  padding: 6px var(--spacing-3);
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  font-family: 'Instrument Sans', sans-serif;
  font-size: 14px;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: background-color 150ms, color 150ms;
}
.filter-tab:hover {
  background-color: var(--color-bg-secondary);
  color: var(--color-text-primary);
}
.filter-tab--active {
  background-color: var(--color-bg-elevated);
  color: var(--color-text-primary);
  font-weight: 500;
}
.filter-tab__count {
  color: var(--color-text-tertiary);
  font-size: 12px;
}
