/* Reusable Component Styles - Mobile First */

/* Card Components - Mobile First */
.card-container {
  perspective: 1000px;
}

.card {
  background: var(--bg-white);
  border-radius: 0;
  position: relative;
  overflow: hidden;
  /* border: var(--card-border); */
  background-size: cover;
}

/* Save the date card - MOBILE FIRST (full screen) */
.save-the-date-card {
  width: 100vw;
  height: 100vh;
  margin: 0;
  border-radius: 0;
  overflow: visible; /* Allow calendar dropdown to extend beyond card */
}

.card-content {
  position: relative;
  z-index: 2;
  padding: 60px 30px;
  text-align: center;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: max(0.5rem, 2.5svh); /* Simpler: minimum 0.5rem, scales with viewport */
}

/* Form Components */
.form-container {
  background: var(--bg-white);
  border-radius: var(--radius-xl);
  padding: var(--space-lg);
  box-shadow: var(--shadow-xl);
  max-width: var(--container-md);
  margin: 0 auto;
}

.form-group {
  margin-bottom: var(--space-md);
}

.form-label {
  display: block;
  margin-bottom: var(--space-xs);
  font-weight: 600;
  color: var(--text-dark);
}

.form-input {
  width: 100%;
  padding: var(--input-padding);
  border: var(--input-border);
  border-radius: var(--radius-sm);
  font-size: var(--font-sm);
  transition: border-color var(--transition-normal);
}

.form-input:focus {
  outline: none;
  border-color: var(--primary-brown);
}

.password-input {
  padding: 12px 16px;
  border: var(--input-border);
  border-radius: var(--radius-sm);
  font-size: var(--font-sm);
  width: 100%;
  transition: border-color var(--transition-normal);
}

.password-input:focus {
  outline: none;
  border-color: #667eea;
}

/* Button Components */
.btn {
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: var(--font-sm);
  transition: all var(--transition-normal);
  text-decoration: none;
  display: inline-block;
  text-align: center;
  padding: 12px 20px;
}

.btn-primary {
  background: var(--primary-brown);
  color: var(--white);
  padding: var(--space-sm) var(--space-lg);
}

.btn-primary:hover {
  background: var(--primary-brown-hover);
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.btn-full {
  width: 100%;
}

.btn-rounded {
  border-radius: var(--radius-full);
  padding: 15px 30px;
  box-shadow: var(--shadow-md);
}

.btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

.submit-button {
  background: var(--bg-gradient-button);
  color: var(--white);
  border: none;
  padding: 12px 24px;
  border-radius: var(--radius-sm);
  font-size: var(--font-sm);
  cursor: pointer;
  width: 100%;
  transition: transform var(--transition-fast);
}

.submit-button:hover {
  transform: translateY(-2px);
}

.submit-button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

/* Typography Components - Mobile First */
.save-text {
  font-family: var(--font-heading);
  font-size: 5.5rem;
  font-weight: 400;
  color: var(--text-dark);
  line-height: 0.9;
  /* margin: 0 0 0 -4rem; */
  text-transform: uppercase;
  letter-spacing: 1rem;
}

.the-text {
  font-family: var(--font-script);
  font-size: 3rem;
  color: var(--text-dark);
  font-weight: 400;
  line-height: 0.9;
  margin: -1rem 0;
}

.date-text {
  font-family: var(--font-heading);
  font-size: 5.5rem;
  font-weight: 400;
  color: var(--text-dark);
  line-height: 0.9;
  /* margin: 0 0 0 -2rem; */
  text-transform: uppercase;
  letter-spacing: 1rem;
}

.flower-icon {
  width: 6rem;
  height: auto;
  /* margin-top: -1rem; */
}

.for-text {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-style: italic;
  font-weight: 400;
  color: var(--text-dark);
  /* letter-spacing: 0.1em; */
  /* text-transform: uppercase; */
  margin: 0;
}

.couple-names-elegant {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 400;
  color: var(--text-dark);
  /* margin: 1rem 0; */
  text-transform: uppercase;
}

.ampersand {
  font-family: var(--font-script);
}

.date-location-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  text-align: center;
}

.wedding-date-elegant {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 400;
  /* letter-spacing: 0.05em; */
  color: var(--text-dark);
  /* text-transform: uppercase; */
  margin: 0;
}

.location-text {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-style: italic;
  font-weight: 400;
  color: var(--text-dark);
  /* letter-spacing: 0.1em; */
  margin: 0;
}

.add-to-calendar-btn {
  font-family: var(--font-heading);
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--text-dark);
  background: white;
  border: 2px solid var(--text-dark);
  border-radius: var(--radius-full);
  padding: .25rem 1.25rem;
  cursor: pointer;
  transition: all var(--transition-normal);
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.add-to-calendar-btn:hover {
  background: var(--text-dark);
  color: white;
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.calendar-icon {
  font-size: 1rem;
}

/* Calendar dropdown menu */
.calendar-button-container {
  position: relative;
  display: inline-block;
}

.calendar-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background: white;
  border: 2px solid var(--text-dark);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-md);
  min-width: 220px;
  z-index: 1000;
  overflow: hidden;
}

.calendar-menu.open-upward {
  top: auto;
  bottom: calc(100% + 8px);
}

.calendar-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 12px 16px;
  border: none;
  background: white;
  font-family: 'Lato', sans-serif;
  font-size: 0.75rem;
  font-weight: 400;
  text-align: left;
  color: var(--text-dark);
  cursor: pointer;
  transition: background var(--transition-normal);
  border-bottom: 1px solid #e5e5e5;
}

.calendar-menu-item:last-child {
  border-bottom: none;
}

.calendar-menu-item:hover {
  background: #f5f5f5;
}

.calendar-menu-item:active {
  background: #e8e8e8;
}

.calendar-menu-item .menu-icon {
  font-size: 1rem;
  flex-shrink: 0;
}

.calendar-menu-item .menu-text {
  flex: 1;
}

.invitation-text {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-style: italic;
  font-weight: 400;
  color: var(--text-dark);
  margin-top: 1.5rem;
}

/* Legacy typography (keep for other pages) */
.wedding-date {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  color: var(--text-dark);
  font-weight: 600;
  padding: 10px;
}

/* Message Components */
.message {
  margin-top: var(--space-sm);
  padding: var(--space-sm);
  border-radius: var(--radius-sm);
  text-align: center;
}

.message.success {
  background: var(--message-success-bg);
  color: var(--success-green);
  border: 1px solid var(--message-success-border);
}

.message.error {
  background: var(--message-error-bg);
  color: var(--error-red-light);
  border: 1px solid var(--message-error-border);
}

.error-message {
  color: var(--error-red);
  margin-top: var(--space-sm);
  font-size: 14px;
}

/* Loading state */
.loading {
  opacity: 0.6;
}

/* SHORT SCREENS: Reduce padding and gap for compact devices */
@media (max-height: 750px) {
  .card-content {
    padding: 40px 30px;
    gap: max(0.25rem, 2svh);
  }
}

/* VERY SHORT SCREENS: More aggressive reduction for iPhone SE and similar */
@media (max-height: 700px) {
  .card-content {
    padding: 30px 30px;
    gap: max(0.2rem, 1.5svh);
  }

  .invitation-text {
    margin-top: 0;
  }
}

/* TABLET (600px+): Increase card size and typography */
@media (min-width: 600px) {
  .save-the-date-card {
    width: var(--container-md);
    max-height: calc(100svh - 3rem);
    height: auto;
    margin: auto;
    border-radius: var(--radius-xl);
  }

  /* .card-content {
    padding: 50px 40px;
    gap: 1rem;
  } */

  /* Legacy styles */
  .wedding-date {
    font-size: var(--font-3xl);
    padding: var(--space-sm);
  }

  .form-container {
    padding: var(--space-2xl);
  }

  .submit-button {
    font-size: var(--font-sm);
    width: auto;
  }
}

/* DESKTOP (900px+): Maximum card size and spacing */
@media (min-width: 900px) {
  .save-the-date-card {
    max-height: calc(100svh - 4rem);
    height: auto;
  }

  /* .card-content {
    padding: 60px 50px;
  } */

  /* Legacy styles */
  .wedding-date {
    font-size: var(--font-4xl);
  }
}
