/* =============================================
   ikigai Provider Portal - Styles
   ============================================= */

/* ---- Base / Variables ---- */
:root {
  --ikigai-primary:    #e8754a;
  --ikigai-secondary:  #4a90d9;
  --ikigai-dark:       #333333;
  --ikigai-light:      #f8f6f2;
  --ikigai-border:     #e0ddd8;
  --ikigai-online:     #27ae60;
  --ikigai-radius:     8px;
  --ikigai-shadow:     0 2px 8px rgba(0,0,0,.08);
  --ikigai-transition: .2s ease;
}

/* ---- Buttons ---- */
.ikigai-btn {
  display: inline-block;
  padding: 10px 20px;
  border: none;
  border-radius: var(--ikigai-radius);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: opacity var(--ikigai-transition);
}
.ikigai-btn:hover { opacity: .85; text-decoration: none; }

.ikigai-btn-primary   { background: var(--ikigai-primary);   color: #fff; }
.ikigai-btn-secondary { background: var(--ikigai-secondary);  color: #fff; }
.ikigai-btn-filter    { background: var(--ikigai-dark);       color: #fff; }
.ikigai-btn-reset     { background: #fff; color: var(--ikigai-dark); border: 1px solid var(--ikigai-border); }
.ikigai-btn-large     { padding: 14px 36px; font-size: 16px; }

/* ---- Badges ---- */
.ikigai-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  color: #fff;
}
.ikigai-badge-online { background: var(--ikigai-online); }

/* ---- Tags ---- */
.ikigai-tag {
  display: inline-block;
  padding: 3px 10px;
  background: var(--ikigai-light);
  border: 1px solid var(--ikigai-border);
  border-radius: 20px;
  font-size: 12px;
  color: var(--ikigai-dark);
  margin: 2px 3px 2px 0;
}

/* ---- Provider List ---- */
.ikigai-provider-list-wrap { max-width: 1100px; margin: 0 auto; padding: 20px 16px; }

.ikigai-filter-form { background: var(--ikigai-light); padding: 16px; border-radius: var(--ikigai-radius); margin-bottom: 24px; }
.ikigai-filter-row  { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.ikigai-filter-row select,
.ikigai-filter-row input[type="text"] {
  padding: 8px 12px;
  border: 1px solid var(--ikigai-border);
  border-radius: var(--ikigai-radius);
  font-size: 14px;
}

.ikigai-count { color: #888; font-size: 14px; margin-bottom: 12px; }

.ikigai-provider-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
}

.ikigai-provider-card {
  background: #fff;
  border: 1px solid var(--ikigai-border);
  border-radius: var(--ikigai-radius);
  box-shadow: var(--ikigai-shadow);
  overflow: hidden;
  transition: transform var(--ikigai-transition), box-shadow var(--ikigai-transition);
}
.ikigai-provider-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0,0,0,.12);
}

.ikigai-card-link  { display: block; color: inherit; text-decoration: none; }
.ikigai-card-image { position: relative; height: 180px; overflow: hidden; background: #f0ede8; }
.ikigai-card-image img { width: 100%; height: 100%; object-fit: cover; }
.ikigai-card-image .ikigai-badge { position: absolute; top: 8px; right: 8px; }

.ikigai-no-image {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #f0ede8, #e0ddd8);
}
.ikigai-no-image span {
  font-size: 48px; font-weight: 700; color: var(--ikigai-primary); opacity: .5;
}

.ikigai-card-body  { padding: 16px; }
.ikigai-card-name  { font-size: 18px; font-weight: 700; margin: 0 0 8px; color: var(--ikigai-dark); }
.ikigai-card-mission { font-size: 13px; color: #555; margin: 0 0 8px; line-height: 1.5; }
.ikigai-card-summary { font-size: 13px; color: #666; margin: 0 0 12px; line-height: 1.6; }

.ikigai-card-meta   { border-top: 1px solid var(--ikigai-border); padding-top: 10px; margin-top: 10px; }
.ikigai-meta-region { font-size: 12px; color: #888; display: block; margin-bottom: 6px; }
.ikigai-genre-tags  { margin-top: 4px; }

/* ---- Provider Single ---- */
.ikigai-provider-single { max-width: 900px; margin: 0 auto; padding: 20px 16px; }

.ikigai-provider-header {
  display: flex; gap: 24px; align-items: flex-start;
  margin-bottom: 32px;
}
.ikigai-provider-image img,
.ikigai-no-image-large {
  width: 160px; height: 160px; border-radius: 50%;
  object-fit: cover; flex-shrink: 0;
  border: 3px solid var(--ikigai-border);
}
.ikigai-no-image-large {
  display: flex; align-items: center; justify-content: center;
  background: var(--ikigai-light);
}
.ikigai-provider-name { font-size: 28px; font-weight: 700; margin: 0 0 8px; }
.ikigai-region        { font-size: 14px; color: #666; margin: 8px 0; }

.ikigai-provider-section { margin-bottom: 32px; }
.ikigai-provider-section h2 {
  font-size: 20px; border-left: 4px solid var(--ikigai-primary);
  padding-left: 12px; margin-bottom: 16px;
}
.ikigai-mission { font-size: 15px; line-height: 1.7; color: var(--ikigai-dark); font-weight: 500; }
.ikigai-summary { font-size: 15px; line-height: 1.8; color: #444; }

.ikigai-contact-cta { text-align: center; margin: 32px 0; }

.ikigai-event-list-inline { display: flex; flex-direction: column; gap: 16px; }
.ikigai-event-item {
  display: flex; gap: 16px; align-items: center;
  padding: 16px; background: var(--ikigai-light);
  border-radius: var(--ikigai-radius); border: 1px solid var(--ikigai-border);
}
.ikigai-event-item .ikigai-event-thumb { width: 80px; height: 60px; object-fit: cover; border-radius: 4px; }
.ikigai-event-info { flex: 1; }
.ikigai-event-title { font-size: 16px; font-weight: 600; margin: 6px 0; }
.ikigai-event-date  { font-size: 13px; color: #888; margin: 0 0 8px; }

/* ---- Event List ---- */
.ikigai-event-list-wrap { max-width: 1100px; margin: 0 auto; padding: 20px 16px; }

.ikigai-event-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
}
.ikigai-event-card {
  background: #fff;
  border: 1px solid var(--ikigai-border);
  border-radius: var(--ikigai-radius);
  box-shadow: var(--ikigai-shadow);
  overflow: hidden;
}
.ikigai-event-thumb-wrap { position: relative; height: 160px; overflow: hidden; background: #f0ede8; }
.ikigai-event-thumb-wrap img { width: 100%; height: 100%; object-fit: cover; }
.ikigai-event-thumb-wrap .ikigai-badge { position: absolute; top: 8px; right: 8px; }
.ikigai-event-card-body { padding: 16px; }
.ikigai-event-card-body .ikigai-event-title { font-size: 15px; font-weight: 700; margin: 8px 0; }
.ikigai-event-provider { font-size: 13px; color: #888; margin: 0 0 8px; }
.ikigai-event-provider a { color: var(--ikigai-secondary); text-decoration: none; }
.ikigai-event-desc { font-size: 13px; color: #666; margin: 0 0 12px; }

/* ---- Registration Form ---- */
.ikigai-reg-form-wrap { max-width: 700px; margin: 0 auto; padding: 20px 16px; }

.ikigai-steps {
  display: flex; gap: 0; margin-bottom: 32px;
  border-radius: var(--ikigai-radius); overflow: hidden;
  border: 1px solid var(--ikigai-border);
}
.ikigai-step {
  flex: 1; padding: 12px 8px; text-align: center;
  font-size: 13px; font-weight: 600; color: #aaa;
  background: var(--ikigai-light); border-right: 1px solid var(--ikigai-border);
}
.ikigai-step:last-child { border-right: none; }
.ikigai-step.active { background: var(--ikigai-primary); color: #fff; }
.ikigai-step-num {
  display: inline-block; width: 22px; height: 22px;
  border-radius: 50%; background: rgba(255,255,255,.3);
  line-height: 22px; margin-right: 6px; font-size: 12px;
}
.ikigai-step.active .ikigai-step-num { background: rgba(255,255,255,.5); }

.ikigai-form-group  { margin-bottom: 20px; }
.ikigai-form-group label { display: block; font-weight: 600; margin-bottom: 6px; font-size: 14px; }
.ikigai-form-group input[type="text"],
.ikigai-form-group input[type="url"],
.ikigai-form-group input[type="email"],
.ikigai-form-group select,
.ikigai-form-group textarea {
  width: 100%; padding: 10px 12px;
  border: 1px solid var(--ikigai-border); border-radius: var(--ikigai-radius);
  font-size: 14px; box-sizing: border-box;
  transition: border-color var(--ikigai-transition);
}
.ikigai-form-group input:focus,
.ikigai-form-group select:focus,
.ikigai-form-group textarea:focus {
  outline: none; border-color: var(--ikigai-primary);
}
.ikigai-form-group .description { font-size: 12px; color: #888; margin-top: 4px; }
.required { color: var(--ikigai-primary); }

.ikigai-url-input-row { display: flex; gap: 10px; }
.ikigai-url-input-row input { flex: 1; }

.ikigai-preview-box {
  background: var(--ikigai-light); border: 1px solid var(--ikigai-border);
  border-radius: var(--ikigai-radius); padding: 16px; margin-bottom: 20px;
}
.ikigai-preview-box h3 { margin: 0 0 12px; font-size: 15px; }
.ikigai-preview-profile { display: flex; gap: 16px; align-items: flex-start; }
.ikigai-preview-image-wrap img { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; }

.ikigai-genre-checkboxes { display: flex; flex-wrap: wrap; gap: 12px; }
.ikigai-checkbox-label   { display: flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 400; cursor: pointer; }

.ikigai-notice {
  background: var(--ikigai-light); border: 1px solid var(--ikigai-border);
  border-left: 4px solid var(--ikigai-secondary);
  border-radius: var(--ikigai-radius); padding: 16px; margin-bottom: 20px;
}
.ikigai-notice-warning { border-left-color: #e67e22; background: #fef9f0; }
.ikigai-notice-success { border-left-color: var(--ikigai-online); background: #f0faf4; }
.ikigai-notice h3     { margin: 0 0 8px; font-size: 15px; }
.ikigai-notice ul     { margin: 0; padding-left: 20px; font-size: 14px; }
.ikigai-notice li     { margin-bottom: 4px; }

.ikigai-form-nav { display: flex; justify-content: flex-end; gap: 12px; margin-top: 24px; }

.ikigai-spinner {
  display: inline-block; width: 16px; height: 16px;
  border: 2px solid var(--ikigai-border); border-top-color: var(--ikigai-primary);
  border-radius: 50%; animation: ikigai-spin .7s linear infinite;
  vertical-align: middle; margin-right: 6px;
}
@keyframes ikigai-spin { to { transform: rotate(360deg); } }

#ikigai-form-messages .ikigai-msg-error   { color: #c0392b; background: #fdf0ee; padding: 10px 14px; border-radius: 6px; margin-bottom: 16px; }
#ikigai-form-messages .ikigai-msg-success { color: #27ae60; background: #f0faf4; padding: 10px 14px; border-radius: 6px; margin-bottom: 16px; }

/* ---- Pagination ---- */
.ikigai-pagination { margin-top: 32px; text-align: center; }
.ikigai-pagination .page-numbers {
  display: inline-block; padding: 8px 14px; margin: 0 3px;
  border: 1px solid var(--ikigai-border); border-radius: 4px;
  font-size: 14px; color: var(--ikigai-dark); text-decoration: none;
  transition: background var(--ikigai-transition);
}
.ikigai-pagination .current { background: var(--ikigai-primary); color: #fff; border-color: var(--ikigai-primary); }
.ikigai-pagination .page-numbers:hover:not(.current) { background: var(--ikigai-light); }

.ikigai-no-results { text-align: center; color: #888; padding: 40px 0; font-size: 15px; }

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .ikigai-provider-grid,
  .ikigai-event-grid    { grid-template-columns: 1fr; }
  .ikigai-provider-header { flex-direction: column; align-items: center; text-align: center; }
  .ikigai-provider-image img { width: 120px; height: 120px; }
  .ikigai-filter-row    { flex-direction: column; }
  .ikigai-filter-row select,
  .ikigai-filter-row input { width: 100%; }
  .ikigai-url-input-row { flex-direction: column; }
  .ikigai-steps .ikigai-step { font-size: 11px; padding: 10px 4px; }
  .ikigai-form-nav { flex-direction: column-reverse; }
  .ikigai-btn-large { width: 100%; text-align: center; }
}
