/* 
  Reusable Component System
*/

/* Buttons */
.btn-solid-dark {
  background: var(--accent-color);
  color: #fff;
  padding: 16px 32px;
  border-radius: 12px;
  font-weight: 700;
  text-decoration: none;
  display: inline-block;
  transition: var(--transition);
  border: none;
  cursor: pointer;
}

.btn-solid-dark:hover {
  background: var(--accent-hover);
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(0, 122, 255, 0.2);
}

.nav-book-btn {
  background: var(--accent-color);
  color: #fff !important;
  padding: 8px 20px;
  border-radius: 8px; /* Sharper for consistency */
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: var(--transition);
}

.nav-book-btn:hover {
  background: var(--accent-hover);
}

/* Cards & Frames */
.card-premium {
  background: var(--card-bg);
  border-radius: 12px;
  padding: 40px;
  border: 1px solid rgba(0,0,0,0.05);
  transition: var(--transition);
}

.card-premium:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 40px rgba(0,0,0,0.05);
}

.img-frame-rounded {
  border-radius: 12px;
  overflow: hidden;
  position: relative;
}

/* Form Inputs */
.input-minimal {
  width: 100%;
  padding: 16px 20px;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  background: #fff;
  font-family: inherit;
  font-size: 15px;
  transition: var(--transition);
}

.input-minimal:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 4px rgba(0, 122, 255, 0.1);
}

/* Tags & Labels */
.tag-badge {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 4px 12px;
  border-radius: 20px;
  background: rgba(0,0,0,0.05);
  color: var(--text-secondary);
}

