/* ============================================================
   Command Dashboard — styles.css
   Palette: matches dashboard.amorousonline.com
   Fonts: Work Sans (body) · Outfit (headings) · Geist Mono (mono)
   ============================================================ */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Work+Sans:wght@400;500;600&family=Outfit:wght@500;600;700&display=swap');

/* ── Geist Mono via CDN ── */
@import url('https://cdn.jsdelivr.net/npm/geist@1.3.0/dist/fonts/geist-mono/style.css');

/* ── Design Tokens ── */
:root {
  /* Exact palette from dashboard.amorousonline.com */
  --bg-base:   #07070B;
  --bg-card:   #101018;
  --bg-card2:  #171722;
  --bg-card3:  #1E1E2C;
  --border:    #242434;
  --border-light: #343448;
  --text-primary:   #ECECF7;
  --text-secondary: #686884;
  --text-dim:       #303046;

  --teal:       #00D4B2;
  --amber:      #FFBA2A;
  --indigo:     #806CFF;
  --green:      #30DA60;
  --red:        #FF4242;
  --monday-blue:#5A8AFF;

  /* Fonts */
  --font-body:    'Work Sans', system-ui, sans-serif;
  --font-heading: 'Outfit', system-ui, sans-serif;
  --font-mono:    'Geist Mono', 'Fira Code', monospace;

  /* Spacing (4px grid) */
  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.25rem;
  --sp-6: 1.5rem;
  --sp-8: 2rem;
  --sp-10: 2.5rem;
  --sp-12: 3rem;

  /* Type scale */
  --text-xs:   clamp(0.75rem,  0.7rem  + 0.25vw, 0.8125rem);
  --text-sm:   clamp(0.8125rem,0.78rem + 0.3vw,  0.9375rem);
  --text-base: clamp(0.9375rem,0.9rem  + 0.2vw,  1rem);
  --text-lg:   clamp(1.0625rem,1rem    + 0.35vw, 1.1875rem);
  --text-xl:   clamp(1.25rem,  1.1rem  + 0.75vw, 1.625rem);

  /* Radius */
  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-pill: 9999px;

  /* Transitions */
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --transition: 180ms var(--ease);

  /* Content width */
  --max-w: 1100px;
}

/* ── Reset ── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
}

body {
  min-height: 100dvh;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text-primary);
  background-color: var(--bg-base);
  line-height: 1.6;
}

img, picture, video, canvas, svg { display: block; max-width: 100%; }
button { cursor: pointer; background: none; border: none; color: inherit; font: inherit; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
p, li { max-width: 72ch; }

:focus-visible {
  outline: 2px solid var(--teal);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

::selection { background: rgba(0,212,178,0.18); color: var(--text-primary); }

/* ── Layout ── */
.app {
  max-width: var(--max-w);
  margin-inline: auto;
  padding: var(--sp-6) var(--sp-4) var(--sp-12);
}

/* ── Header ── */
.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-3);
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--sp-6);
}

.header-left {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
}

.logo {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.logo-icon {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
}

.logo-title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  line-height: 1;
}

.logo-title span {
  color: var(--teal);
}

.clock {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  letter-spacing: 0.04em;
  padding: var(--sp-1) var(--sp-3);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  min-width: 10ch;
  text-align: center;
}

/* ── Refresh Button ── */
.btn-refresh {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  background: var(--bg-card2);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-primary);
  transition: background var(--transition), border-color var(--transition), color var(--transition);
  white-space: nowrap;
}

.btn-refresh:hover {
  background: var(--bg-card3);
  border-color: var(--border-light);
}

.btn-refresh.success {
  color: var(--green);
  border-color: rgba(48,218,96,0.35);
}

.btn-refresh .btn-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.btn-refresh .refresh-ts {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--green);
  margin-left: var(--sp-1);
}

/* Spinner */
@keyframes spin {
  to { transform: rotate(360deg); }
}
.spinner {
  width: 16px;
  height: 16px;
  border: 2px solid var(--border-light);
  border-top-color: var(--teal);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  flex-shrink: 0;
}

/* ── Top Bar (pill badges) ── */
.top-bar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-bottom: var(--sp-6);
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--radius-pill);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  border: 1px solid transparent;
  white-space: nowrap;
}

.pill-label {
  color: var(--text-secondary);
  font-weight: 400;
}

.pill-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  min-width: 1.4em;
  text-align: center;
}

/* Pill variants */
.pill--mail    { background: rgba(0,212,178,0.1);  border-color: rgba(0,212,178,0.25);  color: var(--teal); }
.pill--mention { background: rgba(128,108,255,0.1); border-color: rgba(128,108,255,0.25); color: var(--indigo); }
.pill--limbo   { background: rgba(255,186,42,0.1);  border-color: rgba(255,186,42,0.25);  color: var(--amber); }

/* ── Dashboard Grid ── */
.dashboard-grid {
  display: grid;
  gap: var(--sp-6);
  grid-template-columns: 1fr;
}

@media (min-width: 700px) {
  .dashboard-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 1000px) {
  .dashboard-grid {
    grid-template-columns: 1fr 1fr 1fr;
  }
}

/* Limbo spans full width on wide screens */
.section--limbo {
  grid-column: 1 / -1;
}

/* ── Section / Card ── */
.section {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--border);
  gap: var(--sp-3);
}

.section-title {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.section-icon {
  width: 18px;
  height: 18px;
  color: var(--text-secondary);
  flex-shrink: 0;
}

.section-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-secondary);
  background: var(--bg-card2);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  padding: 1px 8px;
}

.section-body {
  padding: var(--sp-4) var(--sp-5);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

/* ── Event Items (Calendar) ── */
.event-item {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  padding: var(--sp-3) var(--sp-4);
  background: var(--bg-card2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: border-color var(--transition);
}

.event-item:hover { border-color: var(--border-light); }

.event-time {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--teal);
  letter-spacing: 0.04em;
}

.event-title {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-primary);
  line-height: 1.3;
}

.event-join {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  margin-top: var(--sp-1);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--teal);
  transition: opacity var(--transition);
}

.event-join:hover { opacity: 0.75; }

/* ── Monday Task Groups ── */
.task-group {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.task-group-label {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding-bottom: var(--sp-1);
  border-bottom: 1px solid var(--border);
}

.task-group--overdue .task-group-label { color: var(--red); }
.task-group--today   .task-group-label { color: var(--amber); }
.task-group--tomorrow .task-group-label { color: var(--green); }

.task-item {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-card2);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color var(--transition);
}

.task-item:hover { border-color: var(--border-light); }

.task-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 6px;
}

.task-group--overdue  .task-dot { background: var(--red); }
.task-group--today    .task-dot { background: var(--amber); }
.task-group--tomorrow .task-dot { background: var(--green); }

/* ── Monday project grouping (Phase 1.5) ── */
.monday-project-header {
  font-weight: 500;
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  opacity: 0.7;
  margin-top: 8px;
  margin-left: 12px;
  margin-bottom: 2px;
  color: var(--text);
}
.monday-project-header:first-of-type {
  margin-top: 4px;
}
.task-group-label--empty {
  opacity: 0.4;
}
.task-item .task-board {
  display: none;
}


.task-name {
  font-size: var(--text-sm);
  color: var(--text-primary);
  line-height: 1.4;
  flex: 1;
}

.task-board {
  font-size: var(--text-xs);
  color: var(--monday-blue);
  font-family: var(--font-mono);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── Notion Meetings ── */
.meeting-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: var(--bg-card2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: border-color var(--transition);
}

.meeting-item:hover { border-color: var(--border-light); }

.meeting-title {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-primary);
  line-height: 1.3;
  flex: 1;
}

.meeting-date {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-secondary);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── Limbo Panel ── */
.limbo-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.limbo-item {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  gap: var(--sp-2) var(--sp-4);
  align-items: center;
  padding: var(--sp-4) var(--sp-5);
  background: var(--bg-card2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: border-color var(--transition), opacity var(--transition), transform var(--transition);
}

.limbo-item:hover { border-color: var(--border-light); }

.limbo-item.fading {
  opacity: 0;
  transform: translateX(20px);
}

.limbo-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  grid-column: 1;
  grid-row: 1;
  flex-wrap: wrap;
}

.limbo-title {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-primary);
  line-height: 1.3;
  word-break: break-word;
}

.limbo-age {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-secondary);
  white-space: nowrap;
  flex-shrink: 0;
}

.limbo-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  grid-column: 2;
  grid-row: 1 / 3;
}

.limbo-tag-row {
  grid-column: 1;
  grid-row: 2;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

/* Tag pills */
.tag {
  display: inline-flex;
  align-items: center;
  padding: 2px 10px;
  border-radius: var(--radius-pill);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.03em;
  border: 1px solid transparent;
}

.tag--work      { background: rgba(90,138,255,0.12); border-color: rgba(90,138,255,0.3);  color: var(--monday-blue); }
.tag--studio    { background: rgba(128,108,255,0.12); border-color: rgba(128,108,255,0.3); color: var(--indigo); }
.tag--personal  { background: rgba(0,212,178,0.12);  border-color: rgba(0,212,178,0.3);   color: var(--teal); }
.tag--health    { background: rgba(48,218,96,0.12);  border-color: rgba(48,218,96,0.3);   color: var(--green); }
.tag--family    { background: rgba(255,186,42,0.12); border-color: rgba(255,186,42,0.3);  color: var(--amber); }
.tag--sd\+      { background: rgba(255,66,66,0.12);  border-color: rgba(255,66,66,0.3);   color: var(--red); }
.tag--default   { background: var(--bg-card3); border-color: var(--border); color: var(--text-secondary); }

/* ── Action Buttons ── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: background var(--transition), border-color var(--transition), color var(--transition), opacity var(--transition);
  white-space: nowrap;
  border: 1px solid transparent;
}

.btn--resume {
  background: rgba(0,212,178,0.1);
  border-color: rgba(0,212,178,0.3);
  color: var(--teal);
}
.btn--resume:hover {
  background: rgba(0,212,178,0.2);
  border-color: rgba(0,212,178,0.5);
}

.btn--kill {
  background: rgba(255,66,66,0.08);
  border-color: rgba(255,66,66,0.25);
  color: var(--red);
}
.btn--kill:hover {
  background: rgba(255,66,66,0.18);
  border-color: rgba(255,66,66,0.45);
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ── Skeleton Loading ── */
@keyframes shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}

.skeleton {
  background: linear-gradient(
    90deg,
    var(--bg-card2) 25%,
    var(--bg-card3) 50%,
    var(--bg-card2) 75%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s ease-in-out infinite;
  border-radius: var(--radius-sm);
}

.skeleton-line {
  height: 0.9em;
  border-radius: var(--radius-sm);
  margin-bottom: var(--sp-2);
}

.skeleton-line:last-child { width: 60%; }

.skeleton-card {
  padding: var(--sp-4);
  background: var(--bg-card2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.skeleton-tag {
  height: 1.2em;
  width: 60px;
  border-radius: var(--radius-pill);
}

/* ── Error State ── */
.error-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-3);
  padding: var(--sp-8) var(--sp-4);
  color: var(--text-secondary);
}

.error-state svg {
  color: var(--red);
  opacity: 0.7;
}

.error-state p {
  font-size: var(--text-sm);
  max-width: 32ch;
}

/* ── Empty State ── */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-2);
  padding: var(--sp-8) var(--sp-4);
  color: var(--text-secondary);
}

.empty-state svg { opacity: 0.4; }

.empty-state p {
  font-size: var(--text-sm);
  max-width: 30ch;
}

/* ── Scrollable section bodies (limbo) ── */
.section-body--scroll {
  max-height: 480px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}

.section-body--scroll::-webkit-scrollbar { width: 4px; }
.section-body--scroll::-webkit-scrollbar-track { background: transparent; }
.section-body--scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

/* ── Responsive tweaks ── */
@media (max-width: 500px) {
  .header {
    flex-direction: column;
    align-items: flex-start;
  }

  .limbo-item {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
  }

  .limbo-actions {
    grid-column: 1;
    grid-row: 3;
  }

  .limbo-tag-row {
    grid-row: 2;
  }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ── Divider ── */
.section-divider {
  height: 1px;
  background: var(--border);
  margin: var(--sp-1) 0;
}
