:root {
    --primary-green: #7CB915;
    --primary-green-rgb: 124, 185, 21;
    --secondary-bg: #F0F4EF;
    --dark-text: #1a1a1a;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

.brand-green {
    background-color: var(--primary-green);
}

.brand-green-text {
    color: var(--primary-green);
}

.brand-bg {
    background-color: var(--secondary-bg);
}

.drag-drop-zone {
    border: 2px dashed #d1d5db;
    transition: all 0.3s ease;
}

.drag-drop-zone.drag-over {
    border-color: var(--primary-green);
    background-color: #f0f9ff;
}

.logo-preview {
    max-height: 120px;
    object-fit: contain;
}

.product-image-preview {
    max-height: 100px;
    max-width: 100px;
    object-fit: cover;
}

.btn-primary {
    background-color: var(--primary-green);
    transition: all 0.3s ease;
}

.btn-primary:hover {
    filter: brightness(0.9);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(var(--primary-green-rgb), 0.3);
}

.btn-secondary {
    background-color: #6b7280;
    transition: all 0.3s ease;
}

.btn-secondary:hover {
    background-color: #4b5563;
    transform: translateY(-1px);
}

.line-item-row {
    transition: all 0.2s ease;
}

.line-item-row:hover {
    background-color: #f9fafb;
}

@media print {
    .no-print {
        display: none !important;
    }

    body, html, #mainLayout, main, #workspaceContent, #formSection, #workspaceContainer {
        display: block !important;
        position: static !important;
        width: 100% !important;
        height: auto !important;
        min-height: 0 !important;
        overflow: visible !important;
        margin: 0 !important;
        padding: 0 !important;
        background: white !important;
    }

    aside {
        display: none !important;
    }

    #previewPanel {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        background: transparent !important;
        border: none !important;
        float: none !important;
        display: block !important;
        position: static !important;
        height: auto !important;
        overflow: visible !important;
    }

    #previewDocumentContainer {
        background: transparent !important;
        border: none !important;
        padding: 0 !important;
        margin: 0 !important;
        overflow: visible !important;
        height: auto !important;
    }

    #zoomWrapper {
        transform: none !important;
        box-shadow: none !important;
        border: none !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    #estimatePreview {
        box-shadow: none !important;
        padding: 0 !important;
        margin: 0 !important;
        width: 100% !important;
    }

    /* Keep category headers with their content */
    .category-header {
        page-break-after: avoid;
        break-after: avoid;
    }

    /* Prevent table rows from breaking */
    tr {
        page-break-inside: avoid;
        break-inside: avoid;
    }
}

.input-field {
    border: 1px solid #e5e7eb;
    transition: all 0.2s ease;
}

.input-field:focus {
    outline: none;
    border-color: var(--primary-green);
    box-shadow: 0 0 0 3px rgba(var(--primary-green-rgb), 0.1);
}

.delete-btn {
    opacity: 0;
    transition: opacity 0.2s ease;
}

.line-item-row:hover .delete-btn {
    opacity: 1;
}

.paste-area:focus {
    outline: 2px solid var(--primary-green);
    outline-offset: 2px;
    background-color: #f0f9ff;
}

/* --- PREMIUM REDESIGN UI STYLES --- */

/* Horizontal-Only Tables */
.horizontal-table {
    border-collapse: collapse;
    width: 100%;
}
.horizontal-table th, 
.horizontal-table td {
    border-top: none;
    border-left: none;
    border-right: none;
    border-bottom: 1px solid #e5e7eb;
    padding: 12px 16px;
    text-align: left;
}
.horizontal-table th {
    border-bottom: 2px solid #e5e7eb;
    font-weight: 600;
}

/* Sidebar Styling */
.sidebar-link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    border-radius: 8px;
    color: #4b5563; /* slate-600 */
    font-weight: 500;
    transition: all 0.2s ease;
}
.sidebar-link:hover {
    color: #0f172a; /* slate-900 */
    background-color: #f1f5f9; /* slate-100 */
}
.sidebar-link.active {
    color: #ffffff !important;
    background-color: var(--primary-green) !important;
}

/* Accordion Animations */
.accordion-content {
    max-height: 2000px;
    overflow: hidden;
    transition: max-height 0.3s ease-out, padding 0.3s ease-out, opacity 0.2s;
    opacity: 1;
}
.accordion-content:not(.collapsed) {
    max-height: none;
    overflow: visible;
}
.accordion-content.collapsed {
    max-height: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    opacity: 0;
    overflow: hidden !important;
}

/* Spreadsheet Grid Inputs */
.grid-input {
    border: 1px solid transparent;
    background: transparent;
    padding: 6px 10px;
    border-radius: 6px;
    width: 100%;
    transition: all 0.15s ease;
}
.grid-input:focus, 
.grid-input:hover {
    border-color: #d1d5db;
    background: #ffffff;
    outline: none;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

/* Zoom scale origin */
.zoom-container {
    transform-origin: top center;
    transition: transform 0.2s ease;
}

/* Custom categories color badges */
.badge-category {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
}
.badge-design { background-color: #f3e8ff; color: #7e22ce; }
.badge-development { background-color: #dbeafe; color: #1d4ed8; }
.badge-hosting { background-color: #dcfce7; color: #15803d; }
.badge-maintenance { background-color: #fef9c3; color: #a16207; }
.badge-other { background-color: #f3f4f6; color: #374151; }

/* Dynamic Brand Color Helper Utilities */
.bg-brand-green {
    background-color: var(--primary-green) !important;
}
.bg-brand-green-10 {
    background-color: rgba(var(--primary-green-rgb), 0.1) !important;
}
.bg-brand-green-20 {
    background-color: rgba(var(--primary-green-rgb), 0.2) !important;
}
.text-brand-green {
    color: var(--primary-green) !important;
}
.border-brand-green {
    border-color: var(--primary-green) !important;
}
.hover\:text-brand-green:hover {
    color: var(--primary-green) !important;
}
.hover\:bg-brand-green:hover {
    background-color: var(--primary-green) !important;
}
.hover\:bg-brand-green-dark:hover {
    filter: brightness(0.9);
    background-color: var(--primary-green) !important;
}
.hover\:border-brand-green:hover {
    border-color: var(--primary-green) !important;
}
.focus\:border-brand-green:focus {
    border-color: var(--primary-green) !important;
}
.focus\:ring-brand-green:focus {
    border-color: var(--primary-green) !important;
    box-shadow: 0 0 0 3px rgba(var(--primary-green-rgb), 0.2) !important;
}
.peer:checked ~ .peer-checked\:bg-brand-green {
    background-color: var(--primary-green) !important;
}

/* Workspace Divider Resizer */
#workspaceDivider {
    position: relative;
    user-select: none;
    transition: background-color 0.15s ease, width 0.15s ease;
}
#workspaceDivider:hover {
    background-color: rgba(var(--primary-green-rgb), 0.2) !important;
}
#workspaceDivider.active {
    background-color: rgba(var(--primary-green-rgb), 0.4) !important;
}
#workspaceDivider .divider-handle {
    width: 2px;
    height: 32px;
    background-color: #cbd5e1; /* slate-300 */
    border-radius: 9999px;
    transition: background-color 0.15s ease;
}
#workspaceDivider:hover .divider-handle,
#workspaceDivider.active .divider-handle {
    background-color: var(--primary-green) !important;
}
