/* =============================================================================
   FILE: public/css/directory.css
   Lattia Nonprofit Directory Styles
============================================================================= */

/* ─── Variables ─── */
:root {
    --dir-green: #00A63E;
    --dir-green-dark: #008F35;
    --dir-green-light: #e8f9ef;
    --dir-green-bg: #f0fdf4;
    --dir-gray-50: #F9FAFB;
    --dir-gray-100: #F3F4F6;
    --dir-gray-200: #E5E7EB;
    --dir-gray-300: #D1D5DB;
    --dir-gray-400: #9CA3AF;
    --dir-gray-500: #6B7280;
    --dir-gray-600: #4B5563;
    --dir-gray-700: #374151;
    --dir-gray-900: #111827;
    --dir-radius: 14px;
    --dir-shadow: 0 1px 3px rgba(0,0,0,0.06);
    --dir-shadow-lg: 0 4px 16px rgba(0,0,0,0.06);
    --dir-body-bg: linear-gradient(to bottom right, #f9fffc, white, rgba(209, 244, 224, 0.6));
}

/* ─── Directory Page Layout ─── */
.dir-page { background: var(--dir-body-bg); min-height: 100vh; }
.dir-container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

/* ─── Hero Banner ─── */
.dir-hero {
    background: linear-gradient(13deg, #0ed588 0%, #00bb7b 40%, #2bcb78 70%, #00ab60 100%);
    padding: 48px 0 56px;
    border-bottom: 1px solid rgba(0,0,0,0.1);
}
.dir-hero-badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 5px 14px; border-radius: 20px; font-size: 0.75rem; font-weight: 600;
    background: rgba(255,255,255,0.12); color: rgba(255,255,255,0.85);
    margin-bottom: 16px; backdrop-filter: blur(4px);
    border: 1px solid rgba(255,255,255,0.1);
}
.dir-hero-badge i { font-size: 13px; }
.dir-hero h1 { font-size: 2.2rem; font-weight: 800; color: white; margin-bottom: 10px; letter-spacing: -0.02em; }
.dir-hero p { font-size: 1.05rem; color: rgba(255,255,255,0.75); max-width: 540px; margin: 0; line-height: 1.55; }

/* ─── Search & Filters Card ─── */
.dir-search-card {
    background: white; border: 1px solid var(--dir-gray-200); border-radius: var(--dir-radius);
    padding: 28px 28px 24px; margin-top: -28px; margin-bottom: 32px;
    box-shadow: var(--dir-shadow-lg); position: relative; z-index: 2;
}
.dir-search { position: relative; margin-bottom: 20px; }
.dir-search input {
    width: 100%; padding: 14px 16px 14px 44px; border: 1px solid var(--dir-gray-200);
    border-radius: 10px; font-size: 15px; background: var(--dir-gray-50); transition: all 0.2s;
}
.dir-search input:focus { outline: none; border-color: var(--dir-green); box-shadow: 0 0 0 3px rgba(0,166,62,0.1); background: white; }
.dir-search .search-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--dir-gray-400); font-size: 15px; }
.dir-filter-row { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.dir-filter-group { display: flex; flex-direction: column; gap: 6px; }
.dir-filter-group label { font-size: 0.78rem; font-weight: 600; color: var(--dir-gray-500); display: flex; align-items: center; gap: 5px; }
.dir-filter-group label i { font-size: 13px; }
.dir-filter-select {
    padding: 10px 36px 10px 14px; border: 1px solid var(--dir-gray-200); border-radius: 10px;
    font-size: 14px; background: white; appearance: none; color: var(--dir-gray-700); cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 12px center;
    transition: border-color 0.2s;
}
.dir-filter-select:focus { outline: none; border-color: var(--dir-green); }

/* ─── Results Count ─── */
.dir-results-count { font-size: 0.92rem; color: var(--dir-gray-600); margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--dir-gray-200); }
.dir-results-count strong { color: var(--dir-gray-900); }

/* ─── Directory Card Grid ─── */
.dir-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 40px; }
.dir-card {
    background: white; border: 1px solid var(--dir-gray-200); border-radius: var(--dir-radius);
    padding: 24px; transition: all 0.2s ease; display: flex; flex-direction: column;
    text-decoration: none; color: inherit; box-shadow: var(--dir-shadow);
}
.dir-card:hover { border-color: var(--dir-green); box-shadow: var(--dir-shadow-lg); transform: translateY(-2px); }
.dir-card-header { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.dir-card-logo {
    width: 52px; height: 52px; border-radius: 12px;
    background: white; border: 1px solid var(--dir-gray-200);
    display: flex; align-items: center; justify-content: center;
    font-size: 16px; font-weight: 700; color: var(--dir-green); flex-shrink: 0; overflow: hidden;
}
.dir-card-logo img { width: 100%; height: 100%; object-fit: cover; border-radius: 11px; }
.dir-card-header-info { min-width: 0; }
.dir-card-title { font-size: 1.02rem; font-weight: 700; color: var(--dir-gray-900); margin: 0; line-height: 1.3; }
.dir-card-verified { display: inline-flex; align-items: center; gap: 4px; font-size: 0.75rem; font-weight: 600; color: var(--dir-green); margin-top: 2px; }
.dir-card-verified i { font-size: 12px; }
.dir-card-body { font-size: 0.9rem; color: var(--dir-gray-600); line-height: 1.55; flex: 1; margin-bottom: 14px; }
.dir-card-location { font-size: 0.82rem; color: var(--dir-gray-500); margin-bottom: 12px; display: flex; align-items: center; gap: 4px; }
.dir-card-location i { font-size: 12px; color: var(--dir-gray-400); }
.dir-card-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.dir-tag { display: inline-block; padding: 3px 10px; background: var(--dir-green-light); color: var(--dir-green-dark); border-radius: 20px; font-size: 0.75rem; font-weight: 600; text-decoration: none; }
.dir-card-ai { padding-top: 14px; border-top: 1px solid var(--dir-gray-100); font-size: 0.8rem; color: var(--dir-gray-500); display: flex; align-items: center; gap: 6px; }
.dir-card-ai i { color: var(--dir-green); font-size: 14px; }
.dir-card-ai strong { color: var(--dir-gray-700); }

/* ─── Pagination ─── */
.dir-pagination { margin-bottom: 20px; }

/* ─── Empty State ─── */
.dir-empty { text-align: center; padding: 80px 24px; }
.dir-empty-icon {
    width: 64px; height: 64px; border-radius: 50%; margin: 0 auto 16px;
    background: var(--dir-green-light); display: flex; align-items: center; justify-content: center;
}
.dir-empty-icon i { font-size: 24px; color: var(--dir-green); }
.dir-empty h3 { font-size: 1.1rem; font-weight: 700; color: var(--dir-gray-900); margin-bottom: 4px; }
.dir-empty p { font-size: 0.9rem; color: var(--dir-gray-500); }

/* ─── CTA Banner ─── */
.dir-cta-banner {
    background: linear-gradient(13deg, #0ed588 0%, #00bb7b 40%, #2bcb78 70%, #00ab60 100%);
    border-radius: var(--dir-radius); padding: 40px 32px; text-align: center;
    color: white; margin: 48px 0 60px;
    border: 1px solid rgba(255,255,255,0.06);
    box-shadow: 0 4px 24px rgba(0,61,26,0.2);
}
.dir-cta-banner h3 { font-size: 1.3rem; font-weight: 700; margin-bottom: 8px; }
.dir-cta-banner p { opacity: 0.75; margin-bottom: 20px; max-width: 500px; margin-left: auto; margin-right: auto; }
.dir-cta-banner .dir-btn { background: white; color: #003d1a; font-weight: 700; }
.dir-cta-banner .dir-btn:hover { background: rgba(255,255,255,0.9); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,0.2); }

/* =============================================================================
   PUBLIC PROFILE PAGE
============================================================================= */
.profile-page { min-height: 100vh; }

/* ─── White Header ─── */
.profile-header {
    background: white;
    padding: 48px 0 40px;
    border-bottom: 1px solid var(--dir-gray-200);
}
.profile-header-inner {
    max-width: 900px; margin: 0 auto; padding: 0 24px;
    display: flex; align-items: flex-start; justify-content: space-between; gap: 24px;
    position: relative;
}
.profile-header-left {
    display: flex; align-items: flex-start; gap: 24px; flex: 1; min-width: 0;
}
.profile-logo {
    width: 80px; height: 80px; border-radius: var(--dir-radius);
    background: white; border: 2px solid var(--dir-gray-200);
    flex-shrink: 0; display: flex; align-items: center; justify-content: center;
    font-size: 28px; font-weight: 800; color: var(--dir-green); overflow: hidden;
}
.profile-logo img { width: 100%; height: 100%; object-fit: cover; border-radius: 12px; }
.profile-header-info h1 { font-size: 1.75rem; font-weight: 800; color: var(--dir-gray-900); margin: 0 0 4px; }
.profile-subtitle { font-size: 1rem; color: var(--dir-gray-600); line-height: 1.5; margin-bottom: 10px; }
.profile-header-meta { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-bottom: 10px; }
.profile-meta-item { display: inline-flex; align-items: center; gap: 5px; font-size: 0.82rem; color: var(--dir-gray-500); }
.profile-meta-item i { font-size: 13px; }
.profile-meta-item.verified { color: var(--dir-green); font-weight: 600; }
.profile-category-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.profile-cat-tag {
    display: inline-block; padding: 4px 12px; border-radius: 20px;
    font-size: 0.75rem; font-weight: 600; border: 1px solid;
}
.profile-cat-tag:nth-child(6n+1) { background: #eff6ff; color: #2563eb; border-color: #bfdbfe; }
.profile-cat-tag:nth-child(6n+2) { background: #fef3c7; color: #d97706; border-color: #fde68a; }
.profile-cat-tag:nth-child(6n+3) { background: #fce7f3; color: #db2777; border-color: #fbcfe8; }
.profile-cat-tag:nth-child(6n+4) { background: #e0e7ff; color: #4f46e5; border-color: #c7d2fe; }
.profile-cat-tag:nth-child(6n+5) { background: #d1fae5; color: #059669; border-color: #a7f3d0; }
.profile-cat-tag:nth-child(6n+6) { background: #fee2e2; color: #dc2626; border-color: #fecaca; }

/* ─── Body Gradient (matches admin dashboard) ─── */
.profile-body {
    background: var(--dir-body-bg);
    padding: 32px 0 0;
}
.profile-body-inner { max-width: 900px; margin: 0 auto; padding: 0 24px; }

/* ─── White Section Cards ─── */
.profile-card {
    background: white; border: 1px solid var(--dir-gray-200); border-radius: var(--dir-radius);
    padding: 28px; margin-bottom: 20px; box-shadow: var(--dir-shadow);
}
.profile-card-header {
    display: flex; align-items: center; gap: 10px;
    font-size: 1.05rem; font-weight: 700; color: var(--dir-gray-900);
    margin-bottom: 20px; padding-bottom: 14px; border-bottom: 1px solid var(--dir-gray-100);
}
.profile-card-header i { color: var(--dir-green); font-size: 18px; }

/* Q&A */
.profile-qa { margin-bottom: 20px; }
.profile-qa:last-child { margin-bottom: 0; }
.profile-qa h3 { font-size: 0.9rem; font-weight: 700; color: var(--dir-gray-700); margin-bottom: 4px; }
.profile-qa p { font-size: 0.92rem; color: var(--dir-gray-600); line-height: 1.6; margin: 0; }

/* Story */
.profile-story { color: var(--dir-gray-600); line-height: 1.7; font-size: 0.92rem; }

/* Impact Stats */
.profile-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 14px; }
.profile-stat {
    background: transparent; border: none;
    border-radius: 10px; padding: 18px 14px; text-align: center;
}
.profile-stat i { font-size: 22px; color: var(--dir-green); margin-bottom: 6px; display: block; }
.profile-stat-value { font-size: 1.4rem; font-weight: 800; color: var(--dir-gray-900); line-height: 1.2; }
.profile-stat-label { font-size: 0.78rem; color: var(--dir-gray-500); margin-top: 2px; }

/* Donation Grid */
.profile-donation-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
.profile-donate-btn {
    display: flex; align-items: center; gap: 14px; padding: 14px;
    border: 1px solid var(--dir-gray-200); border-radius: 10px;
    text-decoration: none; color: inherit; transition: all 0.2s;
}
.profile-donate-btn:hover { border-color: var(--dir-green); box-shadow: 0 2px 8px rgba(0,166,62,0.1); }
.profile-donate-btn img { width: 52px; height: 52px; border-radius: 8px; object-fit: cover; }
.profile-donate-btn-placeholder {
    width: 52px; height: 52px; border-radius: 8px; background: var(--dir-green-light);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.profile-donate-btn-placeholder i { color: var(--dir-green); font-size: 20px; }
.profile-donate-btn-name { font-weight: 600; font-size: 0.9rem; color: var(--dir-gray-900); margin-bottom: 2px; }
.profile-donate-btn-cta { font-size: 0.8rem; color: var(--dir-green); font-weight: 600; }

/* Contact */
.profile-contact-list { display: flex; flex-direction: column; gap: 14px; }
.profile-contact-row { display: flex; align-items: center; gap: 12px; font-size: 0.92rem; color: var(--dir-gray-700); }
.profile-contact-icon {
    width: 34px; height: 34px; border-radius: 8px; background: var(--dir-green-light);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.profile-contact-icon i { color: var(--dir-green); font-size: 15px; }
.profile-contact-row a { color: var(--dir-green); text-decoration: none; }
.profile-contact-row a:hover { text-decoration: underline; }

/* Videos */
.profile-videos { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 14px; }
.profile-video-wrap { position: relative; padding-bottom: 56.25%; border-radius: 10px; overflow: hidden; background: var(--dir-gray-100); }
.profile-video-wrap iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; }

/* Gallery */
.profile-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; }
.profile-gallery img { width: 100%; height: 140px; object-fit: cover; border-radius: 8px; }

/* ─── AI Discovery Card ─── */
.profile-ai-card {
    flex-shrink: 0; width: 240px; border-radius: var(--dir-radius);
    overflow: hidden; position: relative;
    border: 1px solid var(--dir-gray-200); box-shadow: var(--dir-shadow);
}
.profile-ai-card::before {
    content: '';
    position: absolute; inset: 0; border-radius: var(--dir-radius); padding: 1.5px;
    background: linear-gradient(135deg, #00A63E, #06b6d4, #8b5cf6, #00A63E);
    background-size: 300% 300%;
    animation: borderShift 4s ease infinite;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
}
@keyframes borderShift {
    0%, 100% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
}
.profile-ai-card-inner {
    background: white; border-radius: 13px; padding: 18px; position: relative; z-index: 1;
}
.profile-ai-card .ai-top { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.profile-ai-card .ai-icon {
    width: 36px; height: 36px; border-radius: 8px;
    background: linear-gradient(135deg, #00A63E, #06b6d4);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.profile-ai-card .ai-icon i { color: white; font-size: 17px; }
.profile-ai-card .ai-label {
    font-size: 0.7rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.06em; color: var(--dir-gray-500);
}
.profile-ai-card .ai-sublabel { font-size: 0.72rem; color: var(--dir-gray-400); }
.profile-ai-card .ai-live {
    margin-left: auto; display: flex; align-items: center; gap: 4px;
    font-size: 0.65rem; font-weight: 600; color: var(--dir-green);
}
.profile-ai-card .ai-live-dot {
    width: 5px; height: 5px; border-radius: 50%;
    background: var(--dir-green); animation: aiPulse 2s infinite;
}
@keyframes aiPulse {
    0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(0,166,62,0.4); }
    50% { opacity: 0.7; box-shadow: 0 0 0 4px rgba(0,166,62,0); }
}
.profile-ai-card .ai-number {
    font-size: 2rem; font-weight: 800; line-height: 1; margin-bottom: 2px;
    background: linear-gradient(135deg, #111827, #00A63E);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.profile-ai-card .ai-desc { font-size: 0.78rem; color: var(--dir-gray-500); margin-bottom: 12px; }
.profile-ai-card .ai-cta {
    display: flex; align-items: center; gap: 4px;
    font-size: 0.76rem; font-weight: 600; color: var(--dir-green);
    text-decoration: none; transition: gap 0.2s;
}
.profile-ai-card .ai-cta:hover { gap: 8px; }

/* ─── AI SEO Markup Card ─── */
.seo-card {
    background: linear-gradient(145deg, #0f172a, #1e293b);
    border-radius: 16px; overflow: hidden; margin-bottom: 20px;
    border: 1px solid rgba(255,255,255,0.06);
    box-shadow: 0 8px 32px rgba(0,0,0,0.3);
}
.seo-card-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 18px 24px; border-bottom: 1px solid rgba(255,255,255,0.06);
    cursor: pointer; user-select: none;
}
.seo-card-title {
    display: flex; align-items: center; gap: 10px;
    font-size: 0.95rem; font-weight: 700; color: #f1f5f9;
}
.seo-card-title i { color: #06b6d4; font-size: 18px; }
.seo-toggle { color: #64748b; font-size: 16px; transition: transform 0.3s; }
.seo-tabs { display: flex; border-bottom: 1px solid rgba(255,255,255,0.06); padding: 0 24px; }
.seo-tab {
    padding: 11px 18px; font-size: 0.8rem; font-weight: 600;
    color: #64748b; cursor: pointer; border: none; background: none;
    border-bottom: 2px solid transparent; transition: all 0.2s;
}
.seo-tab:hover { color: #94a3b8; }
.seo-tab.active { color: #06b6d4; border-bottom-color: #06b6d4; }
.seo-tab-content { display: none; }
.seo-tab-content.active { display: block; }
.seo-desc { padding: 14px 24px 0; font-size: 0.82rem; color: #94a3b8; line-height: 1.5; }
.seo-code-wrap { padding: 14px 24px 18px; overflow-x: auto; }
.seo-code {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.75rem; line-height: 1.7; color: #e2e8f0;
    white-space: pre; tab-size: 2; margin: 0;
}
.seo-code .key { color: #06b6d4; }
.seo-code .str { color: #34d399; }
.seo-code .punct { color: #64748b; }
.seo-code .bracket { color: #f59e0b; }
.seo-meta-list { padding: 14px 24px 18px; }
.seo-meta-item {
    display: flex; gap: 12px; padding: 9px 0;
    border-bottom: 1px solid rgba(255,255,255,0.04);
}
.seo-meta-item:last-child { border-bottom: none; }
.seo-meta-tag {
    font-family: monospace; font-size: 0.72rem; color: #06b6d4;
    background: rgba(6,182,212,0.1); padding: 2px 8px; border-radius: 4px;
    white-space: nowrap; height: fit-content;
}
.seo-meta-val { font-size: 0.8rem; color: #94a3b8; line-height: 1.4; }
.seo-semantic-list { padding: 14px 24px 18px; }
.seo-semantic-item { display: flex; align-items: flex-start; gap: 12px; padding: 8px 0; }
.seo-semantic-icon {
    width: 28px; height: 28px; border-radius: 6px;
    background: rgba(52,211,153,0.1); display: flex; align-items: center;
    justify-content: center; flex-shrink: 0;
}
.seo-semantic-icon i { color: #34d399; font-size: 13px; }
.seo-semantic-label { font-size: 0.78rem; font-weight: 600; color: #e2e8f0; }
.seo-semantic-desc { font-size: 0.72rem; color: #64748b; }
.seo-card-footer {
    padding: 12px 24px; background: rgba(0,0,0,0.15);
    border-top: 1px solid rgba(255,255,255,0.04);
    display: flex; align-items: center; gap: 8px;
}
.seo-card-footer i { color: #f59e0b; font-size: 13px; flex-shrink: 0; }
.seo-card-footer span { font-size: 0.72rem; color: #64748b; line-height: 1.4; }
.seo-card-footer strong { color: #94a3b8; }

/* =============================================================================
   SIGNUP FLOW
============================================================================= */
.signup-page { background: var(--dir-body-bg); min-height: 100vh; padding: 40px 24px; }
.signup-container { max-width: 640px; margin: 0 auto; }
.signup-progress { display: flex; justify-content: center; gap: 8px; margin-bottom: 40px; }
.signup-step-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--dir-gray-200); transition: all 0.3s; }
.signup-step-dot.active { background: var(--dir-green); width: 32px; border-radius: 5px; }
.signup-step-dot.completed { background: var(--dir-green); }
.signup-card { background: white; border-radius: 16px; box-shadow: var(--dir-shadow-lg); padding: 40px; border: 1px solid var(--dir-gray-100); }
.signup-card h2 { font-size: 1.5rem; font-weight: 800; color: var(--dir-gray-900); margin-bottom: 6px; }
.signup-card .step-subtitle { color: var(--dir-gray-500); font-size: 0.92rem; margin-bottom: 28px; }

/* Form styles */
.dir-form-group { margin-bottom: 20px; }
.dir-form-group label { display: block; font-size: 0.85rem; font-weight: 600; color: var(--dir-gray-700); margin-bottom: 6px; }
.dir-form-group .helper-text { font-size: 0.78rem; color: var(--dir-gray-400); margin-top: 4px; }
.dir-form-group input[type="text"], .dir-form-group input[type="email"], .dir-form-group input[type="password"],
.dir-form-group input[type="tel"], .dir-form-group input[type="url"], .dir-form-group textarea, .dir-form-group select {
    width: 100%; padding: 10px 14px; border: 1px solid var(--dir-gray-200); border-radius: 8px; font-size: 0.92rem; transition: border-color 0.2s; background: white;
}
.dir-form-group input:focus, .dir-form-group textarea:focus, .dir-form-group select:focus { outline: none; border-color: var(--dir-green); box-shadow: 0 0 0 3px rgba(0,166,62,0.1); }
.dir-form-group textarea { resize: vertical; min-height: 80px; }
.dir-form-error { color: #dc3545; font-size: 0.8rem; margin-top: 4px; }

/* Slug field */
.slug-field-wrap { display: flex; align-items: center; border: 1px solid var(--dir-gray-200); border-radius: 8px; overflow: hidden; transition: border-color 0.2s; }
.slug-field-wrap:focus-within { border-color: var(--dir-green); box-shadow: 0 0 0 3px rgba(0,166,62,0.1); }
.slug-prefix { padding: 10px 12px; background: var(--dir-gray-50); color: var(--dir-gray-500); font-size: 0.85rem; white-space: nowrap; border-right: 1px solid var(--dir-gray-200); }
.slug-field-wrap input { border: none !important; box-shadow: none !important; flex: 1; }

/* EIN verification */
.ein-status { display: inline-flex; align-items: center; gap: 6px; font-size: 0.82rem; font-weight: 600; margin-top: 6px; padding: 4px 12px; border-radius: 20px; }
.ein-status.verified { background: var(--dir-green-light); color: var(--dir-green-dark); }
.ein-status.not-found { background: #fef3cd; color: #856404; }
.ein-status.checking { color: var(--dir-gray-500); }

/* Category pills */
.category-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.category-pill { display: inline-flex; align-items: center; gap: 4px; padding: 6px 14px; border: 1px solid var(--dir-gray-200); border-radius: 20px; font-size: 0.82rem; font-weight: 500; color: var(--dir-gray-600); cursor: pointer; transition: all 0.15s; background: white; }
.category-pill:hover { border-color: var(--dir-green); color: var(--dir-green); }
.category-pill input { display: none; }
.category-pill.selected { background: var(--dir-green-light); border-color: var(--dir-green); color: var(--dir-green-dark); font-weight: 600; }

/* Buttons */
.dir-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 28px; border-radius: 8px; font-size: 0.92rem; font-weight: 600; border: none; cursor: pointer; transition: all 0.2s; text-decoration: none; }
.dir-btn-primary { background: var(--dir-green); color: white; }
.dir-btn-primary:hover { background: var(--dir-green-dark); }
.dir-btn-outline { background: white; color: var(--dir-gray-700); border: 1px solid var(--dir-gray-200); }
.dir-btn-outline:hover { border-color: var(--dir-gray-400); }
.dir-btn-lg { padding: 14px 36px; font-size: 1rem; }
.signup-actions { display: flex; justify-content: space-between; align-items: center; margin-top: 32px; }

/* ─── Responsive ─── */
@media (max-width: 1024px) { .dir-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 768px) {
    .profile-header-inner { flex-direction: column; align-items: center; text-align: center; }
    .profile-header-left { flex-direction: column; align-items: center; }
    .profile-ai-card { width: 100%; }
    .profile-header-meta { justify-content: center; }
    .profile-category-tags { justify-content: center; }
    .dir-hero { padding: 36px 0 44px; }
    .dir-hero h1 { font-size: 1.8rem; }
    .dir-search-card { margin-top: -20px; padding: 20px; }
    .dir-filter-row { grid-template-columns: 1fr; gap: 12px; }
    .dir-grid { grid-template-columns: 1fr; }
    .signup-card { padding: 28px 20px; }
    .signup-actions { flex-direction: column; gap: 12px; }
    .signup-actions .dir-btn { width: 100%; }
    .profile-stats-grid { grid-template-columns: repeat(2, 1fr); }
    .seo-tabs { overflow-x: auto; }
    .seo-tab { white-space: nowrap; }
}