/* components.css - All UI components (OPTIMIZED - compact) */

/* Buttons */
.btn { display: inline-flex; align-items: center; gap: 5px; padding: 7px 14px; border-radius: var(--radius); border: none; font-size: 13px; font-weight: 500; transition: all 0.2s; }
.btn-primary { background: var(--green); color: var(--white); }
.btn-primary:hover { background: #2E7D32; text-decoration: none; }
.btn-saffron { background: var(--saffron); color: var(--white); }
.btn-saffron:hover { background: #E65100; }
.btn-outline { background: none; border: 1px solid var(--green); color: var(--green); }
.btn-outline:hover { background: var(--green-bg); }
.btn-sm { padding: 4px 10px; font-size: 12px; }
.btn-danger { background: var(--red); color: var(--white); }
.btn-block { width: 100%; justify-content: center; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Cards */
.card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; }
.card-header { padding: 10px 14px; border-bottom: 1px solid var(--border); font-weight: 600; color: var(--green); display: flex; align-items: center; justify-content: space-between; font-size: 14px; }
.card-body { padding: 12px 14px; }
.card-footer { padding: 8px 14px; border-top: 1px solid var(--border); background: var(--gray-light); }

/* Forms */
.form-group { margin-bottom: 10px; }
.form-group label { display: block; font-size: 12px; font-weight: 500; margin-bottom: 3px; color: var(--black); }
.form-group label .required { color: var(--red); }
.form-control { width: 100%; padding: 7px 10px; border: 1px solid var(--border); border-radius: var(--radius); font-size: 13px; transition: border 0.2s; background: var(--white); }
.form-control:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 2px rgba(27,94,32,0.1); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media(max-width:600px) { .form-row { grid-template-columns: 1fr; } }
.form-error { font-size: 11px; color: var(--red); margin-top: 2px; }

/* Tables */
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: 12px; }
th { background: var(--green); color: var(--white); padding: 7px 10px; text-align: left; font-weight: 500; white-space: nowrap; }
td { padding: 6px 10px; border-bottom: 1px solid var(--border); }
tr:hover { background: var(--green-bg); }

/* Badges */
.badge { display: inline-block; padding: 2px 8px; border-radius: 20px; font-size: 11px; font-weight: 600; }
.badge-green { background: var(--green-bg); color: var(--green); }
.badge-saffron { background: #FFF3E0; color: var(--saffron); }
.badge-red { background: #FFEBEE; color: var(--red); }
.badge-gray { background: var(--gray-light); color: var(--gray); }

/* Modal */
.modal-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.5); z-index: 200; align-items: center; justify-content: center; }
.modal-overlay.open { display: flex; }
.modal { background: var(--white); border-radius: var(--radius); width: 90%; max-width: 500px; max-height: 90vh; overflow-y: auto; }
.modal-header { padding: 12px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; font-weight: 600; color: var(--green); }
.modal-header .close { background: none; border: none; font-size: 20px; color: var(--gray); cursor: pointer; }
.modal-body { padding: 14px 16px; }
.modal-footer { padding: 10px 16px; border-top: 1px solid var(--border); display: flex; gap: 8px; justify-content: flex-end; }

/* Alert / Toast */
.alert { padding: 8px 12px; border-radius: var(--radius); margin-bottom: 10px; font-size: 12px; }
.alert-success { background: #E8F5E9; color: var(--green); border: 1px solid #A5D6A7; }
.alert-error { background: #FFEBEE; color: var(--red); border: 1px solid #EF9A9A; }
.alert-info { background: #E3F2FD; color: #1565C0; border: 1px solid #90CAF9; }

/* Loading & Empty */
.spinner { display: inline-block; width: 20px; height: 20px; border: 3px solid var(--border); border-top-color: var(--green); border-radius: 50%; animation: spin 0.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.loading { text-align: center; padding: 20px; color: var(--gray); }
.empty-state { text-align: center; padding: 30px 15px; color: var(--gray); }
.empty-state .icon { font-size: 36px; margin-bottom: 6px; }

/* Pagination */
.pagination { display: flex; gap: 4px; justify-content: center; margin-top: 12px; }
.pagination button { padding: 4px 10px; border: 1px solid var(--border); border-radius: var(--radius); background: var(--white); font-size: 12px; }
.pagination button.active { background: var(--green); color: var(--white); border-color: var(--green); }
.pagination button:disabled { opacity: 0.4; }

/* Tabs */
.tabs { display: flex; border-bottom: 2px solid var(--border); margin-bottom: 12px; overflow-x: auto; }
.tab { padding: 8px 14px; cursor: pointer; font-size: 12px; font-weight: 500; color: var(--gray); border-bottom: 2px solid transparent; margin-bottom: -2px; white-space: nowrap; }
.tab.active { color: var(--green); border-bottom-color: var(--green); }
.tab:hover { color: var(--green); }

/* Search box */
.search-box { position: relative; }
.search-box input { padding-left: 32px; }
.search-box .search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--gray); }

/* Verified badge */
.verified { color: var(--green); font-size: 14px; }

/* WhatsApp share */
.btn-whatsapp { background: #25D366; color: var(--white); }
.btn-whatsapp:hover { background: #1DA851; }

/* Grid layouts */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
@media(max-width:900px) { .grid-3, .grid-4 { grid-template-columns: 1fr 1fr; } }
@media(max-width:600px) { .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; } }

/* Stat cards (homepage) */
.stat-card { background: var(--white); border-radius: var(--radius); padding: 12px 8px; text-align: center; box-shadow: var(--shadow); border-top: 3px solid var(--green); }
.stat-card .number { font-size: 22px; font-weight: 700; color: var(--green); }
.stat-card .label { font-size: 11px; color: var(--gray); margin-top: 2px; }

/* Sadhu card */
.sadhu-card { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 10px 12px; display: flex; gap: 10px; transition: transform 0.2s; cursor: pointer; }
.sadhu-card:hover { transform: translateY(-1px); box-shadow: 0 3px 10px rgba(0,0,0,0.12); }
.sadhu-card img { width: 55px; height: 55px; border-radius: 50%; object-fit: cover; border: 2px solid var(--green-bg); }
.sadhu-card .info h3 { font-size: 14px; color: var(--green); margin-bottom: 1px; }
.sadhu-card .info p { font-size: 11px; color: var(--gray); margin: 0; }
.sadhu-card .location { font-size: 11px; color: var(--saffron); margin-top: 2px; }

/* Profile header */
.profile-header { display: flex; gap: 16px; padding: 16px; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); margin-bottom: 12px; }
.profile-header img { width: 90px; height: 90px; border-radius: 50%; object-fit: cover; border: 2px solid var(--green); }
.profile-header .details h1 { font-size: 20px; color: var(--green); margin: 0 0 2px; }
.profile-header .details p { font-size: 12px; color: var(--gray); margin: 0; }
@media(max-width:600px) { .profile-header { flex-direction: column; align-items: center; text-align: center; } }

/* Sidebar + Content layout */
.layout-sidebar { display: grid; grid-template-columns: 220px 1fr; gap: 12px; }
.sidebar { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); padding: 0; }
.sidebar-menu a { display: block; padding: 8px 14px; border-bottom: 1px solid var(--border); color: var(--black); font-size: 12px; }
.sidebar-menu a:hover, .sidebar-menu a.active { background: var(--green-bg); color: var(--green); text-decoration: none; }
@media(max-width:768px) { .layout-sidebar { grid-template-columns: 1fr; } .sidebar { display: none; } }
