/* ═══════════════════════════════════════════════════════════════
   UniProy — index.css
   Landing page, navigation, footer, hero, cards
   Mobile-first · Breakpoints: 480 · 640 · 768 · 992 · 1200
   ═══════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════
   HEADER & NAV
   ══════════════════════════════════════ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  padding: 12px 0 0;
}

.nav-pro {
  border-radius: 20px;
  padding: .78rem .9rem;
  background: var(--card);
  border: 1px solid var(--border);
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow-soft);
}

/* Brand */
.brand-wrap {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--text);
  flex-shrink: 0;
}

.brand-mark {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(0,89,78,0.14), rgba(181,161,96,0.18));
  border: 1px solid var(--border);
  color: var(--brand);
  font-size: 1.1rem;
  flex-shrink: 0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.22);
}
.brand-mark.brand-mark-image { padding: 6px; overflow: hidden; }
.brand-mark.brand-mark-image img { width: 100%; height: 100%; object-fit: contain; }

.brand-copy {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}
.brand-copy.has-logo { gap: 4px; }

.brand-logo-wordmark {
  height: 34px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
}

.brand-title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.02rem;
  color: var(--text);
}
.brand-sub {
  font-size: .74rem;
  color: var(--text-muted);
  font-weight: 700;
  letter-spacing: .02em;
}

/* Unitropico lockup */
.unitropico-lockup {
  min-height: 42px;
  padding: .45rem .82rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--card);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-soft);
}
.unitropico-logo { width: auto; height: 22px; object-fit: contain; }
.unitropico-logo-white { display: none; }

html[data-theme="dark"] .unitropico-logo-color { display: none; }
html[data-theme="dark"] .unitropico-logo-white { display: inline-block; }
html[data-theme="dark"] .brand-logo-wordmark,
html[data-theme="dark"] .footer-brand-logo { filter: brightness(0) invert(1); }

/* Nav links */
.nav-link {
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--text-muted);
  padding: .65rem .82rem !important;
  border-radius: 999px;
  transition: all var(--transition-fast);
  font-size: .88rem;
}
.nav-link:hover, .nav-link:focus { color: var(--brand); background: rgba(0,89,78,0.07); }
.nav-link.active { color: var(--brand) !important; background: rgba(0,89,78,0.07); }

/* Right actions */
.nav-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* Theme toggle */
.theme-toggle {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  flex-shrink: 0;
}
.theme-toggle:hover { color: var(--brand); border-color: var(--brand); background: rgba(0,89,78,0.06); }

/* Auth chip */
.auth-user-dropdown { position: relative; }

.auth-user-chip {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  min-height: 42px;
  padding: .5rem .9rem;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,0.08);
  background: linear-gradient(135deg, rgba(53,181,161,0.16), rgba(37,99,235,0.10));
  color: var(--text);
  box-shadow: var(--shadow-soft);
  font-weight: 700;
  font-size: .82rem;
  cursor: pointer;
  transition:
    border-color var(--transition-fast),
    transform    var(--transition-fast),
    box-shadow   var(--transition-fast),
    background   var(--transition-fast);
}
button.auth-user-chip { appearance: none; }
.auth-user-chip:hover, .auth-user-chip:focus-visible {
  border-color: rgba(0,89,78,0.18);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.auth-user-chip.dropdown-toggle::after { display: none; }
.auth-user-chip i { color: var(--brand); }
.auth-user-caret { color: var(--text-muted); font-size: .7rem; }

/* Auth dropdown menu */
.auth-user-menu {
  width: min(370px, calc(100vw - 24px));
  margin-top: 10px;
  padding: 14px;
  border-radius: 22px;
  border: 1px solid var(--border);
  background: var(--card);
  box-shadow: var(--shadow-lg);
}
.auth-user-menu-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.auth-user-menu-head strong {
  display: block;
  color: var(--text);
  font-family: var(--font-heading);
  font-size: .98rem;
  line-height: 1.3;
}
.auth-user-menu-copy {
  margin: 12px 0 0;
  color: var(--text-muted);
  font-size: .88rem;
  line-height: 1.7;
}
.auth-user-menu-list { display: grid; gap: 8px; margin-top: 14px; }
.auth-user-menu-item {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 10px;
  align-items: start;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--card-solid);
}
.auth-user-menu-item i {
  width: 40px; height: 40px;
  border-radius: 13px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,89,78,0.1);
  color: var(--brand);
}
.auth-user-menu-item strong { display: block; color: var(--text); font-size: .88rem; margin-bottom: 3px; }
.auth-user-menu-item small  { display: block; color: var(--text-muted); line-height: 1.55; font-size: .8rem; }

/* Auth modal */
.auth-modal {
  border: 1px solid var(--border);
  border-radius: 22px;
  background: var(--card-solid);
  color: var(--text);
  box-shadow: var(--shadow-lg);
}

/* Logout */
.btn-brand.btn-logout-pro {
  background: linear-gradient(135deg, #8f1d3f, #dc3545);
  box-shadow: 0 12px 30px rgba(143,29,63,0.22);
}
.btn-brand.btn-logout-pro:hover { box-shadow: 0 16px 38px rgba(143,29,63,0.30); }
.footer-link.footer-link-logout { color: #c62828; font-weight: 800; }
html[data-theme="dark"] .footer-link.footer-link-logout { color: #fda4af; }

/* ══════════════════════════════════════
   HERO
   ══════════════════════════════════════ */
.hero-section { padding: clamp(22px, 4vw, 34px) 0 clamp(52px, 8vw, 72px); }

.hero-panel {
  padding: clamp(20px, 4vw, 34px);
  border-radius: var(--radius-xl);
  background: var(--card);
  border: 1px solid var(--border);
  backdrop-filter: blur(18px);
  box-shadow: var(--shadow-lg);
  position: relative;
  overflow: hidden;
}
.hero-panel::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(800px 340px at 8% 0%,  var(--hero-grad-1), transparent 60%),
    radial-gradient(700px 320px at 98% 6%, var(--hero-grad-2), transparent 58%);
  pointer-events: none;
}
.hero-copy, .hero-side-card { position: relative; z-index: 1; }

/* Eyebrow */
.eyebrow {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: .5rem .86rem;
  border: 1px solid var(--border);
  background: var(--glass);
  color: var(--brand);
  font-weight: 800;
  font-size: .82rem;
  letter-spacing: .04em;
  margin-bottom: 16px;
}

/* Hero typography */
.hero-title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 5vw, 3.9rem);
  line-height: .98;
  letter-spacing: -0.05em;
  font-weight: 900;
  color: var(--text);
  margin: 0 0 16px;
  max-width: 860px;
}
.hero-title span { color: var(--brand); }

.hero-text {
  max-width: 680px;
  font-size: clamp(.94rem, 2vw, 1.05rem);
  line-height: 1.82;
  color: var(--text-muted);
  margin-bottom: 22px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 20px;
}

.hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

/* Hero side card */
.hero-side-card {
  border-radius: 22px;
  padding: 20px;
  background: rgba(255,255,255,0.36);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-md);
}
html[data-theme="dark"] .hero-side-card { background: rgba(10,20,33,0.52); }

.hero-side-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 16px;
}

.auth-session-meta {
  margin: 10px 0 0;
  color: var(--text-muted);
  font-size: .86rem;
  line-height: 1.55;
}

/* Status badge */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  border-radius: 999px;
  padding: .48rem .7rem;
  background: rgba(16,185,129,0.12);
  border: 1px solid rgba(16,185,129,0.22);
  color: #0f766e;
  font-size: .8rem;
  font-weight: 800;
}
html[data-theme="dark"] .status-badge { color: #86efac; }
.status-badge i { font-size: .54rem; }

/* Stats grid */
.stats-grid { display: grid; gap: 10px; margin-bottom: 16px; }

.mini-stat {
  display: grid;
  grid-template-columns: 50px 1fr;
  gap: 10px;
  align-items: center;
  padding: 13px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--card-solid);
}
.mini-stat strong { display: block; color: var(--text); font-family: var(--font-heading); font-size: .96rem; margin-bottom: 3px; }
.mini-stat small  { display: block; color: var(--text-muted); line-height: 1.45; font-size: .82rem; }

.mini-stat-icon {
  width: 50px; height: 50px;
  border-radius: 15px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,89,78,0.10);
  color: var(--brand);
  border: 1px solid rgba(0,89,78,0.14);
  font-size: 1.05rem;
}
.mini-stat-icon.gold   { background: rgba(181,161,96,0.14); color: #8a6b19; border-color: rgba(181,161,96,0.18); }
.mini-stat-icon.blue   { background: rgba(37,99,235,0.12);  color: var(--blue); border-color: rgba(37,99,235,0.16); }
.mini-stat-icon.dark   { background: rgba(15,23,42,0.08);   color: var(--dark-chip); border-color: rgba(15,23,42,0.12); }

.mini-stat-link {
  appearance: none;
  width: 100%;
  text-align: left;
  text-decoration: none;
  color: inherit;
  font: inherit;
  cursor: pointer;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
}
.mini-stat-link:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: rgba(0,89,78,0.22); }
.mini-stat-link:hover strong,
.mini-stat-link:hover .mini-stat-icon { color: var(--brand); }

/* Access box */
.access-box {
  padding: 14px;
  border-radius: 16px;
  border: 1px dashed var(--border-strong);
  background: rgba(127,127,127,0.04);
}
.access-text { color: var(--text-muted); line-height: 1.7; }

/* ══════════════════════════════════════
   WORKSPACE CARDS
   ══════════════════════════════════════ */
.workspace-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 22px;
}

/* 5 cards: top row = 3 equal, bottom row = 2 centered */
.workspace-card:nth-child(1) { grid-column: 1 / 3; }
.workspace-card:nth-child(2) { grid-column: 3 / 5; }
.workspace-card:nth-child(3) { grid-column: 5 / 7; }
.workspace-card:nth-child(4) { grid-column: 2 / 4; }
.workspace-card:nth-child(5) { grid-column: 4 / 6; }

.workspace-card,
.workspace-dock {
  border: 1px solid var(--border);
  background: var(--card);
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow-soft);
}

.workspace-card {
  position: relative;
  overflow: hidden;
  border-radius: 26px;
  padding: clamp(18px, 3vw, 26px);
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.workspace-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 24px 56px rgba(0,89,78,0.13);
  border-color: rgba(0,89,78,0.22);
}
.workspace-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(420px 220px at 0% 0%,   rgba(0,89,78,0.10),  transparent 62%),
    radial-gradient(360px 180px at 100% 0%, rgba(181,161,96,0.12), transparent 58%);
  pointer-events: none;
}
.workspace-card > *, .workspace-dock > * { position: relative; z-index: 1; }

.workspace-card.f3::after {
  background:
    radial-gradient(420px 220px at 0% 0%,   rgba(0,89,78,0.14),   transparent 62%),
    radial-gradient(360px 180px at 100% 0%, rgba(124,58,237,0.12), transparent 58%);
}
.workspace-card.f3 .workspace-icon {
  color: var(--brand);
  background: rgba(0,89,78,0.14);
  border-color: rgba(0,89,78,0.18);
}

.workspace-card.review::after {
  background:
    radial-gradient(420px 220px at 0% 0%,   rgba(181,161,96,0.14), transparent 60%),
    radial-gradient(360px 180px at 100% 0%, rgba(0,89,78,0.08),   transparent 56%);
}
.workspace-card.approval::after {
  background:
    radial-gradient(420px 220px at 0% 0%,   rgba(37,99,235,0.12), transparent 60%),
    radial-gradient(360px 180px at 100% 0%, rgba(0,89,78,0.10),   transparent 58%);
}

.workspace-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.workspace-eyebrow {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: .5rem .84rem;
  border: 1px solid var(--border);
  background: var(--glass);
  color: var(--text-muted);
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.workspace-icon {
  width: 54px; height: 54px;
  border-radius: 17px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  color: var(--brand);
  background: rgba(0,89,78,0.12);
  border: 1px solid rgba(0,89,78,0.14);
  flex-shrink: 0;
}
.workspace-card.review .workspace-icon   { color: #8a6b19; background: rgba(181,161,96,0.16); border-color: rgba(181,161,96,0.20); }
.workspace-card.approval .workspace-icon { color: var(--blue); background: rgba(37,99,235,0.14); border-color: rgba(37,99,235,0.18); }

/* Eyebrow pill — accent tints per phase */
.workspace-card.f1 .workspace-eyebrow,
.workspace-card.f2 .workspace-eyebrow {
  color: var(--brand);
  background: rgba(0,89,78,0.08);
  border-color: rgba(0,89,78,0.18);
}
.workspace-card.f3 .workspace-eyebrow {
  color: #7c3aed;
  background: rgba(124,58,237,0.08);
  border-color: rgba(124,58,237,0.18);
}
.workspace-card.review .workspace-eyebrow {
  color: #8a6b19;
  background: rgba(181,161,96,0.12);
  border-color: rgba(181,161,96,0.22);
}
.workspace-card.approval .workspace-eyebrow {
  color: var(--blue);
  background: rgba(37,99,235,0.10);
  border-color: rgba(37,99,235,0.18);
}

/* Card hover — accent border per type */
.workspace-card.review:hover   { box-shadow: 0 24px 56px rgba(181,161,96,0.16); border-color: rgba(181,161,96,0.32); }
.workspace-card.approval:hover { box-shadow: 0 24px 56px rgba(37,99,235,0.14); border-color: rgba(37,99,235,0.28); }

/* Card-accent buttons — same shape as btn-brand, color-matched per card */
.workspace-card.review .workspace-actions .btn-brand {
  background: linear-gradient(135deg, #7a5c12, #b5a160);
  box-shadow: 0 10px 26px rgba(181,161,96,0.28);
}
.workspace-card.review .workspace-actions .btn-brand:hover {
  box-shadow: 0 16px 36px rgba(181,161,96,0.38);
}
.workspace-card.approval .workspace-actions .btn-brand {
  background: linear-gradient(135deg, #1d4ed8, #3b82f6);
  box-shadow: 0 10px 26px rgba(37,99,235,0.26);
}
.workspace-card.approval .workspace-actions .btn-brand:hover {
  box-shadow: 0 16px 36px rgba(37,99,235,0.36);
}

.workspace-card h3, .workspace-dock h3 {
  font-family: var(--font-heading);
  font-weight: 800;
  color: var(--text);
  margin: 0 0 8px;
  font-size: clamp(.98rem, 2vw, 1.15rem);
}
.workspace-card p, .workspace-dock p { color: var(--text-muted); line-height: 1.75; margin: 0; }

.workspace-meta,
.workspace-actions,
.workspace-dock-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.workspace-actions { margin-top: auto; }

/* Workspace dock */
.workspace-dock {
  margin-top: 20px;
  border-radius: 26px;
  padding: clamp(18px, 3vw, 24px) clamp(18px, 3vw, 26px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px 20px;
  flex-wrap: wrap;
  background:
    radial-gradient(900px 260px at 12% 0%,  var(--hero-grad-1), transparent 62%),
    radial-gradient(900px 260px at 100% 0%, var(--hero-grad-2), transparent 58%),
    var(--card);
}

/* ══════════════════════════════════════
   MODULE / BENEFIT / TIMELINE CARDS
   ══════════════════════════════════════ */
.module-card, .benefit-card, .timeline-step,
.governance-card, .callout-panel, .final-cta {
  border: 1px solid var(--border);
  background: var(--card);
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow-soft);
}

.module-card {
  height: 100%;
  border-radius: 22px;
  padding: clamp(18px, 3vw, 24px);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
}
.module-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: rgba(0,89,78,0.22); }

.module-icon, .benefit-icon {
  width: 54px; height: 54px;
  border-radius: 17px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
  font-size: 1.15rem;
}
.module-icon  { background: rgba(0,89,78,0.10);  color: var(--brand);   border: 1px solid rgba(0,89,78,0.12); }

.module-icon.gold,  .benefit-icon.gold   { background: rgba(181,161,96,0.14); color: #8a6b19;    border: 1px solid rgba(181,161,96,0.18); }
.module-icon.blue,  .benefit-icon.blue   { background: rgba(37,99,235,0.12);  color: var(--blue); border: 1px solid rgba(37,99,235,0.16); }
.module-icon.green, .benefit-icon.green  { background: rgba(15,118,110,0.12); color: var(--green); border: 1px solid rgba(15,118,110,0.16); }
.module-icon.dark                        { background: rgba(15,23,42,0.08);   color: var(--dark-chip); border: 1px solid rgba(15,23,42,0.12); }
.module-icon.violet                      { background: rgba(124,58,237,0.12); color: var(--violet); border: 1px solid rgba(124,58,237,0.16); }

.module-card h4, .benefit-card h5,
.timeline-step h5, .callout-panel h5, .footer-brand h4 {
  font-family: var(--font-heading);
  font-weight: 800;
  color: var(--text);
}
.module-card p, .benefit-card p { color: var(--text-muted); line-height: 1.75; margin-bottom: 0; }

.chip-wrap { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 16px; }

/* Timeline */
.timeline-wrap { display: grid; gap: 12px; }

.timeline-step {
  border-radius: 18px;
  padding: 14px 16px;
  display: grid;
  grid-template-columns: 50px 1fr;
  gap: 14px;
  align-items: start;
}

.timeline-num {
  width: 50px; height: 50px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: .96rem;
  background: linear-gradient(135deg, rgba(181,161,96,0.22), rgba(0,89,78,0.18));
  border: 1px solid var(--border);
  color: var(--text);
  flex-shrink: 0;
}
.timeline-step p { margin: 0; color: var(--text-muted); line-height: 1.7; }

.timeline-step-f3 .timeline-num {
  background: linear-gradient(135deg, rgba(0,89,78,0.22), rgba(124,58,237,0.16));
  color: var(--brand);
  border-color: rgba(0,89,78,0.20);
}

/* Benefit */
.benefit-card { height: 100%; border-radius: 20px; padding: clamp(16px, 2.5vw, 22px); }

/* Governance */
.governance-card {
  border-radius: 26px;
  padding: clamp(20px, 3.5vw, 28px);
  overflow: hidden;
  position: relative;
}
.governance-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(700px 300px at 15% 0%,  var(--hero-grad-1), transparent 60%),
    radial-gradient(700px 300px at 100% 0%, var(--hero-grad-2), transparent 58%);
  pointer-events: none;
}
.governance-card > * { position: relative; z-index: 1; }

.governance-list { display: grid; gap: 10px; }
.gov-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 13px 15px;
  border-radius: 16px;
  background: var(--card-solid);
  border: 1px solid var(--border);
  color: var(--text-soft);
  font-weight: 700;
  font-size: clamp(.84rem, 2vw, .94rem);
}
.gov-item i { color: var(--brand); flex-shrink: 0; }

/* Callout */
.callout-panel {
  border-radius: 22px;
  padding: clamp(16px, 3vw, 22px);
  background: linear-gradient(180deg, rgba(0,89,78,0.08), rgba(181,161,96,0.08));
}
.callout-panel p { color: var(--text-muted); line-height: 1.75; }

/* ══════════════════════════════════════
   FINAL CTA
   ══════════════════════════════════════ */
.final-cta {
  border-radius: 26px;
  padding: clamp(22px, 4vw, 32px);
  background:
    radial-gradient(900px 400px at 12% 0%,  var(--hero-grad-1), transparent 60%),
    radial-gradient(900px 400px at 100% 0%, var(--hero-grad-2), transparent 58%),
    var(--card);
}

.final-cta-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(240px, .9fr);
  gap: 24px 32px;
  align-items: end;
}

.final-cta-copy   { max-width: 56ch; }
.final-cta-title  { margin-bottom: 10px; max-width: 14ch; }
.final-cta-text   { margin-bottom: 0; max-width: 52ch; }

.final-cta-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
}
.final-cta-primary  { min-width: 210px; }
.final-cta-secondary { display: flex; flex-wrap: wrap; gap: 8px; }

.final-cta-login {
  display: inline-flex;
  align-items: center;
  color: var(--text);
  font-weight: 600;
  transition: color var(--transition-fast), transform var(--transition-fast);
}
.final-cta-login:hover { color: var(--brand); transform: translateX(2px); }

/* ══════════════════════════════════════
   FOOTER
   ══════════════════════════════════════ */
.site-footer {
  padding: clamp(28px, 5vw, 40px) 0 clamp(16px, 3vw, 22px);
  border-top: 1px solid var(--border);
  background: rgba(127,127,127,0.04);
}

.footer-brand { display: flex; align-items: flex-start; gap: 12px; }
.footer-mark  { flex: 0 0 auto; }

.footer-brand p,
.footer-contact,
.footer-link,
.footer-bottom { color: var(--text-muted); }

.footer-brand-logo { height: 46px; width: auto; object-fit: contain; margin-bottom: 8px; }

.footer-title {
  font-family: var(--font-heading);
  font-weight: 800;
  color: var(--text);
  margin-bottom: 12px;
  font-size: clamp(.9rem, 2vw, 1rem);
}

.footer-link {
  display: block;
  margin-bottom: 8px;
  font-size: .9rem;
  transition: color var(--transition-fast), transform var(--transition-fast);
}
.footer-link:hover { color: var(--brand); transform: translateX(2px); }

.footer-bottom {
  border-top: 1px solid var(--border);
  margin-top: 22px;
  padding-top: 16px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  font-size: .9rem;
}

.footer-brand-block { display: flex; flex-direction: column; gap: 16px; }
.footer-unitropico-logo-wrap { display: flex; align-items: center; }
.footer-unitropico-logo {
  width: 190px; max-width: 80%; height: auto;
  object-fit: contain;
  filter: drop-shadow(0 6px 20px rgba(15,23,42,0.10));
}
html[data-theme="dark"] .footer-unitropico-logo {
  filter: brightness(1.05) drop-shadow(0 6px 20px rgba(0,0,0,0.26));
}

/* ══════════════════════════════════════
   RESPONSIVE — Tablet 992px
   ══════════════════════════════════════ */
@media (max-width: 991.98px) {
  .hero-section { padding: 18px 0 48px; }

  .workspace-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .workspace-card:nth-child(n) { grid-column: auto; }

  .workspace-dock {
    flex-direction: column;
    align-items: flex-start;
  }

  .final-cta-grid { grid-template-columns: 1fr; }

  .nav-actions { display: none; }

  .auth-user-menu { right: 0; left: auto; }
}

/* ══════════════════════════════════════
   RESPONSIVE — Mobile 768px
   ══════════════════════════════════════ */
@media (max-width: 767.98px) {
  .site-header { padding-top: 10px; }

  .nav-pro { border-radius: 16px; padding: .72rem .85rem; }

  .brand-mark { width: 40px; height: 40px; border-radius: 13px; }

  .hero-panel { padding: 16px; border-radius: 22px; }

  .hero-title {
    font-size: clamp(1.9rem, 9vw, 2.8rem);
    line-height: 1.02;
  }
  .hero-text { font-size: .96rem; }

  .hero-actions,
  .workspace-actions,
  .workspace-dock-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .hero-actions .btn,
  .workspace-actions .btn,
  .workspace-dock-actions .btn {
    width: 100%;
    justify-content: center;
  }

  .final-cta-actions,
  .final-cta-secondary { align-items: stretch; }
  .final-cta-primary,
  .final-cta-secondary .btn,
  .final-cta-login { width: 100%; justify-content: center; }

  .timeline-step { grid-template-columns: 44px 1fr; gap: 10px; }
  .timeline-num  { width: 44px; height: 44px; border-radius: 13px; }

  .footer-bottom { flex-direction: column; }
}

/* ══════════════════════════════════════
   RESPONSIVE — Small phone 480px
   ══════════════════════════════════════ */
@media (max-width: 479.98px) {
  .hero-panel { padding: 14px; border-radius: 18px; }

  .workspace-grid { grid-template-columns: 1fr; }
  .workspace-card { padding: 16px; border-radius: 20px; }

  .final-cta { padding: 18px; border-radius: 20px; }

  .governance-card { padding: 16px; border-radius: 20px; }

  .hero-pills { gap: 6px; }
  .hero-pills .pill { font-size: .78rem; padding: .56rem .78rem; }

  .module-icon, .benefit-icon { width: 48px; height: 48px; font-size: 1rem; margin-bottom: 12px; }

  .nav-pro { border-radius: 14px; }
}

/* ══════════════════════════════════════════════════════════════
   ROLE DASHBOARD
   ══════════════════════════════════════════════════════════════ */
[data-dashboard-shell] {
  padding: 0 0 clamp(36px, 6vw, 60px);
}

.dash-shell { animation: dashFadeIn .32s ease both; }

@keyframes dashFadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Wrap card */
.dash-card-wrap {
  border: 1px solid var(--border);
  background: var(--card);
  backdrop-filter: blur(18px);
  border-radius: 28px;
  padding: clamp(20px, 3.5vw, 32px);
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
}
.dash-card-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(700px 320px at 6%   0%, var(--hero-grad-1), transparent 60%),
    radial-gradient(700px 320px at 96%  0%, var(--hero-grad-2), transparent 58%);
  pointer-events: none;
}
.dash-card-wrap > * { position: relative; z-index: 1; }

.dash-card-admin::after {
  background:
    radial-gradient(700px 320px at 6%   0%, var(--hero-grad-2), transparent 58%),
    radial-gradient(700px 320px at 96%  0%, var(--hero-grad-3), transparent 60%);
}

/* Header */
.dash-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px 20px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}
.dash-welcome { flex: 1 1 240px; }
.dash-title {
  font-family: var(--font-heading);
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--text);
  margin: 8px 0 4px;
}
.dash-header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  flex-shrink: 0;
}

/* Inner grid (2-col for formulador) */
.dash-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.dash-inner-panel {
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 20px;
  background: var(--card-solid);
}

/* Active project */
.dash-project-name {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(.95rem, 2vw, 1.06rem);
  color: var(--text);
  margin: 0 0 8px;
  line-height: 1.3;
}
.dash-project-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: .32rem .7rem;
  background: rgba(0,89,78,0.10);
  border: 1px solid rgba(0,89,78,0.16);
  color: var(--brand);
  font-size: .76rem;
  font-weight: 800;
  text-transform: capitalize;
  margin-bottom: 16px;
}

/* Phase pills */
.dash-phase-row {
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.dash-phase-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: .48rem .8rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--glass);
  color: var(--text-soft);
  font-size: .80rem;
  font-weight: 700;
  transition: all var(--transition-fast);
  backdrop-filter: blur(10px);
}
.dash-phase-pill:hover { border-color: var(--brand); color: var(--brand); background: rgba(0,89,78,0.07); }
.dash-phase-f3:hover   { border-color: var(--violet); color: var(--violet); background: rgba(124,58,237,0.07); }

/* Action list (shared between formulador & admin) */
.dash-action-list { display: grid; gap: 8px; }
.dash-action-row {
  display: grid;
  grid-template-columns: 42px 1fr 18px;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--bg-soft);
  text-decoration: none;
  color: var(--text);
  transition: all var(--transition-fast);
}
.dash-action-row:hover {
  border-color: var(--brand);
  background: rgba(0,89,78,0.04);
  transform: translateX(3px);
  color: var(--text);
}
.dash-action-row > .fa-chevron-right { color: var(--text-muted); font-size: .78rem; }
.dash-action-row:hover > .fa-chevron-right { color: var(--brand); }

.dash-action-icon {
  width: 42px; height: 42px;
  border-radius: 13px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,89,78,0.10);
  color: var(--brand);
  border: 1px solid rgba(0,89,78,0.14);
  font-size: .94rem;
  flex-shrink: 0;
}
.dash-action-icon.green  { background: rgba(15,118,110,0.12); color: var(--green);  border-color: rgba(15,118,110,0.18); }
.dash-action-icon.gold   { background: rgba(181,161,96,0.14); color: #8a6b19;       border-color: rgba(181,161,96,0.20); }
.dash-action-icon.blue   { background: rgba(37,99,235,0.12);  color: var(--blue);   border-color: rgba(37,99,235,0.18); }
.dash-action-icon.violet { background: rgba(124,58,237,0.12); color: var(--violet); border-color: rgba(124,58,237,0.18); }

.dash-action-copy strong { display: block; font-size: .87rem; color: var(--text); margin-bottom: 2px; font-weight: 700; }
.dash-action-copy small  { display: block; font-size: .77rem; color: var(--text-muted); line-height: 1.4; }

/* Stats row (admin) */
.dash-stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 18px;
}
.dash-stat-item {
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 16px 20px;
  background: var(--card-solid);
  text-align: center;
  transition: border-color var(--transition-fast), transform var(--transition-fast);
}
.dash-stat-item:hover { border-color: rgba(0,89,78,0.20); transform: translateY(-2px); }
.dash-stat-num {
  display: block;
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  color: var(--text);
  line-height: 1;
  margin-bottom: 6px;
}
.dash-stat-label { font-size: .80rem; color: var(--text-muted); font-weight: 600; }
.dash-stat-green .dash-stat-num { color: var(--brand); }

/* ── Avatar (nav chip + dashboard) ──────────────────────────── */
.chip-avatar {
  width: 26px; height: 26px;
  border-radius: 999px;
  object-fit: cover;
  border: 1px solid rgba(0,89,78,0.18);
  flex-shrink: 0;
}

.dash-welcome-top {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 6px;
}
.dash-welcome-top > div:last-child { display: flex; flex-direction: column; gap: 2px; }

.dash-avatar {
  width: 52px; height: 52px;
  border-radius: 999px;
  border: 2px solid var(--border);
  background: rgba(0,89,78,0.10);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
  position: relative;
}
.dash-avatar-lg { width: 64px; height: 64px; border-width: 2px; margin-top: 2px; }

.dash-avatar-img {
  width: 100%; height: 100%;
  object-fit: cover;
  border-radius: 999px;
  display: block;
}
.dash-avatar-initials {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.1rem;
  color: var(--brand);
  line-height: 1;
  text-transform: uppercase;
}
.dash-avatar-lg .dash-avatar-initials { font-size: 1.4rem; }

/* Guest panel */
.dash-guest-wrap {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: clamp(18px, 3vw, 26px);
  border: 1px solid var(--border);
  border-radius: 24px;
  background: var(--card);
  backdrop-filter: blur(16px);
}
.dash-guest-icon {
  width: 56px; height: 56px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(181,161,96,0.14);
  color: #8a6b19;
  border: 1px solid rgba(181,161,96,0.18);
  font-size: 1.2rem;
  flex-shrink: 0;
  margin-top: 4px;
}
.dash-guest-copy h3 {
  font-family: var(--font-heading);
  font-weight: 800;
  color: var(--text);
  margin: 8px 0 10px;
}

/* ══════════════════════════════════════════════════════════════
   NOTIFICATIONS
   ══════════════════════════════════════════════════════════════ */
.notif-wrap { position: relative; }

.notif-btn {
  width: 42px; height: 42px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  flex-shrink: 0;
  position: relative;
}
.notif-btn:hover { color: var(--brand); border-color: var(--brand); background: rgba(0,89,78,0.06); }

.notif-badge {
  position: absolute;
  top: -4px; right: -4px;
  min-width: 18px; height: 18px;
  border-radius: 999px;
  background: #dc3545;
  color: #fff;
  font-size: .62rem;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  border: 2px solid var(--bg);
  line-height: 1;
}

.notif-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: min(360px, calc(100vw - 24px));
  border-radius: 22px;
  border: 1px solid var(--border);
  background: var(--card-solid);
  box-shadow: var(--shadow-lg);
  z-index: 200;
  overflow: hidden;
  animation: notifSlideIn .18s ease both;
}
@keyframes notifSlideIn {
  from { opacity: 0; transform: translateY(-8px) scale(.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.notif-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--border);
  gap: 10px;
}
.notif-panel-title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: .92rem;
  color: var(--text);
}
.notif-mark-all {
  font-size: .76rem !important;
  padding: .3rem .66rem !important;
  min-height: unset !important;
}

.notif-list {
  max-height: 330px;
  overflow-y: auto;
  padding: 8px;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}

.notif-item {
  display: grid;
  grid-template-columns: 10px 1fr;
  gap: 10px;
  align-items: start;
  padding: 11px;
  border-radius: 14px;
  transition: background var(--transition-fast);
  cursor: default;
}
.notif-item:hover { background: var(--bg-soft); }

.notif-dot {
  width: 8px; height: 8px;
  border-radius: 999px;
  background: transparent;
  margin-top: 5px;
  flex-shrink: 0;
}
.notif-item.is-unread .notif-dot { background: var(--brand); }

.notif-body strong { display: block; font-size: .85rem; color: var(--text); margin-bottom: 3px; }
.notif-body p      { font-size: .81rem; color: var(--text-muted); margin: 0 0 5px; line-height: 1.55; }
.notif-time        { font-size: .73rem; color: var(--text-muted); }

.notif-empty {
  text-align: center;
  padding: 28px 16px;
  color: var(--text-muted);
}
.notif-empty i { font-size: 1.6rem; margin-bottom: 8px; display: block; opacity: .5; }
.notif-empty p { margin: 0; font-size: .86rem; }

/* ══════════════════════════════════════════════════════════════
   HELP FAB & MODAL
   ══════════════════════════════════════════════════════════════ */
.help-fab {
  position: fixed;
  right: clamp(12px, 3vw, 18px);
  bottom: calc(clamp(12px, 3vw, 18px) + 46px + 10px);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: .62rem 1.1rem;
  border-radius: 999px;
  border: 1px solid rgba(0,89,78,0.26);
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: #fff;
  font-weight: 700;
  font-size: .86rem;
  box-shadow: 0 10px 28px rgba(0,89,78,0.26);
  z-index: 29;
  transition: all var(--transition-fast);
}
.help-fab:hover { transform: translateY(-2px); box-shadow: 0 16px 36px rgba(0,89,78,0.34); color: #fff; }

/* Help modal */
.help-modal-icon {
  width: 38px; height: 38px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,89,78,0.12);
  color: var(--brand);
  border: 1px solid rgba(0,89,78,0.16);
  font-size: .96rem;
  flex-shrink: 0;
}
.text-brand { color: var(--brand) !important; }

.help-user-info {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 14px;
  background: rgba(0,89,78,0.07);
  border: 1px solid rgba(0,89,78,0.12);
  margin-bottom: 18px;
  color: var(--brand);
  font-size: .84rem;
  font-weight: 700;
  flex-wrap: wrap;
}
.help-user-email {
  flex: 1;
  color: var(--text-soft);
  font-weight: 600;
  font-size: .82rem;
  word-break: break-all;
}
.help-role-chip {
  padding: .24rem .6rem;
  border-radius: 999px;
  background: var(--brand);
  color: #fff;
  font-size: .70rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  white-space: nowrap;
}
.letter-spacing-1 { letter-spacing: .06em; }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — dashboard / notif / help
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 767.98px) {
  .dash-grid { grid-template-columns: 1fr; }
  .dash-stats-row { grid-template-columns: repeat(3, 1fr); }
  .dash-header { flex-direction: column; align-items: flex-start; }
  .dash-guest-wrap { flex-direction: column; align-items: flex-start; }
  .dash-guest-icon { width: 48px; height: 48px; font-size: 1rem; }
  .help-fab-label { display: none; }
  .help-fab { padding: .68rem; }
  .notif-panel { right: -10px; }
}

@media (max-width: 479.98px) {
  .dash-card-wrap { border-radius: 22px; padding: 16px; }
  .dash-stats-row { gap: 8px; }
  .dash-stat-item { padding: 12px; border-radius: 16px; }
  .dash-stat-num  { font-size: 1.5rem; }
}
