/* ── GiftConnect v2 Frontend CSS ──────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Poppins:wght@700;800;900&display=swap');

:root {
  --gc-primary:  #FF6B6B;
  --gc-secondary:#4ECDC4;
  --gc-purple:   #6C5CE7;
  --gc-green:    #00B894;
  --gc-yellow:   #FFD93D;
  --gc-pink:     #FD79A8;
  --gc-blue:     #74B9FF;
  --gc-dark:     #2D3436;
  --gc-font:     'Nunito', sans-serif;
  --gc-heading:  'Poppins', sans-serif;
  --gc-radius:   16px;
  --gc-radius-sm:10px;
  --gc-shadow:   0 4px 20px rgba(0,0,0,0.08);
  --gc-shadow-lg:0 16px 40px rgba(0,0,0,0.15);
}

.gc-wrap { font-family: var(--gc-font); color: var(--gc-dark); }
.gc-wrap * { box-sizing: border-box; }
.gc-wrap h1,.gc-wrap h2,.gc-wrap h3,.gc-wrap h4 { font-family: var(--gc-heading); margin:0 0 8px; }

/* ── Hero ─────────────────────────────────────────── */
.gc-hero {
  background: linear-gradient(135deg,#1a1a2e 0%,#16213e 40%,#0f3460 70%,#533483 100%);
  padding: 40px 24px; text-align: center; position: relative; overflow: hidden;
}
.gc-hero::before {
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse at 20% 50%,rgba(255,107,107,0.15) 0%,transparent 60%),
              radial-gradient(ellipse at 80% 20%,rgba(108,92,231,0.2) 0%,transparent 50%),
              radial-gradient(ellipse at 60% 80%,rgba(78,205,196,0.1) 0%,transparent 50%);
}
.gc-hero-inner { position:relative; z-index:1; max-width:700px; margin:0 auto; }
.gc-hero h1 { font-size:clamp(1.6rem,4vw,2.8rem); color:#fff; text-shadow:0 2px 20px rgba(0,0,0,0.3); letter-spacing:-0.5px; margin-bottom:10px; }
.gc-hero p  { font-size:1rem; color:rgba(255,255,255,0.85); margin-bottom:24px; font-weight:600; }
.gc-hero-btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ── Birthday Bar ─────────────────────────────────── */
.gc-birthday-bar { background:linear-gradient(135deg,#6C5CE7,#a29bfe); color:#fff; text-align:center; padding:10px 20px; font-weight:700; font-size:0.95rem; }
.gc-birthday-today { background:linear-gradient(135deg,#FF6B6B,#FD79A8); animation:gc-pulse 1.5s infinite; }
@keyframes gc-pulse { 0%,100%{opacity:1} 50%{opacity:0.85} }

/* ── How It Works Strip ───────────────────────────── */
.gc-hiw-strip { display:flex; align-items:center; justify-content:center; gap:12px; background:linear-gradient(135deg,#f8f9ff,#fff5fb); padding:20px 24px; flex-wrap:wrap; }
.gc-hiw-step { display:flex; align-items:center; gap:10px; font-weight:700; font-size:0.9rem; color:#555; }
.gc-hiw-num  { width:30px; height:30px; border-radius:50%; background:var(--gc-purple); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:900; font-size:0.85rem; flex-shrink:0; }
.gc-hiw-arrow{ color:#ccc; font-size:1.2rem; font-weight:700; }

/* ── Buttons ──────────────────────────────────────── */
.gc-btn { display:inline-flex; align-items:center; gap:8px; padding:11px 24px; border:none; border-radius:50px; font-family:var(--gc-font); font-size:0.95rem; font-weight:700; cursor:pointer; transition:all 0.25s ease; text-decoration:none; line-height:1; }
.gc-btn:hover { transform:translateY(-2px); text-decoration:none; }
.gc-btn-white  { background:#fff; color:var(--gc-primary); box-shadow:0 4px 20px rgba(0,0,0,0.15); }
.gc-btn-white:hover { box-shadow:0 8px 30px rgba(0,0,0,0.2); color:var(--gc-primary); }
.gc-btn-primary{ background:var(--gc-primary); color:#fff; box-shadow:0 4px 20px rgba(255,107,107,0.4); }
.gc-btn-primary:hover { box-shadow:0 8px 30px rgba(255,107,107,0.5); color:#fff; }
.gc-btn-secondary{ background:var(--gc-secondary); color:#fff; box-shadow:0 4px 20px rgba(78,205,196,0.4); }
.gc-btn-secondary:hover { color:#fff; }
.gc-btn-purple { background:var(--gc-purple); color:#fff; box-shadow:0 4px 20px rgba(108,92,231,0.4); }
.gc-btn-purple:hover { color:#fff; }
.gc-btn-success{ background:var(--gc-green); color:#fff; }
.gc-btn-success:hover{ background:#00a381; color:#fff; }
.gc-btn-danger { background:#e74c3c; color:#fff; }
.gc-btn-danger:hover { background:#c0392b; color:#fff; }
.gc-btn-outline{ background:transparent; color:var(--gc-primary); border:2px solid var(--gc-primary); }
.gc-btn-outline:hover { background:var(--gc-primary); color:#fff; }
.gc-btn-outline-white{ background:transparent; color:#fff; border:2px solid rgba(255,255,255,0.6); }
.gc-btn-outline-white:hover { background:rgba(255,255,255,0.15); color:#fff; }
.gc-btn-sm { padding:7px 16px; font-size:0.85rem; }
.gc-btn:disabled { opacity:0.6; cursor:not-allowed; transform:none; }

/* ── Section ──────────────────────────────────────── */
.gc-section     { padding:48px 24px; max-width:1200px; margin:0 auto; }
.gc-section-alt { background:linear-gradient(135deg,#f8f9ff,#fff5fb); padding:48px 24px; }
.gc-section-dark{ background:linear-gradient(135deg,#1a1a2e,#16213e); padding:48px 24px; }
.gc-section-title { font-size:1.7rem; font-weight:900; color:var(--gc-dark); margin-bottom:8px; }
.gc-section-title-white,.gc-section-dark .gc-section-title { color:#fff; }
.gc-section-sub { font-size:0.95rem; color:#666; margin-bottom:28px; font-weight:600; }
.gc-section-sub-white,.gc-section-dark .gc-section-sub { color:rgba(255,255,255,0.75); }

/* ── Category Grid ────────────────────────────────── */
.gc-category-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:12px; }
.gc-category-btn {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:6px; padding:16px 10px;
  background:#fff; border:none; border-radius:var(--gc-radius);
  cursor:pointer; transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow:var(--gc-shadow); position:relative; overflow:hidden;
  font-family:var(--gc-font); font-weight:700; font-size:0.82rem;
  color:var(--gc-dark); text-decoration:none;
}
.gc-category-btn::before { content:''; position:absolute; inset:0; background:var(--cat-color,var(--gc-primary)); opacity:0; transition:opacity 0.3s; }
.gc-category-btn:hover,.gc-category-btn.active { transform:translateY(-4px) scale(1.04); box-shadow:var(--gc-shadow-lg); color:#fff; }
.gc-category-btn:hover::before,.gc-category-btn.active::before { opacity:1; }
.gc-cat-icon { font-size:1.7rem; position:relative; z-index:1; transition:transform 0.3s; }
.gc-category-btn:hover .gc-cat-icon,.gc-category-btn.active .gc-cat-icon { transform:scale(1.2) rotate(-5deg); }
.gc-cat-name { position:relative; z-index:1; }
.gc-cat-bar  { position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--cat-color,var(--gc-primary)); opacity:0.7; }
.gc-section-dark .gc-category-btn { background:rgba(255,255,255,0.1); color:#fff; border:1px solid rgba(255,255,255,0.15); }
.gc-section-dark .gc-category-btn::before { background:var(--cat-color,var(--gc-primary)); }

/* ── Page Header ──────────────────────────────────── */
.gc-page-header { background:linear-gradient(135deg,#6C5CE7,#a29bfe); padding:18px 24px; text-align:center; }
.gc-page-header-inner h1 { color:#fff; font-size:clamp(1.1rem,3vw,1.5rem); margin-bottom:4px; }
.gc-page-header-inner p  { color:rgba(255,255,255,0.85); font-weight:600; font-size:0.85rem; margin:0; }

/* ── Filter Bar ───────────────────────────────────── */
.gc-filter-bar { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:28px; }
.gc-filter-btn { padding:6px 12px; border-radius:50px; font-weight:700; font-size:0.82rem; border:2px solid #e0e0e0; background:#fff; color:#555; text-decoration:none; transition:all 0.2s; cursor:pointer; white-space:nowrap; }
.gc-filter-btn:hover,.gc-filter-btn.active { background:var(--fc,var(--gc-purple)); border-color:var(--fc,var(--gc-purple)); color:#fff; }

/* ── Business Cards ───────────────────────────────── */
.gc-biz-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:20px; }
.gc-biz-grid-full { grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); }
.gc-biz-card {
  display:flex; flex-direction:column; background:#fff; border-radius:var(--gc-radius);
  box-shadow:var(--gc-shadow); overflow:hidden; text-decoration:none; color:var(--gc-dark);
  transition:all 0.3s ease; position:relative; border-top:4px solid var(--biz-color,#6C5CE7);
}
.gc-biz-card:hover { transform:translateY(-6px); box-shadow:var(--gc-shadow-lg); text-decoration:none; color:var(--gc-dark); }
.gc-biz-has-offer { border-top:4px solid var(--biz-color,#FF6B6B); }
.gc-biz-has-offer::after { content:''; position:absolute; inset:0; border-radius:var(--gc-radius); box-shadow:0 0 0 2px var(--biz-color,#FF6B6B); pointer-events:none; }
.gc-biz-offer-ribbon { position:absolute; top:12px; right:-2px; background:var(--biz-color,#FF6B6B); color:#fff; font-size:0.7rem; font-weight:800; padding:4px 10px 4px 8px; border-radius:4px 0 0 4px; }
.gc-biz-card-top { display:flex; align-items:center; justify-content:space-between; padding:16px 16px 8px; }
.gc-biz-avatar { width:52px; height:52px; border-radius:14px; background:linear-gradient(135deg,var(--biz-color,#6C5CE7),rgba(0,0,0,0.1)); display:flex; align-items:center; justify-content:center; font-size:1.8rem; }
.gc-biz-online-badge { font-size:0.72rem; font-weight:800; background:#e8f8f5; color:#00B894; padding:4px 8px; border-radius:20px; }
.gc-offer-badge { font-size:0.72rem; font-weight:800; background:linear-gradient(135deg,#FF6B6B,#FD79A8); color:#fff; padding:4px 8px; border-radius:20px; }
.gc-biz-card-body { padding:4px 16px 16px; flex:1; }
.gc-biz-card-body h3 { font-size:1rem; font-weight:900; margin-bottom:6px; }
.gc-biz-cat-tag { display:inline-block; font-size:0.72rem; font-weight:800; color:#fff; padding:3px 10px; border-radius:20px; margin-bottom:8px; }
.gc-biz-subs { display:flex; flex-wrap:wrap; gap:5px; margin:8px 0; }
.gc-sub-tag { font-size:0.72rem; font-weight:700; background:#f3f0ff; color:var(--gc-purple); padding:3px 8px; border-radius:20px; }
.gc-biz-location { font-size:0.8rem; color:#888; margin:4px 0; }
.gc-biz-rating { font-size:0.85rem; margin:4px 0; }
.gc-biz-desc { font-size:0.82rem; color:#666; margin-top:6px; line-height:1.5; }
.gc-biz-card-footer { padding:10px 16px; border-top:1px solid #f0f0f0; }
.gc-biz-offer-count { font-size:0.8rem; font-weight:800; color:var(--gc-primary); }

/* ── Business Profile ─────────────────────────────── */
.gc-back-link { color:var(--gc-purple); font-weight:700; text-decoration:none; }
.gc-back-link:hover { text-decoration:underline; }
.gc-profile-header { background:linear-gradient(135deg,var(--biz-color,#6C5CE7),#1a1a2e); padding:36px 24px; display:flex; align-items:center; gap:24px; flex-wrap:wrap; }
.gc-profile-avatar { width:80px; height:80px; border-radius:20px; background:rgba(255,255,255,0.15); display:flex; align-items:center; justify-content:center; font-size:2.8rem; flex-shrink:0; }
.gc-profile-info h1 { color:#fff; font-size:1.8rem; }
.gc-profile-info p,.gc-profile-info span { color:rgba(255,255,255,0.85); font-weight:600; font-size:0.9rem; }
.gc-profile-info a { color:#fff; }
.gc-profile-cols { display:grid; grid-template-columns:1fr 380px; gap:32px; }
.gc-profile-left { display:flex; flex-direction:column; gap:24px; }
.gc-profile-block { background:#fff; border-radius:var(--gc-radius); padding:24px; box-shadow:var(--gc-shadow); }
.gc-profile-block h3 { font-size:1.1rem; font-weight:900; margin-bottom:14px; }
.gc-profile-right { display:flex; flex-direction:column; gap:16px; }
.gc-offers-heading { font-size:1.2rem; font-weight:900; margin-bottom:4px; }
.gc-offer-card-profile { background:#fff; border-radius:var(--gc-radius); box-shadow:var(--gc-shadow); overflow:hidden; }
.gc-offer-card-inner { padding:20px; }
.gc-offer-type-badge { display:inline-block; font-size:0.75rem; font-weight:800; padding:4px 10px; border-radius:20px; margin-bottom:10px; }
.gc-offer-type-free     { background:#e8f8f5; color:#00B894; }
.gc-offer-type-discount,.gc-offer-type-special { background:#fff3e0; color:#e17055; }
.gc-offer-card-inner h4 { font-size:1rem; font-weight:900; margin-bottom:6px; }
.gc-offer-card-inner p  { font-size:0.875rem; color:#555; line-height:1.6; }
.gc-id-note { font-size:0.8rem; font-weight:700; color:#E17055; margin:8px 0; }
.gc-no-id   { color:var(--gc-green); }
.gc-claimed-badge { background:#e8f8f5; color:var(--gc-green); font-weight:800; padding:10px 16px; border-radius:10px; text-align:center; margin-top:12px; }
.gc-review-item { background:#f9f9f9; border-radius:10px; padding:14px; margin-bottom:12px; }
.gc-review-top  { display:flex; align-items:center; gap:10px; margin-bottom:6px; flex-wrap:wrap; }

/* ── Dashboard ────────────────────────────────────── */
.gc-dashboard-wrap { max-width:1100px; margin:0 auto; }
.gc-dash-header { background:linear-gradient(135deg,#6C5CE7,#a29bfe); padding:28px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.gc-dash-header h2 { color:#fff; margin:0; }
.gc-dash-header p  { color:rgba(255,255,255,0.85); margin:4px 0 0; font-weight:600; }
.gc-bday-alert { color:#FFD93D !important; font-weight:800 !important; }
.gc-stats-row { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:0; }
.gc-stat-card { padding:20px 24px; text-align:center; background:#fff; border-top:4px solid var(--stat-color); }
.gc-stat-num   { font-size:2rem; font-weight:900; color:var(--stat-color); }
.gc-stat-label { font-size:0.8rem; font-weight:700; color:#666; text-transform:uppercase; letter-spacing:0.5px; }

/* ── Tabs ─────────────────────────────────────────── */
.gc-tabs { padding:24px; }
.gc-tab-nav { display:flex; gap:8px; border-bottom:2px solid #f0f0f0; margin-bottom:20px; flex-wrap:wrap; }
.gc-tab-btn { padding:10px 20px; background:none; border:none; font-family:var(--gc-font); font-weight:800; font-size:0.9rem; color:#888; cursor:pointer; border-bottom:3px solid transparent; margin-bottom:-2px; transition:all 0.2s; border-radius:8px 8px 0 0; }
.gc-tab-btn:hover { color:var(--gc-purple); background:#f8f5ff; }
.gc-tab-btn.active { color:var(--gc-purple); border-bottom-color:var(--gc-purple); background:#f8f5ff; }
.gc-tab-count { background:var(--gc-purple); color:#fff; border-radius:20px; padding:1px 7px; font-size:0.72rem; margin-left:6px; }
.gc-tab-pane { display:none; }
.gc-tab-pane.active { display:block; }

/* ── Claims ───────────────────────────────────────── */
.gc-claims-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.gc-claim-card { background:#fff; border-radius:var(--gc-radius); box-shadow:var(--gc-shadow); padding:20px; border-top:4px solid var(--biz-color,#6C5CE7); }
.gc-claim-card-top { display:flex; align-items:flex-start; gap:14px; margin-bottom:12px; }
.gc-claim-avatar { width:44px; height:44px; border-radius:12px; background:linear-gradient(135deg,var(--biz-color,#6C5CE7),rgba(0,0,0,0.1)); display:flex; align-items:center; justify-content:center; font-size:1.5rem; flex-shrink:0; }
.gc-claim-card h4 { font-size:0.95rem; font-weight:900; margin-bottom:2px; }
.gc-claim-card h4 a { color:var(--gc-dark); text-decoration:none; }
.gc-claim-card h4 a:hover { color:var(--gc-purple); }
.gc-claim-offer-title { font-size:0.8rem; color:#888; font-weight:600; }
.gc-claim-date { font-size:0.78rem; color:#aaa; margin-top:8px; }
.gc-redeemed-badge { background:#e8f8f5; color:var(--gc-green); font-weight:800; padding:8px 12px; border-radius:8px; font-size:0.85rem; margin:10px 0; }
.gc-birthday-redeem-note { background:linear-gradient(135deg,#FFD93D,#FF8E53); color:#fff; font-weight:800; padding:10px 14px; border-radius:10px; font-size:0.85rem; margin-top:10px; text-align:center; }
.gc-redeem-later-note { background:#f3f0ff; color:var(--gc-purple); font-weight:700; padding:8px 12px; border-radius:8px; font-size:0.82rem; margin-top:8px; }
.gc-review-submitted { background:#fffbf0; border-left:3px solid var(--gc-yellow); padding:10px; border-radius:6px; font-size:0.85rem; margin-top:8px; }

/* ── Offer Management ─────────────────────────────── */
.gc-offers-list { display:flex; flex-direction:column; gap:12px; }
.gc-offer-manage-card { background:#fff; border-radius:var(--gc-radius); box-shadow:var(--gc-shadow); padding:16px 20px; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.gc-offer-inactive { opacity:0.6; }
.gc-offer-manage-left { display:flex; align-items:center; gap:14px; }
.gc-offer-manage-icon { width:44px; height:44px; border-radius:12px; background:linear-gradient(135deg,#6C5CE7,#a29bfe); display:flex; align-items:center; justify-content:center; font-size:1.6rem; flex-shrink:0; }
.gc-offer-manage-left h4 { font-size:0.95rem; font-weight:900; margin-bottom:4px; }
.gc-offer-manage-left p  { font-size:0.8rem; color:#888; margin:2px 0; }
.gc-offer-manage-actions { display:flex; gap:8px; }
.gc-status-dot { font-size:0.78rem; font-weight:700; margin-right:8px; }
.gc-dot-green { color:var(--gc-green); }
.gc-dot-grey  { color:#aaa; }

/* ── Claims Table ─────────────────────────────────── */
.gc-claims-table-wrap { overflow-x:auto; }
.gc-claims-table { width:100%; border-collapse:collapse; font-size:0.875rem; }
.gc-claims-table th { background:#f8f5ff; color:var(--gc-purple); font-weight:800; padding:10px 14px; text-align:left; }
.gc-claims-table td { padding:10px 14px; border-bottom:1px solid #f0f0f0; }
.gc-claims-table tr:hover td { background:#fafafa; }
.gc-bday-row td { background:#fffbf0 !important; }

/* ── Badges ───────────────────────────────────────── */
.gc-badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:0.75rem; font-weight:800; }
.gc-badge-success,.gc-badge-active { background:#e8f8f5; color:var(--gc-green); }
.gc-badge-pending  { background:#fff3e0; color:#e17055; }
.gc-badge-secondary{ background:#f0f0f0; color:#888; }
.gc-avg-rating { font-size:1.2rem; margin-bottom:20px; font-weight:800; }

/* ── Forms ────────────────────────────────────────── */
.gc-form-group { margin-bottom:16px; }
.gc-form-group label { display:block; font-weight:800; margin-bottom:6px; font-size:0.88rem; color:#555; }
.gc-form-control { width:100%; padding:11px 14px; border:2px solid #e8e8e8; border-radius:var(--gc-radius-sm); font-family:var(--gc-font); font-size:0.95rem; color:var(--gc-dark); transition:border-color 0.2s; outline:none; background:#fff; }
.gc-form-control:focus { border-color:var(--gc-purple); }
.gc-form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }

/* ── Auth ─────────────────────────────────────────── */
.gc-auth-wrap { max-width:520px; margin:40px auto; padding:0 16px; }
.gc-auth-box  { background:#fff; border-radius:24px; box-shadow:0 20px 60px rgba(0,0,0,0.1); overflow:hidden; }
.gc-auth-logo { background:linear-gradient(135deg,#6C5CE7,#a29bfe); padding:28px 32px; text-align:center; }
.gc-auth-logo h2 { color:#fff; font-size:1.6rem; margin:0 0 4px; }
.gc-auth-logo p  { color:rgba(255,255,255,0.85); font-weight:600; margin:0; }
.gc-auth-tabs { display:flex; border-bottom:2px solid #f0f0f0; }
.gc-auth-tab { flex:1; padding:14px; background:none; border:none; font-family:var(--gc-font); font-weight:800; font-size:0.95rem; cursor:pointer; color:#888; transition:all 0.2s; }
.gc-auth-tab.active { color:var(--gc-purple); border-bottom:3px solid var(--gc-purple); margin-bottom:-2px; }
.gc-auth-panel { padding:24px 28px; }
.gc-reg-type-picker { display:flex; gap:10px; margin-bottom:20px; }
.gc-reg-type-btn { flex:1; padding:12px; border:2px solid #e0e0e0; border-radius:var(--gc-radius); background:#fff; font-family:var(--gc-font); font-weight:700; cursor:pointer; transition:all 0.2s; font-size:0.9rem; }
.gc-reg-type-btn.active { border-color:var(--gc-purple); background:#f3f0ff; color:var(--gc-purple); }
.gc-reg-type-btn .icon { font-size:1.2rem; display:block; margin-bottom:4px; }
.gc-subs-checkbox-list { display:flex; flex-wrap:wrap; gap:8px; }
.gc-subs-checkbox-list label { display:flex; align-items:center; gap:6px; background:#f3f0ff; border:2px solid transparent; border-radius:20px; padding:6px 12px; cursor:pointer; font-weight:700; font-size:0.82rem; transition:all 0.2s; }
.gc-subs-checkbox-list input[type=checkbox] { width:14px; height:14px; accent-color:var(--gc-purple); }

/* ── Alert ────────────────────────────────────────── */
.gc-alert { padding:12px 16px; border-radius:var(--gc-radius-sm); font-weight:700; margin-bottom:16px; }
.gc-alert-error   { background:#fff0f0; color:#e74c3c; border-left:4px solid #e74c3c; }
.gc-alert-success { background:#e8f8f5; color:#00B894; border-left:4px solid #00B894; }

/* ── Modal ────────────────────────────────────────── */
.gc-modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:99999; align-items:center; justify-content:center; padding:20px; backdrop-filter:blur(4px); }
.gc-modal-overlay.open { display:flex; }
.gc-modal { background:#fff; border-radius:24px; box-shadow:0 30px 80px rgba(0,0,0,0.2); width:100%; max-width:500px; max-height:90vh; overflow-y:auto; animation:gc-modal-in 0.3s cubic-bezier(0.34,1.56,0.64,1); }
@keyframes gc-modal-in { from{opacity:0;transform:scale(0.85) translateY(20px)} to{opacity:1;transform:scale(1) translateY(0)} }
.gc-modal-header { padding:20px 24px; border-bottom:2px solid #F0F0F0; display:flex; align-items:center; justify-content:space-between; }
.gc-modal-header h3 { font-size:1.1rem; font-weight:900; color:var(--gc-dark); }
.gc-modal-close { background:#EEE; border:none; border-radius:50%; width:32px; height:32px; cursor:pointer; font-size:1rem; display:flex; align-items:center; justify-content:center; }
.gc-modal-body { padding:20px 24px; }
.gc-modal-footer { padding:14px 24px; border-top:2px solid #F0F0F0; display:flex; gap:10px; justify-content:flex-end; }

/* ── Star Picker ──────────────────────────────────── */
.gc-star-picker { display:flex; gap:4px; }
.gc-star-btn { background:none; border:none; font-size:1.5rem; cursor:pointer; padding:0; opacity:0.3; transition:opacity 0.15s,transform 0.15s; }
.gc-star-btn.lit { opacity:1; }
.gc-star-btn:hover { transform:scale(1.2); }

/* ── Empty ────────────────────────────────────────── */
.gc-empty { text-align:center; padding:40px 20px; }
.gc-empty-icon { font-size:3rem; margin-bottom:12px; }
.gc-empty h3 { font-size:1.1rem; font-weight:900; margin-bottom:8px; }
.gc-empty p  { color:#888; font-size:0.9rem; }

/* ── Card ─────────────────────────────────────────── */
.gc-card { background:#fff; border-radius:var(--gc-radius); box-shadow:var(--gc-shadow); }
.gc-card-body { padding:20px; }

/* ── Responsive ───────────────────────────────────── */
@media (max-width:1024px) {
  .gc-profile-cols { grid-template-columns:1fr; }
  .gc-category-grid { grid-template-columns:repeat(4,1fr); }
}
@media (max-width:768px) {
  .gc-category-grid { grid-template-columns:repeat(3,1fr); }
  .gc-stats-row { grid-template-columns:repeat(2,1fr); }
  .gc-form-row { grid-template-columns:1fr; }
  .gc-hiw-arrow { display:none; }
  .gc-filter-btn { font-size:0.75rem; padding:5px 10px; }
}
@media (max-width:480px) {
  .gc-category-grid { grid-template-columns:repeat(2,1fr); }
  .gc-biz-grid,.gc-biz-grid-full { grid-template-columns:1fr !important; }
  .gc-auth-panel { padding:16px; }
  .gc-filter-btn { font-size:0.72rem; padding:4px 9px; }
}

/* ── Fix: explicit dark text on all white/light surfaces ── */
.gc-profile-block,
.gc-profile-block h3,
.gc-profile-block p,
.gc-profile-block small,
.gc-offer-card-profile,
.gc-offer-card-inner h4,
.gc-offer-card-inner p,
.gc-biz-card,
.gc-biz-card-body h3,
.gc-biz-card-body p,
.gc-claim-card,
.gc-claim-card h4,
.gc-claim-card p,
.gc-card,
.gc-card-body,
.gc-tabs,
.gc-tab-pane,
.gc-review-item,
.gc-review-item p,
.gc-offers-list,
.gc-offer-manage-card,
.gc-offer-manage-left h4,
.gc-offer-manage-left p,
.gc-auth-box,
.gc-auth-panel,
.gc-auth-panel p,
.gc-form-group label,
.gc-tv-submit-card,
.gc-tv-submit-card h2,
.gc-tv-submit-card p,
.gc-tv-hiw-step p,
.gc-profile-info p { color: var(--gc-dark, #2D3436) !important; }

/* headings in white cards */
.gc-profile-block h3,
.gc-offer-card-inner h4,
.gc-biz-card-body h3,
.gc-claim-card h4,
.gc-offer-manage-left h4,
.gc-auth-logo ~ * h3 { color: var(--gc-dark, #2D3436) !important; }

/* muted text stays muted but still readable */
.gc-biz-location,
.gc-biz-desc,
.gc-claim-offer-title,
.gc-claim-date,
.gc-offer-manage-left p { color: #555 !important; }

/* section titles on white/light bg */
.gc-section .gc-section-title,
.gc-section .gc-section-sub { color: var(--gc-dark, #2D3436) !important; }
.gc-section .gc-section-sub { color: #555 !important; }

/* ── gc_home_hero: compact hero variant ───────────── */
.gc-hero-compact { padding: 22px 24px; }
.gc-hero-compact h1 { font-size: clamp(1.1rem, 3vw, 1.5rem); margin-bottom: 14px; }

/* ── Gift Requests ────────────────────────────────── */
.gc-requests-list { display:flex; flex-direction:column; gap:16px; }
.gc-request-card { background:#fff; border-radius:var(--gc-radius); box-shadow:var(--gc-shadow); padding:20px; border-left:4px solid var(--req-color,var(--gc-purple)); }
.gc-request-card-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-bottom:14px; }
.gc-request-cat-icon { font-size:2rem; width:44px; height:44px; border-radius:12px; background:linear-gradient(135deg,var(--req-color,var(--gc-purple)),rgba(0,0,0,0.1)); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.gc-request-card h4 { font-size:0.95rem; font-weight:900; margin-bottom:3px; color:var(--gc-dark); }
.gc-request-msg { font-size:0.82rem; color:#888; font-style:italic; margin:2px 0 0; }
.gc-request-waiting { background:#f8f5ff; border-radius:10px; padding:12px 16px; font-size:0.85rem; font-weight:700; color:var(--gc-purple); display:flex; align-items:center; gap:8px; }
.gc-request-offers { border-top:1px solid #f0f0f0; padding-top:14px; }
.gc-request-offer-item { background:#f9f9f9; border-radius:10px; padding:14px; margin-bottom:10px; }
.gc-request-offer-item.gc-offer-accepted { background:#e8f8f5; border:1px solid #00B894; }
.gc-request-offer-top { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:6px; font-size:0.88rem; }
.gc-request-offer-msg { font-size:0.85rem; color:#555; margin:4px 0; line-height:1.5; }
.gc-coupon-box { background:linear-gradient(135deg,#6C5CE7,#a29bfe); color:#fff; font-weight:900; padding:8px 14px; border-radius:8px; display:inline-block; font-size:0.9rem; margin-top:8px; letter-spacing:1px; }

/* ── Toast notification ───────────────────────────── */
.gc-toast { position:fixed; bottom:24px; right:24px; z-index:99999; padding:14px 20px; border-radius:12px; font-weight:700; font-size:0.9rem; box-shadow:0 8px 30px rgba(0,0,0,0.15); max-width:360px; }

/* ── Request Prompt Bar ───────────────────────────── */
.gc-request-prompt {
  background: linear-gradient(135deg, var(--req-color, var(--gc-purple)), color-mix(in srgb, var(--req-color, var(--gc-purple)) 70%, #000));
  border-radius: var(--gc-radius);
  padding: 16px 20px;
  margin-bottom: 24px;
  color: #fff;
}
.gc-request-prompt-inner {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.gc-request-prompt-inner p { margin: 0; color: #fff; }
.gc-request-prompt-inner > div { flex: 1; min-width: 180px; }

/* ── Public Requests Page ─────────────────────────── */
.gc-pub-req-cta { background:linear-gradient(135deg,#6C5CE7,#a29bfe); border-radius:var(--gc-radius); padding:18px 22px; margin-bottom:8px; }
.gc-pub-req-cta-inner { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.gc-pub-req-cta-inner strong { color:#fff; font-size:1rem; display:block; margin-bottom:4px; }
.gc-pub-req-cta-inner p { color:rgba(255,255,255,0.85); font-size:0.85rem; margin:0; font-weight:600; }
.gc-pub-req-count { background:rgba(255,255,255,0.25); color:#fff; font-size:0.7rem; font-weight:800; padding:1px 7px; border-radius:20px; margin-left:5px; }
.gc-filter-btn.active .gc-pub-req-count { background:rgba(255,255,255,0.3); }

.gc-pub-req-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; margin-top:24px; }
.gc-pub-req-card { background:#fff; border-radius:var(--gc-radius); box-shadow:var(--gc-shadow); padding:20px; border-top:4px solid var(--req-color,#6C5CE7); display:flex; flex-direction:column; gap:12px; }
.gc-pub-req-card-top { display:flex; align-items:flex-start; gap:12px; }
.gc-pub-req-icon { font-size:1.8rem; width:44px; height:44px; border-radius:12px; background:linear-gradient(135deg,var(--req-color,#6C5CE7),rgba(0,0,0,0.1)); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.gc-pub-req-date { font-size:0.78rem; color:#aaa; font-weight:600; margin:4px 0 0; }
.gc-pub-req-message { background:#f8f5ff; border-left:3px solid var(--req-color,#6C5CE7); border-radius:0 8px 8px 0; padding:10px 14px; display:flex; gap:8px; align-items:flex-start; }
.gc-pub-req-message p { font-size:0.875rem; color:#555; font-style:italic; margin:0; line-height:1.5; }
.gc-pub-req-footer { display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap; margin-top:auto; padding-top:8px; border-top:1px solid #f0f0f0; }

@media (max-width:600px) { .gc-pub-req-grid { grid-template-columns:1fr; } }

/* ── Businesses Pagination ────────────────────────── */
.gc-pagination { display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-top:32px; }
.gc-page-btn { padding:8px 16px; border-radius:50px; background:#fff; border:2px solid #e0e0e0; color:#555; font-weight:700; font-size:0.85rem; text-decoration:none; transition:all 0.2s; }
.gc-page-btn:hover,.gc-page-btn.active { background:var(--gc-purple); border-color:var(--gc-purple); color:#fff; }

/* ── No Email Notice ──────────────────────────────── */
.gc-no-email-notice {
  background: #e8f8f0;
  border: 2px solid #00B894;
  border-radius: 10px;
  padding: 12px 16px;
  text-align: center;
  font-weight: 800;
  font-size: 0.85rem;
  color: #00875a;
  margin-bottom: 18px;
  letter-spacing: 0.3px;
}

/* ── List My Business Page ────────────────────────── */
.gc-lmb-notice { background:#f3f0ff; border:2px solid var(--gc-purple); border-radius:12px; padding:14px 18px; margin-bottom:24px; font-weight:700; color:var(--gc-purple); font-size:0.9rem; }
.gc-lmb-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:16px; }
.gc-lmb-card { background:#fff; border-radius:var(--gc-radius); box-shadow:var(--gc-shadow); padding:20px; text-decoration:none; color:var(--gc-dark); display:flex; flex-direction:column; gap:10px; transition:all 0.3s; border-top:4px solid var(--cat-color,var(--gc-purple)); cursor:pointer; }
.gc-lmb-card:hover { transform:translateY(-5px); box-shadow:var(--gc-shadow-lg); color:var(--gc-dark); }
.gc-lmb-card-icon { font-size:2.5rem; text-align:center; }
.gc-lmb-card h3 { font-size:1rem; font-weight:900; margin:0; color:var(--gc-dark); text-align:center; }
.gc-lmb-subs { display:flex; flex-wrap:wrap; gap:4px; justify-content:center; }
.gc-lmb-subs span { font-size:0.72rem; background:#f3f0ff; color:var(--gc-purple); padding:2px 8px; border-radius:20px; font-weight:700; }
.gc-lmb-card-footer { display:flex; align-items:center; justify-content:space-between; font-size:0.78rem; font-weight:700; color:#888; border-top:1px solid #f0f0f0; padding-top:10px; margin-top:auto; }
.gc-lmb-join-btn { background:var(--cat-color,var(--gc-purple)); color:#fff; padding:4px 12px; border-radius:20px; font-size:0.75rem; }
/* ── Category Checkbox Scroll ─────────────────────── */
.gc-cat-checkbox-scroll {
  display:grid; grid-template-columns:1fr 1fr;
  gap:8px; max-height:240px; overflow-y:auto;
  border:2px solid #e8e8e8; border-radius:12px; padding:10px;
  scrollbar-width:thin; scrollbar-color:var(--gc-purple) #f0f0f0;
}
.gc-cat-checkbox-scroll::-webkit-scrollbar { width:5px; }
.gc-cat-checkbox-scroll::-webkit-scrollbar-thumb { background:var(--gc-purple); border-radius:4px; }
.gc-cat-checkbox-item {
  display:flex; align-items:center; gap:8px;
  padding:8px 10px; border-radius:10px; cursor:pointer;
  transition:all 0.2s; border:2px solid #e8e8e8;
  background:#fff; user-select:none;
}
.gc-cat-checkbox-item:hover { border-color:var(--gc-purple); background:#f3f0ff; }
.gc-cat-checkbox-item.gc-cat-checked { background:#f3f0ff; border-color:var(--gc-purple); }
.gc-cat-checkbox-item input[type=checkbox] { display:none; }
.gc-cat-cb-icon {
  width:32px; height:32px; border-radius:8px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:1.1rem;
}
.gc-cat-checkbox-item span:last-child { font-size:0.82rem; font-weight:700; color:var(--gc-dark); }
.gc-cat-checkbox-item.gc-cat-checked span:last-child { color:var(--gc-purple); }
/* Checkmark on selected */
.gc-cat-checkbox-item.gc-cat-checked::after {
  content:'✓'; margin-left:auto; color:var(--gc-purple);
  font-weight:900; font-size:0.9rem; flex-shrink:0;
}
@media (max-width:480px) { .gc-lmb-grid { grid-template-columns:repeat(2,1fr); } }

/* ── Business card website button ─────────────────── */
.gc-biz-website-btn {
  display:inline-block; color:var(--gc-purple); font-weight:700;
  font-size:0.82rem; cursor:pointer; text-decoration:underline;
  text-underline-offset:2px;
}
.gc-biz-website-btn:hover { color:var(--gc-primary); }
