/* ============================================================
   Petwebly Affiliate Marketplace — Public Stylesheet
   Brand: Deep Navy (#1a237e) + Amber (#f59e0b) + White
   ============================================================ */

:root {
  --pam-navy:       #1a237e;
  --pam-navy-dark:  #0d1457;
  --pam-navy-light: #283593;
  --pam-amber:      #f59e0b;
  --pam-amber-dark: #d97706;
  --pam-amber-light:#fbbf24;
  --pam-white:      #ffffff;
  --pam-grey-50:    #f9fafb;
  --pam-grey-100:   #f3f4f6;
  --pam-grey-200:   #e5e7eb;
  --pam-grey-400:   #9ca3af;
  --pam-grey-600:   #4b5563;
  --pam-grey-800:   #1f2937;
  --pam-success:    #10b981;
  --pam-danger:     #ef4444;
  --pam-warning:    #f59e0b;
  --pam-radius:     12px;
  --pam-radius-sm:  8px;
  --pam-shadow:     0 4px 24px rgba(26,35,126,0.10);
  --pam-shadow-lg:  0 8px 40px rgba(26,35,126,0.16);
  --pam-transition: 0.25s ease;
}

/* ── Reset & Base ─────────────────────────────────────────── */
.pam-wrap * { box-sizing: border-box; }
.pam-wrap { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; color: var(--pam-grey-800); }

/* ── Notices ──────────────────────────────────────────────── */
.pam-notice {
  padding: 14px 20px;
  border-radius: var(--pam-radius-sm);
  margin-bottom: 20px;
  font-size: 15px;
  line-height: 1.5;
}
.pam-notice a { font-weight: 600; }
.pam-notice-info    { background: #e8eaf6; border-left: 4px solid var(--pam-navy); color: var(--pam-navy-dark); }
.pam-notice-success { background: #d1fae5; border-left: 4px solid var(--pam-success); color: #065f46; }
.pam-notice-warning { background: #fef3c7; border-left: 4px solid var(--pam-amber); color: #92400e; }
.pam-notice-error   { background: #fee2e2; border-left: 4px solid var(--pam-danger); color: #991b1b; }

/* ── Buttons ──────────────────────────────────────────────── */
.pam-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  border-radius: var(--pam-radius-sm);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: all var(--pam-transition);
  line-height: 1;
}
.pam-btn-primary   { background: var(--pam-navy); color: var(--pam-white); }
.pam-btn-primary:hover { background: var(--pam-navy-dark); color: var(--pam-white); transform: translateY(-1px); box-shadow: var(--pam-shadow); }
.pam-btn-amber     { background: var(--pam-amber); color: var(--pam-navy-dark); }
.pam-btn-amber:hover { background: var(--pam-amber-dark); color: var(--pam-navy-dark); transform: translateY(-1px); }
.pam-btn-outline   { background: transparent; border: 2px solid var(--pam-navy); color: var(--pam-navy); }
.pam-btn-outline:hover { background: var(--pam-navy); color: var(--pam-white); }
.pam-btn-sm        { padding: 8px 16px; font-size: 13px; }
.pam-btn-lg        { padding: 16px 36px; font-size: 17px; }
.pam-btn-full      { width: 100%; justify-content: center; }

/* ── Forms ────────────────────────────────────────────────── */
.pam-form-group { margin-bottom: 20px; }
.pam-form-group label { display: block; font-size: 14px; font-weight: 600; color: var(--pam-grey-600); margin-bottom: 6px; }
.pam-form-group label span.required { color: var(--pam-danger); margin-left: 3px; }
.pam-form-control {
  width: 100%;
  padding: 12px 16px;
  border: 2px solid var(--pam-grey-200);
  border-radius: var(--pam-radius-sm);
  font-size: 15px;
  color: var(--pam-grey-800);
  background: var(--pam-white);
  transition: border-color var(--pam-transition);
  outline: none;
}
.pam-form-control:focus { border-color: var(--pam-navy); }
.pam-form-control::placeholder { color: var(--pam-grey-400); }
textarea.pam-form-control { min-height: 100px; resize: vertical; }
select.pam-form-control { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%234b5563' d='M6 8L0 0h12z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; padding-right: 40px; }
.pam-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media (max-width: 600px) { .pam-form-row { grid-template-columns: 1fr; } }

/* ── Cards ────────────────────────────────────────────────── */
.pam-card {
  background: var(--pam-white);
  border-radius: var(--pam-radius);
  box-shadow: var(--pam-shadow);
  overflow: hidden;
  transition: transform var(--pam-transition), box-shadow var(--pam-transition);
}
.pam-card:hover { transform: translateY(-4px); box-shadow: var(--pam-shadow-lg); }
.pam-card-body { padding: 24px; }
.pam-card-header { padding: 20px 24px; border-bottom: 1px solid var(--pam-grey-100); }

/* ── Badges ───────────────────────────────────────────────── */
.pam-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.pam-badge-approved  { background: #d1fae5; color: #065f46; }
.pam-badge-pending   { background: #fef3c7; color: #92400e; }
.pam-badge-suspended { background: #fee2e2; color: #991b1b; }
.pam-badge-featured  { background: var(--pam-amber); color: var(--pam-navy-dark); }

/* ── Marketplace Page ─────────────────────────────────────── */

/* Hero */
.pam-hero {
  background: linear-gradient(135deg, var(--pam-navy) 0%, var(--pam-navy-light) 60%, #3949ab 100%);
  padding: 80px 20px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.pam-hero::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -20%;
  width: 60%;
  height: 200%;
  background: rgba(255,255,255,0.03);
  border-radius: 50%;
}
.pam-hero-content { position: relative; z-index: 1; max-width: 800px; margin: 0 auto; }
.pam-hero h1 { font-size: clamp(28px, 5vw, 52px); font-weight: 800; color: var(--pam-white); margin: 0 0 16px; line-height: 1.15; }
.pam-hero h1 span { color: var(--pam-amber); }
.pam-hero p { font-size: 18px; color: rgba(255,255,255,0.85); margin: 0 0 36px; line-height: 1.6; }

/* Search Bar */
.pam-search-bar {
  display: flex;
  max-width: 640px;
  margin: 0 auto 32px;
  background: var(--pam-white);
  border-radius: 50px;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,0.2);
}
.pam-search-bar input {
  flex: 1;
  border: none;
  padding: 16px 24px;
  font-size: 16px;
  outline: none;
  background: transparent;
  color: var(--pam-grey-800);
}
.pam-search-bar button {
  background: var(--pam-amber);
  border: none;
  padding: 16px 28px;
  font-size: 15px;
  font-weight: 700;
  color: var(--pam-navy-dark);
  cursor: pointer;
  transition: background var(--pam-transition);
  white-space: nowrap;
}
.pam-search-bar button:hover { background: var(--pam-amber-dark); }

/* Hero CTA Buttons */
.pam-hero-ctas { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* Section */
.pam-section { padding: 64px 20px; }
.pam-section-alt { background: var(--pam-grey-50); }
.pam-section-title { text-align: center; margin-bottom: 48px; }
.pam-section-title h2 { font-size: clamp(24px, 4vw, 38px); font-weight: 800; color: var(--pam-navy); margin: 0 0 12px; }
.pam-section-title p { font-size: 17px; color: var(--pam-grey-600); margin: 0; }
.pam-section-title .pam-divider { width: 60px; height: 4px; background: var(--pam-amber); border-radius: 2px; margin: 16px auto 0; }

/* Category Grid */
.pam-category-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 20px;
  max-width: 1200px;
  margin: 0 auto;
}
.pam-category-card {
  background: var(--pam-white);
  border-radius: var(--pam-radius);
  padding: 28px 16px;
  text-align: center;
  text-decoration: none;
  box-shadow: var(--pam-shadow);
  transition: all var(--pam-transition);
  border: 2px solid transparent;
  cursor: pointer;
}
.pam-category-card:hover {
  border-color: var(--pam-amber);
  transform: translateY(-6px);
  box-shadow: var(--pam-shadow-lg);
  text-decoration: none;
}
.pam-category-icon {
  width: 64px;
  height: 64px;
  background: linear-gradient(135deg, var(--pam-navy) 0%, var(--pam-navy-light) 100%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  font-size: 28px;
  transition: background var(--pam-transition);
}
.pam-category-card:hover .pam-category-icon { background: linear-gradient(135deg, var(--pam-amber) 0%, var(--pam-amber-dark) 100%); }
.pam-category-card h3 { font-size: 14px; font-weight: 700; color: var(--pam-navy); margin: 0; line-height: 1.3; }

/* Featured Partners */
.pam-partners-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
}
.pam-partner-card {
  background: var(--pam-white);
  border-radius: var(--pam-radius);
  box-shadow: var(--pam-shadow);
  overflow: hidden;
  transition: all var(--pam-transition);
  position: relative;
}
.pam-partner-card:hover { transform: translateY(-4px); box-shadow: var(--pam-shadow-lg); }
.pam-partner-card .pam-featured-ribbon {
  position: absolute;
  top: 16px;
  right: -8px;
  background: var(--pam-amber);
  color: var(--pam-navy-dark);
  font-size: 11px;
  font-weight: 800;
  padding: 4px 16px 4px 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.pam-partner-logo {
  height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--pam-grey-50);
  padding: 20px;
  border-bottom: 1px solid var(--pam-grey-100);
}
.pam-partner-logo img { max-height: 80px; max-width: 100%; object-fit: contain; }
.pam-partner-logo .pam-logo-placeholder {
  font-size: 40px;
  font-weight: 800;
  color: var(--pam-navy);
  opacity: 0.3;
}
.pam-partner-info { padding: 20px; }
.pam-partner-info h3 { font-size: 17px; font-weight: 700; color: var(--pam-navy); margin: 0 0 8px; }
.pam-partner-info p { font-size: 14px; color: var(--pam-grey-600); margin: 0 0 16px; line-height: 1.5; }
.pam-partner-commission { font-size: 13px; color: var(--pam-grey-600); margin-bottom: 16px; }
.pam-partner-commission strong { color: var(--pam-success); font-size: 15px; }

/* How It Works */
.pam-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 32px; max-width: 1000px; margin: 0 auto; }
.pam-step { text-align: center; padding: 32px 20px; }
.pam-step-number {
  width: 56px;
  height: 56px;
  background: var(--pam-amber);
  color: var(--pam-navy-dark);
  border-radius: 50%;
  font-size: 22px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
}
.pam-step h3 { font-size: 18px; font-weight: 700; color: var(--pam-navy); margin: 0 0 10px; }
.pam-step p { font-size: 15px; color: var(--pam-grey-600); margin: 0; line-height: 1.6; }

/* Trust Signals */
.pam-trust-bar {
  background: var(--pam-navy);
  padding: 32px 20px;
  display: flex;
  justify-content: center;
  gap: 48px;
  flex-wrap: wrap;
}
.pam-trust-item { text-align: center; color: var(--pam-white); }
.pam-trust-item .pam-trust-icon { font-size: 32px; margin-bottom: 8px; }
.pam-trust-item strong { display: block; font-size: 22px; font-weight: 800; color: var(--pam-amber); }
.pam-trust-item span { font-size: 13px; color: rgba(255,255,255,0.75); }

/* Revenue Banner */
.pam-revenue-banner {
  background: linear-gradient(135deg, var(--pam-amber) 0%, #fbbf24 100%);
  padding: 48px 20px;
  text-align: center;
}
.pam-revenue-banner h2 { font-size: 32px; font-weight: 800; color: var(--pam-navy-dark); margin: 0 0 12px; }
.pam-revenue-banner p { font-size: 17px; color: var(--pam-navy); margin: 0 0 28px; }

/* ── Dashboard ────────────────────────────────────────────── */
.pam-dashboard { max-width: 1100px; margin: 0 auto; padding: 32px 20px; }
.pam-dashboard-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 32px; flex-wrap: wrap; gap: 16px; }
.pam-dashboard-header h1 { font-size: 28px; font-weight: 800; color: var(--pam-navy); margin: 0; }

/* Stats Grid */
.pam-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 20px; margin-bottom: 32px; }
.pam-stat-card {
  background: var(--pam-white);
  border-radius: var(--pam-radius);
  padding: 24px;
  box-shadow: var(--pam-shadow);
  border-top: 4px solid var(--pam-navy);
  text-align: center;
}
.pam-stat-card.amber { border-top-color: var(--pam-amber); }
.pam-stat-card.green { border-top-color: var(--pam-success); }
.pam-stat-card .pam-stat-value { font-size: 32px; font-weight: 800; color: var(--pam-navy); margin-bottom: 4px; }
.pam-stat-card .pam-stat-label { font-size: 13px; color: var(--pam-grey-600); font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }

/* Affiliate Code Box */
.pam-code-box {
  background: var(--pam-grey-50);
  border: 2px dashed var(--pam-navy);
  border-radius: var(--pam-radius);
  padding: 24px;
  margin-bottom: 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
}
.pam-code-box .pam-code { font-size: 24px; font-weight: 800; color: var(--pam-navy); letter-spacing: 2px; font-family: monospace; }
.pam-code-box p { font-size: 14px; color: var(--pam-grey-600); margin: 4px 0 0; }

/* Tables */
.pam-table-wrap { overflow-x: auto; border-radius: var(--pam-radius); box-shadow: var(--pam-shadow); margin-bottom: 32px; }
.pam-table { width: 100%; border-collapse: collapse; background: var(--pam-white); }
.pam-table th { background: var(--pam-navy); color: var(--pam-white); padding: 14px 16px; font-size: 13px; font-weight: 700; text-align: left; text-transform: uppercase; letter-spacing: 0.5px; }
.pam-table td { padding: 14px 16px; font-size: 14px; border-bottom: 1px solid var(--pam-grey-100); vertical-align: middle; }
.pam-table tr:last-child td { border-bottom: none; }
.pam-table tr:hover td { background: var(--pam-grey-50); }
.pam-table .pam-link-code { font-family: monospace; font-size: 13px; background: var(--pam-grey-100); padding: 4px 8px; border-radius: 4px; }

/* Tabs */
.pam-tabs { display: flex; border-bottom: 2px solid var(--pam-grey-200); margin-bottom: 28px; flex-wrap: wrap; gap: 4px; }
.pam-tab { padding: 12px 20px; font-size: 14px; font-weight: 600; color: var(--pam-grey-600); cursor: pointer; border-bottom: 3px solid transparent; margin-bottom: -2px; transition: all var(--pam-transition); }
.pam-tab:hover { color: var(--pam-navy); }
.pam-tab.active { color: var(--pam-navy); border-bottom-color: var(--pam-amber); }
.pam-tab-panel { display: none; }
.pam-tab-panel.active { display: block; }

/* ── Register / Login Forms ───────────────────────────────── */
.pam-auth-wrap { max-width: 600px; margin: 0 auto; padding: 40px 20px; }
.pam-auth-card { background: var(--pam-white); border-radius: var(--pam-radius); box-shadow: var(--pam-shadow-lg); overflow: hidden; }
.pam-auth-header { background: linear-gradient(135deg, var(--pam-navy), var(--pam-navy-light)); padding: 36px 40px; text-align: center; }
.pam-auth-header h2 { font-size: 26px; font-weight: 800; color: var(--pam-white); margin: 0 0 8px; }
.pam-auth-header p { font-size: 15px; color: rgba(255,255,255,0.8); margin: 0; }
.pam-auth-body { padding: 36px 40px; }
@media (max-width: 500px) { .pam-auth-body { padding: 24px 20px; } .pam-auth-header { padding: 28px 20px; } }

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 768px) {
  .pam-hero { padding: 48px 16px; }
  .pam-section { padding: 40px 16px; }
  .pam-category-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .pam-trust-bar { gap: 24px; }
  .pam-dashboard { padding: 20px 16px; }
  .pam-stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .pam-category-grid { grid-template-columns: repeat(2, 1fr); }
  .pam-stats-grid { grid-template-columns: 1fr 1fr; }
  .pam-hero-ctas { flex-direction: column; align-items: center; }
}
