@import url('../assets/UpSlide Fonts/Inter (Web)/inter.css');

:root {
  /* Existing spacing tokens */
  --general-padding: 20px;
  --general-side-padding: calc(24px * 3);

  /* ========================================== */
  /* DESIGN TOKENS                              */
  /* ========================================== */

  /* Colors - Primary Brand (Red) */
  --color-primary: rgb(250, 71, 74);
  --color-primary-10: rgba(250, 71, 74, 0.1);
  --color-primary-20: rgba(250, 71, 74, 0.2);
  --color-primary-30: rgba(250, 71, 74, 0.3);
  --color-primary-40: rgba(250, 71, 74, 0.4);
  --color-primary-80: rgba(250, 71, 74, 0.8);

  /* Colors - Neutral */
  --color-dark: rgb(5, 11, 36);
  --color-text-secondary: rgb(62, 72, 116);
  --color-border: rgb(229, 231, 235);
  --color-bg-light: rgb(250, 250, 250);
  --color-bg-pink: rgb(250, 240, 240);
  --color-white: rgb(255, 255, 255);
  --color-white-70: rgba(255, 255, 255, 0.7);
  --color-white-50: rgba(255, 255, 255, 0.5);

  /* Colors - Success (Green) */
  --color-success: rgb(22, 162, 73);
  --color-success-10: rgba(22, 162, 73, 0.1);
  --color-success-30: rgba(22, 162, 73, 0.3);
  --color-success-80: rgba(22, 162, 73, 0.8);

  /* Colors - Accent (PowerPoint Orange) */
  --color-accent-orange: rgb(249, 115, 31);
  --color-accent-orange-dark: rgb(224, 89, 6);
  --color-accent-orange-50: rgba(249, 115, 31, 0.5);

  /* Colors - Game Elements */
  --color-marker-red: #ef4444;
  --color-marker-red-30: rgba(239, 68, 68, 0.3);
  --color-error-zone-green: #22c55e;
  --color-error-zone-green-30: rgba(34, 197, 94, 0.3);

  /* Colors - External Brands */
  --color-linkedin: rgb(10, 102, 194);

  /* Colors - Gray Scale */
  --color-gray-light: rgb(243, 244, 246);
  --color-gray-medium: rgb(209, 213, 219);
  --color-backdrop: rgba(0, 0, 0, 0.7);

  /* Shadows */
  --shadow-sm: 0 0 6px rgba(0, 0, 0, 0.1);
  --shadow-md: 0 2px 12px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 2px 12px rgba(0, 0, 0, 0.2);

  /* Transitions */
  --transition-default: 0.18s cubic-bezier(0.4, 0.14, 0.43, 1);
  --transition-border: border-color 0.2s;

  /* Border Radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 24px;
  --radius-full: 48px;
  --radius-circle: 50%;
}

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

a {
  color: inherit;
  text-decoration: none;
}

/* View switching (required by app.js) */
.view {
  display: none;
}

.view.active {
  display: block;
}

/* Hidden attribute */
[hidden] {
  display: none !important;
}

/* Modal positioning (required for modal__backdrop click) */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1000;
}

.modal[hidden] {
  display: none;
}

.modal__backdrop {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

/* Button disabled state */
button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Slide container needs relative positioning for markers */
#game-slide-container,
#practice-slide-container {
  position: relative;
  display: inline-block;
}

/* Wrapper for image + marker/error-zone - positioning context */
.slide-image-wrapper {
  position: relative;
  display: inline-block;
  line-height: 0; /* Remove gap below image */
}

.slide-image-wrapper img {
  display: block;
  width: 100%;
  max-width: 720px;
  height: auto;
}

/* Markers need absolute positioning */
#game-marker,
#practice-marker {
  position: absolute;
  transform: translate(-50%, -50%);
  pointer-events: none;
  width: 16px;
  height: 16px;
  background-color: var(--color-marker-red);
  border-radius: var(--radius-circle);
  z-index: 10;
}

/* Marker pop-in animation (Story 3.3) */
#game-marker.pop-in,
#practice-marker.pop-in {
  animation: popIn 0.2s ease-out forwards;
}

@keyframes popIn {
  0% {
    transform: translate(-50%, -50%) scale(0);
    opacity: 0;
  }
  70% {
    transform: translate(-50%, -50%) scale(1.2);
  }
  100% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
  }
}

/* Error zones need absolute positioning */
.game-error-zone {
  position: absolute;
  pointer-events: none;
  z-index: 5;
}

/* Tutorial error zone highlight - green */
.game-error-zone.practice-zone {
  background-color: var(--color-error-zone-green-30);
  border: 2px solid var(--color-error-zone-green);
  border-radius: var(--radius-sm);
}

/* Debug: Game error zone highlight - red */
.game-error-zone.debug-zone {
  background-color: var(--color-marker-red-30);
  border: 2px solid var(--color-marker-red);
  border-radius: var(--radius-sm);
}

/* Images should not exceed container */
img {
  max-width: 100%;
  height: auto;
}

/* Modal content centering */
.modal__content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1001;
}

/* Nickname modal form */
.nickname-modal__form {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.nickname-modal__form input {
  padding: 0.5rem;
}

.error-message {
  color: var(--color-primary);
  font-size: 0.875rem;
}

/* Button loading state */
.btn--loading {
  opacity: 0.7;
  cursor: wait;
}

/* Tutorial instructions layout */
.tutorial-instructions {
  margin-bottom: 2rem;
}

.instruction-step {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 0.75rem;
}

.instruction-step span {
  flex-shrink: 0;
}

/* Practice section */
.practice-section {
  margin-top: 2rem;
}

.practice-buttons {
  display: flex;
  gap: 1rem;
  margin-top: 1rem;
}

body, button, input, textarea, select, option, optgroup, h1, h2, h3, h4, h5, h6 {
  font-family: 'Inter', ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}

header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--general-padding) 0px var(--general-padding) var(--general-side-padding);
}

header img {
  width: 100px;
  height: auto;
}

.red-bg-container {
  background-color: var(--color-bg-pink);
  color: rgb(5, 9, 31);
  border-bottom: 1px solid var(--color-border);
  border-top: 1px solid var(--color-border);
}

.blue-bg-container {
  background-color: var(--color-dark);
  color: var(--color-white);
}

.white-bg-container {
  background-color: var(--color-white);
  color: var(--color-dark);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.redplus-bg-container {
  background-color: var(--color-primary-10);
  color: var(--color-primary);
}

.cta-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background-color: var(--color-primary);
  color: white;
  border: none;
  border-radius: var(--radius-lg);
  padding: 16px 48px;
  cursor: pointer;
  font-size: 18px;
  font-weight: 500;
  box-shadow: var(--shadow-md);
}

.cta-button disabled {
  opacity: 0.5;
}

.allcenter-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--general-padding);
  text-align: center;
}

.container-padding {
  padding: calc(var(--general-padding) * 4) var(--general-side-padding) calc(var(--general-padding) * 4) var(--general-side-padding);
}

h1 {
  font-size: 90px;
  font-weight: 800;
}

h2 {
  font-size: 36px;
  font-weight: 700;
}

.announcement-text-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 8px 16px;
  border-radius: var(--radius-2xl);
}

.lucide-icon {
  width: 16px;
  margin-right: 8px;
}

.description-text {
  font-size: 22px;
  font-weight: 300;
  line-height: 1.5;
  text-align: center;
}

.bold-text {
  font-weight: 600;
}

.feature-cards-section {
  gap: calc(var(--general-padding) * 2);
}

.feature-cards-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--general-padding);
}

.feature-card {
  display: grid;
  grid-template-rows: 48px 48px 56px;
  place-items: center;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  width: 320px;
  height: 200px;
  padding: 16px;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  transition: transform var(--transition-default), box-shadow var(--transition-default);
}

.feature-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-8px);
  border: 1px solid var(--color-primary-20);
}

.feature-card .lucide-icon {
  width: 48px;
  height: 48px;
  color: var(--color-primary);
  background-color: var(--color-bg-pink);
  padding: 12px;
  border-radius: var(--radius-full);
}

.feature-card-title {
  font-size: 18px;
  font-weight: 600;
}

.feature-card-description {
  font-size: 16px;
  font-weight: 300;
  color: var(--color-text-secondary);
}

footer {
  background-color: var(--color-dark);
  color: var(--color-white-70);
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  padding: var(--general-padding) var(--general-side-padding);
  font-size: 14px;
}

footer nav {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: var(--general-padding);
}

footer a:hover {
  color: rgba(255, 255, 255, 1);
}

/* nickname modal */
.modal__backdrop {
  background-color: var(--color-backdrop);
}

#nickname-modal .modal__content {
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--general-padding);
  width: 420px;
  height: 240px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

#nickname-modal .modal__content div {
  display: flex;
  gap: 8px;
  flex-direction: column;
}

#nickname-modal .cta-button {
  width: 100%;
  padding-bottom: 10px;
  padding-top: 10px;
  margin-top: 12px;
}

h4 {
  font-size: 18px;
  font-weight: 600;
}

.modal__content p {
  font-size: 14px;
  font-weight: 400;
  color: var(--color-text-secondary);
}

#nickname-modal input {
  padding: 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: 16px;
  font-weight: 400;
  color: var(--color-text-secondary);
}

#nickname-modal input:focus {
  outline: none;
  border: 1px solid var(--color-primary);
}

/* tutorial practice view */
#tutorial-practice-view h2, #results-view h2, #thankyou-view h2 {
  font-size: 48px;
  font-weight: 700;
}
#tutorial-practice-view h3 {
  font-size: 36px;
  font-weight: 700;
}

#tutorial-practice-view .description-text {
  font-size: 18px;
}

#tutorial-practice-view .feature-card, #home-view .feature-card  {
  place-items: start;
  text-align: left;
  align-items: start;
  grid-template-rows: 48px 22px 56px;
  box-shadow: var(--shadow-sm);
  gap: 12px;
  padding-top: 16px;
  padding-bottom: 16px;
}

#tutorial-practice-view .feature-card {
  grid-template-rows: 48px 22px 1fr;
  background-color: var(--color-bg-light);
  min-height: 220px;
}

#tutorial-practice-view .feature-card:hover {
  transform: translateY(0px);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--color-primary-40);
}

#tutorial-practice-view .feature-card .lucide-icon {
  color: rgb(0,0,0);
  background-color: rgb(0,0,0,0.05);
}

#tutorial-practice-view > div {
  margin-bottom: 0;
}

.powerpoint-slide-top {
  width: 100%;
  height: 60px;
  padding: 0 40px;
  background: linear-gradient(135deg, var(--color-accent-orange-dark), var(--color-accent-orange));
  border-style: solid;
  border-width: 2px 2px 0 2px;
  border-color: var(--color-accent-orange);
  border-radius: 16px 16px 0 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--color-white);
}

.powerpoint-slide-top div {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.powerpoint-slide-container img {
  border-style: solid;
  border-width: 0 2px 0 2px;
  border-color: var(--color-accent-orange);
}

.powerpoint-slide-top img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  border: none;
}

.powerpoint-slide-point {
  width: 12px;
  height: 12px;
  background-color: var(--color-white-50);
  border-radius: var(--radius-circle);
}

.powerpoint-slide-bottom {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-secondary);
  gap: 12px;
  width: 100%;
  height: 60px;
  padding: 0 40px;
  background-color: var(--color-gray-light);
  border-style: solid;
  border-width: 2px 2px 2px 2px;
  border-right-color: var(--color-accent-orange);
  border-left-color: var(--color-accent-orange);
  border-bottom-color: var(--color-accent-orange);
  border-top-color: var(--color-border);
  border-radius: 0 0 16px 16px;
  margin-top: -4px;
}

.slide-points-container {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}


.slide-point {
  width: 12px;
  height: 12px;
  background-color: var(--color-gray-medium);
  border-radius: var(--radius-circle);
  transition: width 0.2s cubic-bezier(0.4, 0.14, 0.43, 1), background-color 0.2s cubic-bezier(0.4, 0.14, 0.43, 1), border-radius 0.2s cubic-bezier(0.4, 0.14, 0.43, 1);
}

.slide-point.completed {
  background-color: var(--color-accent-orange-50);
  transition: width 0.2s cubic-bezier(0.4, 0.14, 0.43, 1), background-color 0.2s cubic-bezier(0.4, 0.14, 0.43, 1), border-radius 0.2s cubic-bezier(0.4, 0.14, 0.43, 1);
}

.slide-point.active {
  width: 16px;
  background-color: var(--color-accent-orange);
  border-radius: var(--radius-lg);
  transition: width 0.2s cubic-bezier(0.4, 0.14, 0.43, 1), background-color 0.2s cubic-bezier(0.4, 0.14, 0.43, 1), border-radius 0.2s cubic-bezier(0.4, 0.14, 0.43, 1);
}

.tutorial__feedback--correct, .tutorial__feedback--incorrect {
  padding: 16px 40px;
  min-width: 600px;
  border-radius: var(--radius-lg);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.feedback-title {
  font-size: 18px;
  font-weight: 500;
  color: var(--color-dark);
}

.feedback-message {
  font-size: 14px;
  font-weight: 400;
  max-width: 500px;
  color: var(--color-text-secondary);
}
.tutorial__feedback--correct {
  background-color: var(--color-success-10);
  border: 1px solid var(--color-success-30);
}
.tutorial__feedback--correct svg {
  stroke: var(--color-success);
}

.tutorial__feedback--incorrect {
  background-color: var(--color-primary-10);
  border: 1px solid var(--color-primary-30);
}
.tutorial__feedback--incorrect svg {
  stroke: var(--color-primary);
}

/* game view */
#game-view .allcenter-container {
  flex-direction: row;
  align-items: start;
  justify-content: center;
  gap: var(--general-padding);
}

.game-slide-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--general-padding);
}

.game-cards-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--general-padding);
}

.game-card {
  display: grid;
  grid-template-areas:
    "main right"
    "main bottom";
  grid-template-columns: 48px 1fr;
  grid-template-rows: 24px 24px;
  column-gap: 12px;
  align-items: center;
  place-items: center;
  justify-items: start;
  justify-content: start;
}

.game-card, .game-error-result-container {
  background-color: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  width: 320px;
  height: fit-content;
  padding: 16px;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
}

.game-card .lucide-icon {
  width: 48px;
  height: 48px;
  color: var(--color-primary);
  background-color: var(--color-bg-pink);
  padding: 12px;
  border-radius: var(--radius-full);
}

.game-card-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-secondary);
}

.game-card-value {
  font-size: 24px;
  font-weight: 700;
  color: var(--color-dark);
}

.game-error-result-container {
display: flex;
flex-direction: column;
align-items: start;
justify-content: center;
gap: 8px;
}

#game-error-result-message {
  background-color: rgba(245, 240, 240, 0.5);
  border-radius: var(--radius-lg);
  padding: 16px;
  font-size: 14px;
  font-weight: 400;
  color: var(--color-text-secondary);
  width: 100%;
  min-height: 48px;
  height: auto;
  display: flex;
  align-items: start;
  justify-content: center;
  text-align: left;
  gap: 8px;
  transition: background-color var(--transition-default), border-color var(--transition-default);
}

#game-error-result-message.game-feedback--correct {
  background-color: var(--color-success-10);
  color: var(--color-success-80);
  border: 1px solid var(--color-success-30);
}

#game-error-result-message.game-feedback--incorrect {
  background-color: var(--color-primary-10);
  color: var(--color-primary-80);
  border: 1px solid var(--color-primary-30);
}

.game-error-result-message-title {
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 4px;
}

.game-error-result-message-description {
  font-size: 12px;
  font-weight: 400;
}

/* results view */
.results-main-icon {
  height: 70px;
  width: 70px;
  color: var(--color-primary);
  background-color: var(--color-primary-10);
  padding: 16px;
  border-radius: var(--radius-full);
  margin-bottom: 16px;
}

#results-view .white-bg-container {
  padding: 40px 72px;
}

.results-view-buttons-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 16px;
}

.inverted-cta-button {
  background-color: transparent;
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
  transition: background-color var(--transition-default), color var(--transition-default);
}


.inverted-cta-button:hover {
  background-color: var(--color-primary);
  color: white;
}

#linkedin-share-btn img {
  width: 20px;
  height: 20px;
  object-fit: contain;
  margin-right: 8px;
}

#results-view h2, #thankyou-view h2 {
  margin-bottom: 8px;
}

#results-view h3 {
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 8px;
}

#results-view .description-text {
  color: var(--color-text-secondary);
  font-size: 18px;
}

#results-view .feature-card {
  width: 280px;
  height: 168px;
  background-color: var(--color-bg-light);
  box-shadow: var(--shadow-sm);
  grid-template-rows: 62px 36px 36px;
}

#results-view .feature-card-title {
  font-size: 28px;
  font-weight: 700;
  color: var(--color-dark);
}

#results-view .feature-card:hover {
  transform: translateY(0px);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--color-primary-40);
}

#results-view .feature-card .lucide-icon {
  height: 64px;
  width: 64px;
  background-color: transparent;
}

#final-score {
  font-size: 52px;
  font-weight: 700;
  color: var(--color-primary);
}

.results-view-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 24px;
}

#results-view .results-view-enter-competition-text {
  font-size: 32px;
  font-weight: 700;
}

#demo-container {
  border-radius: var(--radius-lg);
  padding: 0px 24px;
  min-width: 1000px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

#demo-container h3 {
  font-size: 32px;
  font-weight: 700;
  color: var(--color-dark);
}

#demo-container p {
  font-size: 16px;
  font-weight: 400;
  color: var(--color-text-secondary);
  max-width: 90%;
}

.animated-cta-button {
  transition: transform var(--transition-default), background-color var(--transition-default);
}
.animated-cta-button:hover {
  transform: translateY(-8px);
  background-color: var(--color-primary-80);
}

/* Leaderboard Modal Styling (Story 3.7) */
#leaderboard-modal .modal__content {
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--general-padding);
  width: 600px;
  max-width: 90vw;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

#leaderboard-modal .modal__content h3 {
  font-size: 36px;
  font-weight: 700;
  color: var(--color-dark);
  text-align: center;
  margin: 0;
}

/* Leaderboard table wrapper */
.leaderboard-table-wrapper {
  overflow-y: auto;
  max-height: 400px;
}

/* Leaderboard table */
.leaderboard-table {
  width: 100%;
  border-collapse: collapse;
}

.leaderboard-table th {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-align: left;
  padding: 12px 8px;
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  background-color: var(--color-white);
}

.leaderboard-table td {
  font-size: 14px;
  font-weight: 400;
  color: var(--color-dark);
  padding: 10px 8px;
  border-bottom: 1px solid var(--color-border);
}

/* Alternating row backgrounds */
.leaderboard-table tbody tr:nth-child(even) {
  background-color: var(--color-bg-light);
}

/* Top 3 rank styling */
.leaderboard-table tbody tr:nth-child(1) td:first-child,
.leaderboard-table tbody tr:nth-child(2) td:first-child,
.leaderboard-table tbody tr:nth-child(3) td:first-child {
  color: var(--color-primary);
  font-weight: 700;
}

/* Current player highlight */
.leaderboard-row--current-player {
  background-color: var(--color-primary-10) !important;
  border-left: 3px solid var(--color-primary);
}

.leaderboard-row--current-player .leaderboard-nickname {
  font-weight: 700;
}

/* User rank display (outside top 50) */
#user-rank-display {
  background-color: var(--color-primary-10);
  border-left: 3px solid var(--color-primary);
  border-radius: var(--radius-md);
  padding: 12px;
  margin-top: 8px;
}

.leaderboard__user-entry {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.user-entry__rank {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-primary);
}

.user-entry__label {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-dark);
}

.user-entry__stats {
  display: flex;
  gap: 16px;
  font-size: 14px;
  color: var(--color-text-secondary);
}

/* Close button centered */
#leaderboard-modal .cta-button {
  align-self: center;
  padding: 12px 32px;
}

/* LinkedIn Share Modal */
#linkedin-share-modal .modal__content {
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--general-padding);
  width: 500px;
  max-width: 90vw;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

#linkedin-share-modal .modal__content h4 {
  font-size: 24px;
  font-weight: 700;
  color: var(--color-dark);
  margin: 0;
}

#linkedin-share-modal .modal__content p {
  font-size: 14px;
  color: var(--color-text-secondary);
  margin: 0;
}

.linkedin-message-preview {
  background-color: rgb(248, 249, 250);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 16px;
  font-size: 14px;
  line-height: 1.5;
  color: var(--color-dark);
  max-height: 150px;
  overflow-y: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

#linkedin-share-modal .cta-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
}

/* form view */
#form-view .game-card {
  background-color: var(--color-dark);
  color: white;
  min-width: 600px;
  padding: 22px 24px;

}
#form-view .game-card-title {
  font-size: 14px;
  font-weight: 700;
  color: inherit;
}
#form-view .game-card-value {
  font-size: 12px;
  font-weight: 400;
  color: inherit;
}
#form-view .game-card .lucide-icon {
  width: 48px;
  height: 48px;
  background-color: var(--color-primary);
  padding: 12px;
  border-radius: var(--radius-full);
  color: inherit;
}

#form-view .description-text, #thankyou-view .description-text {
  font-size: 16px;
}

.form-field-container{
  display: grid;
  min-width: 600px;
  grid-template-areas:
    "top-left top-right"
    "middle middle"
    "bottom-left bottom-right";
  grid-template-rows: 1fr 1fr 1fr;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: start;
  justify-items: start;
  margin-bottom: 16px;
}

.form-input {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: start;
  gap: 8px;
}

.form-input input {
  min-width: 100%;
  padding: 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: 16px;
  font-weight: 400;
  color: var(--color-dark);
}

.form-input input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px var(--color-primary-20);
}

.form-checkbox-container {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.form-checkbox-input {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: start;
}

.required-input label::after {
  content: " *";
  color: var(--color-primary);
  font-weight: bold;
}


.form-checkbox-input input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-circle);
  background-color: transparent;
  cursor: pointer;
  margin-right: 10px;
  position: relative;
  transition: var(--transition-border);
}

.form-checkbox-input input[type="checkbox"]:checked {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

#competition-form .cta-button {
  width: 100%;
}

#competition-form .description-text, #form-view .form-tiny-description-text {
  font-size: 12px;
  color: var(--color-text-secondary);
  margin-top: 8px;
  max-width: 600px;
}

/* ======================================== */
/* Story 3.8: ActiveCampaign Form Styling   */
/* ======================================== */

/* Task 1: Hide the fake reference form (AC: #7) */
#competition-form {
  display: none !important;
}

/* Task 2: Main form container reset (AC: #1) */
._form_38,
._form_38 *,
#_form_698125BFB7322_,
form[class*="_form"] {
  background: var(--color-bg-pink) !important;
}

._form_38,
#_form_698125BFB7322_,
form[class*="_form"] {
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
  min-width: 600px;
}

/* Task 2 & 3: Form content - grid layout (AC: #1) */
._form_38 ._form-content,
form[class*="_form"] ._form-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  max-width: 600px;
  background: var(--color-bg-pink) !important;
}

/* Task 3: First Name - column 1 */
._form_38 ._form_element._x76720960 {
  grid-column: 1;
}

/* Task 3: Last Name - column 2 */
._form_38 ._form_element._x05594857 {
  grid-column: 2;
}

/* Task 3: Full-width fields (Work Email, checkboxes, button) */
._form_38 ._form_element._x34036905, /* Work Email */
._form_38 ._form_element._x32344840, /* Consent */
._form_38 ._form_element._x40904097, /* Newsletter */
._form_38 ._button-wrapper {
  grid-column: 1 / -1;
}

/* Task 3: Company - column 1 */
._form_38 ._form_element._x78411732 {
  grid-column: 1;
}

/* Task 3: Job Title - column 2 */
._form_38 ._form_element._x02445949 {
  grid-column: 2;
}

/* Task 4: Labels (AC: #2) */
._form_38 ._form-label {
  font-weight: 500 !important;
  margin-bottom: 8px !important;
  color: var(--color-dark) !important;
}

/* Task 4: Required asterisk */
._form_38 .field-required {
  color: var(--color-primary) !important;
  font-weight: bold;
}

/* Task 5: Input fields (AC: #3) */
._form_38 input[type="text"] {
  padding: 12px !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  font-size: 16px !important;
  color: var(--color-dark) !important;
  background-color: rgb(249, 245, 245) !important;
}

/* Task 5: Input focus state */
._form_38 input[type="text"]:focus {
  outline: none !important;
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 2px var(--color-primary-20) !important;
}

/* Task 6: Hide fieldset legends - sr-only pattern (AC: #4) */
._form_38 ._form-fieldset legend {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  border: 0 !important;
}

/* Task 7: Checkbox container */
._form_38 ._row._checkbox-radio {
  display: flex;
  align-items: flex-start;
}

/* Task 7: Custom circular checkboxes (AC: #4) */
._form_38 ._row._checkbox-radio input[type="checkbox"] {
  appearance: none !important;
  -webkit-appearance: none !important;
  width: 20px !important;
  height: 20px !important;
  border: 2px solid var(--color-primary) !important;
  border-radius: var(--radius-circle) !important;
  background-color: var(--color-bg-pink) !important;
  cursor: pointer;
  margin-right: 10px !important;
  flex-shrink: 0;
  margin-top: 2px;
}

/* Task 7: Checkbox checked state */
._form_38 ._row._checkbox-radio input[type="checkbox"]:checked {
  background-color: var(--color-primary) !important;
}

/* Task 9: Hide ActiveCampaign branding (AC: #6) */
._form_38 ._form-branding {
  display: none !important;
}

._form_38 ._form-content #_form_38_submit{
  width: 100% !important;
  background-color: var(--color-primary) !important;
  color: white !important;
  border: none !important;
  border-radius: var(--radius-lg) !important;
  padding: 16px 48px !important;
  cursor: pointer !important;
  font-size: 18px !important;
  font-weight: 500 !important;
  box-shadow: var(--shadow-md) !important;
  transition: transform var(--transition-default), background-color var(--transition-default);
}

._form_38 ._form-content #_form_38_submit:hover {
  transform: translateY(-8px);
  background-color: var(--color-primary-80);
}

/* thank you view */
#thankyou-view .trusted-companies-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

#thankyou-view .trusted-companies-container h3 {
  font-size: 12px;
  font-weight: 400;
  color: var(--color-text-secondary);
  margin: 0;
}

#thankyou-view .trusted-companies-container #trust-logos-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 16px;
}

#trust-logos-container img {
  width: 100px;
  height: 50px;
  object-fit: contain;
}

#thankyou-view .thankyou-view-buttons-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 16px;
}

.thankyou-main-icon {
  height: 70px;
  width: 70px;
  color: var(--color-success);
  background-color: var(--color-success-10);
  padding: 16px;
  border-radius: var(--radius-full);
  margin-bottom: 16px;
}

.thankyou-view-card-container {
  border-bottom: 0.5px solid rgba(62, 72, 116, 0.2);
  padding-bottom: calc(var(--general-padding) * 3);
  margin-bottom: var(--general-padding);
}


.thankyou-view-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  background-color: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 32px;
  width: 600px;
  max-width: 100%;
}

.thankyou-view-card-container .description-text {
  color: var(--color-text-secondary);
}

.thankyou-view-card-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--color-dark);
}

.thankyou-view-card-value {
  display: flex;
  flex-direction: column;
  text-align: left;
  align-self: start;
  padding-left: 20%;
  font-size: 14px;
  font-weight: 400;
  color: var(--color-text-secondary);
  gap: 24px;
}

.thankyou-view-card-value li::marker {
  color: var(--color-primary);
}

/* Base animation class - elements start invisible */
.animate-appear {
  opacity: 0;
}

/* Animation triggers only when parent view is active */
.view.active .animate-appear {
  animation: appearSlideUp 250ms ease-out forwards;
}

/* Stagger delay modifiers - combine with .animate-appear */
.view.active .animate-appear.animate-delay-1 { animation-delay: 50ms; }
.view.active .animate-appear.animate-delay-2 { animation-delay: 100ms; }
.view.active .animate-appear.animate-delay-3 { animation-delay: 150ms; }
.view.active .animate-appear.animate-delay-4 { animation-delay: 200ms; }
.view.active .animate-appear.animate-delay-5 { animation-delay: 250ms; }
.view.active .animate-appear.animate-delay-6 { animation-delay: 300ms; }

/* Keyframe definition */
@keyframes appearSlideUp {
  from {
    opacity: 0;
    transform: translateY(15px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* mobile block modal */
#mobile-block-modal .modal__content {
  background-color: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--general-padding);
  width: 290px;
  height: 180px;
  display: flex;
  gap: 16px;
  flex-direction: column;
  justify-content: center;
}

@media (max-width: 580px) {
  #home-view h1 {
    font-size: 48px;
  }
  footer {
    padding: var(--general-padding) 16px;
  }
}