/* buttons.css — Your work goes here. */

/* ============================================================
   BASE BUTTON
   ============================================================ */

.btn {
   display: inline-flex;
   align-items: center;
   gap: 5px;
   border-radius: var(--radius-md);
   font-size: 0.9rem;
   font-weight: 600;
   padding: 0.6rem 1.25rem;
   cursor: pointer;
   border: 1px solid transparent;
   transition: var(--transition-base);
}

/* ============================================================
   PRIMARY BUTTON
   ============================================================ */

.btn-primary {
   background: var(--color-accent);
   color: white;

   &:hover, &:focus {
      transform: translateY(-2px);
      box-shadow: var(--shadow-md);
   }

   &:active {
      transform: translateY(0);
      box-shadow: var(--shadow-sm);
   }
}

/* ============================================================
   GHOST BUTTON
   ============================================================ */

.btn-ghost {
   background: transparent;
   color: var(--color-text-muted);
   border: 1px solid var(--color-border);

   &:hover, &:focus {
      background-color: var(--color-surface-raised);
      color: var(--color-text);
      border-color: var(--color-accent);
   }
}

/* ============================================================
   ICON BUTTON
   ============================================================ */

.btn-icon {
   width: 2.5rem;
   height: 2.5rem;
   padding: 0;
   display: flex;
   align-items: center;
   justify-content: center;
   background: transparent;
   border: 1px solid var(--color-border);
   color: var(--color-text-muted);
   transition: var(--transition-base);

   &:hover, &:focus {
      transform: scale(1.1);
      color: var(--color-accent-light);
   }
}

/* ============================================================
   LOADING BUTTON
   ============================================================ */

@keyframes spin {
   0% {
      transform: rotate(0deg);
   }
   100% {
      transform: rotate(360deg);
   }
}

.btn-loading {
   background: var(--color-surface-raised);
   color: var(--color-text-muted);
   cursor: default;
   display: inline-flex;
   gap: 10px;
}

.loading-spinner {
   width: 1rem;
   height: 1rem;
   border-radius: 50%;
   border: 2px solid var(--color-border);
   border-top-color: var(--color-accent-light);
   animation: spin 700ms linear infinite;
}
