/* Custom styles for Portfolio Tracker */

/* Dark theme overrides */
.dark body,
body.dark {
    background-color: #0b1120;
    color: #e2e8f0;
}

.dark .bg-white {
    background-color: #0f172a;
}

.dark .bg-gray-50 {
    background-color: #111827;
}

.dark .bg-gray-100 {
    background-color: #1f2937;
}

.dark .text-gray-900 {
    color: #f8fafc;
}

.dark .text-gray-700 {
    color: #e2e8f0;
}

.dark .text-gray-500 {
    color: #cbd5f5;
}

.dark .text-gray-400 {
    color: #b6c2d6;
}

.dark .text-gray-600 {
    color: #d1d9e6;
}

.dark .border-gray-200 {
    border-color: #1f2937;
}

.dark .border-gray-300 {
    border-color: #334155;
}

.dark .shadow {
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.35);
}

.dark input,
.dark select,
.dark textarea {
    background-color: #0b1220;
    color: #e2e8f0;
    border-color: #334155;
}

.dark .hover\\:bg-gray-50:hover,
.dark .hover\\:bg-gray-100:hover {
    background-color: #0b1220;
}

.dark .hover\\:text-indigo-900:hover {
    color: #c7d2fe;
}

.dark #movers-grid .bg-gray-50 {
    background-color: #0b1220;
}

.dark #movers-grid .text-gray-600,
.dark #movers-grid .text-gray-400 {
    color: #e2e8f0;
}

.dark #movers-grid .bg-green-50 {
    background-color: rgba(16, 185, 129, 0.18);
}

.dark #movers-grid .bg-green-100 {
    background-color: rgba(16, 185, 129, 0.28);
}

.dark #movers-grid .bg-green-200 {
    background-color: rgba(16, 185, 129, 0.38);
}

.dark #movers-grid .bg-green-300 {
    background-color: rgba(16, 185, 129, 0.5);
}

.dark #movers-grid .bg-red-50 {
    background-color: rgba(239, 68, 68, 0.18);
}

.dark #movers-grid .bg-red-100 {
    background-color: rgba(239, 68, 68, 0.28);
}

.dark #movers-grid .bg-red-200 {
    background-color: rgba(239, 68, 68, 0.38);
}

.dark #movers-grid .bg-red-300 {
    background-color: rgba(239, 68, 68, 0.5);
}

.dark #movers-grid .text-green-700,
.dark #movers-grid .text-green-800,
.dark #movers-grid .text-green-900 {
    color: #d1fae5;
}

.dark #movers-grid .text-red-700,
.dark #movers-grid .text-red-800,
.dark #movers-grid .text-red-900 {
    color: #fee2e2;
}

.dark #movers-grid .bg-white\\/60 {
    background-color: rgba(255, 255, 255, 0.12);
}

.link-soft {
    color: #2563eb;
}

.link-soft:hover {
    color: #1d4ed8;
    text-decoration: underline;
}

.dark .link-soft {
    color: #93c5fd;
}

.dark .link-soft:hover {
    color: #bfdbfe;
}

.chart-icon-layer {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.chart-icon-layer img {
    position: absolute;
    border-radius: 9999px;
    background-color: rgba(15, 23, 42, 0.8);
    border: 1px solid rgba(255, 255, 255, 0.2);
    object-fit: cover;
}

/* HTMX loading indicator */
.htmx-indicator {
    display: none;
}

.htmx-request .htmx-indicator {
    display: inline-block;
}

.htmx-request.htmx-indicator {
    display: inline-block;
}

/* Asset type badges */
.badge-crypto {
    background-color: #f7931a;
    color: white;
}

.badge-stablecoin {
    background-color: #10b981;
    color: white;
}

.badge-stock {
    background-color: #22c55e;
    color: white;
}

.badge-forex {
    background-color: #3b82f6;
    color: white;
}

.badge-fiat {
    background-color: #3b82f6;
    color: white;
}

.badge-tcg {
    background-color: #a855f7;
    color: white;
}

.badge-defi {
    background-color: #ec4899;
    color: white;
}

.badge-nft {
    background-color: #111827;
    color: white;
}

/* Higher-level portfolio classes */
.badge-stables {
    background-color: #10b981;
    color: white;
}

.badge-crypto-defi {
    background-color: #f97316;
    color: white;
}

.badge-memes {
    background-color: #eab308;
    color: #111827;
}

/* Asset icon fallback */
.asset-icon {
    width: 32px;
    height: 32px;
    border-radius: 9999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.asset-icon svg {
    width: 18px;
    height: 18px;
    color: #ffffff;
}

.asset-icon-crypto {
    background-color: #f7931a;
}

.asset-icon-stablecoin {
    background-color: #10b981;
}

.asset-icon-stock {
    background-color: #22c55e;
}

.asset-icon-forex {
    background-color: #3b82f6;
}

.asset-icon-fiat {
    background-color: #3b82f6;
}

.asset-icon-tcg {
    background-color: #a855f7;
}

.asset-icon-defi {
    background-color: #ec4899;
}

.asset-icon-nft {
    background-color: #111827;
}

/* Blur numeric inputs when privacy mode is enabled to avoid shoulder-surfing. */
.privacy-blur {
    filter: blur(6px);
    transition: filter 0.15s ease;
}

.privacy-blur:focus,
.privacy-blur:hover {
    filter: blur(0);
}

/* Card hover effects */
.asset-card {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.asset-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1);
}

/* Price change indicators */
.price-up {
    color: #22c55e;
}

.price-down {
    color: #ef4444;
}

/* Form styling */
.form-input:focus {
    outline: none;
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

/* Loading spinner */
.spinner {
    border: 2px solid #f3f3f3;
    border-top: 2px solid #6366f1;
    border-radius: 50%;
    width: 16px;
    height: 16px;
    animation: spin 1s linear infinite;
    display: inline-block;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Empty state styling */
.empty-state {
    text-align: center;
    padding: 3rem;
    color: #6b7280;
}

/* Responsive table */
@media (max-width: 640px) {
    .responsive-table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }
}

/* Tag chips */
.tag-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 500;
    border-radius: 9999px;
    background-color: #e0e7ff;
    color: #3730a3;
    white-space: nowrap;
}

.tag-chip-small {
    padding: 0.125rem 0.375rem;
    font-size: 0.625rem;
}

.tag-chip-filter {
    background-color: #dbeafe;
    color: #1e40af;
}

.tag-chip button {
    padding: 0;
    background: none;
    border: none;
    cursor: pointer;
    font-size: inherit;
    line-height: 1;
}

/* Tag chip color variants - cycle through colors based on tag name hash */
.tag-chip[data-tag] {
    /* Default indigo */
}

/* Time range buttons */
.range-btn {
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 500;
    border-radius: 0.375rem;
    border: 1px solid #d1d5db;
    background-color: white;
    color: #374151;
    cursor: pointer;
    transition: all 0.15s ease;
}

.range-btn:hover {
    background-color: #f3f4f6;
    border-color: #9ca3af;
}

.range-btn.active {
    background-color: #4f46e5;
    border-color: #4f46e5;
    color: white;
}

.range-btn.active:hover {
    background-color: #4338ca;
}

/* Chart mode toggle buttons */
.chart-mode-btn {
    padding: 0.25rem 0.5rem;
    font-size: 0.65rem;
    font-weight: 500;
    border-radius: 0.25rem;
    border: 1px solid #e5e7eb;
    background-color: #f9fafb;
    color: #6b7280;
    cursor: pointer;
    transition: all 0.15s ease;
}

.chart-mode-btn:hover {
    background-color: #f3f4f6;
    border-color: #d1d5db;
}

.chart-mode-btn.active {
    background-color: #dbeafe;
    border-color: #93c5fd;
    color: #1d4ed8;
}
