/* ============================================
   Junk Journal Creator Pro - Frontend Styles
   Victorian Craft Aesthetic
   ============================================ */

/* --- Typography & Color Palette --- */
:root {
    --jjcp-primary: #5a4a3a;
    --jjcp-secondary: #8b7355;
    --jjcp-accent: #d4c4b0;
    --jjcp-bg-cream: #f9f7f4;
    --jjcp-text: #2c2c2c;
    --jjcp-border: #d4c4b0;
    --jjcp-success: #6a8b5f;
    --jjcp-warning: #c4914b;
    --jjcp-error: #a64b4b;
}

.jjcp-wrap {
    font-family: 'Garamond', 'Georgia', serif;
    color: var(--jjcp-text);
    background: #fff;
    margin: 20px 20px 20px 0;
}

.jjcp-page-title {
    font-family: 'Garamond', 'Georgia', serif;
    font-size: 2.2em;
    font-weight: normal;
    letter-spacing: 0.03em;
    color: var(--jjcp-primary);
    margin-bottom: 1.5em;
    padding-bottom: 0.5em;
    border-bottom: 2px solid var(--jjcp-secondary);
}

/* --- Layout Structure --- */
.jjcp-layout {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 2em;
    max-width: 1800px;
}

.jjcp-column {
    min-width: 0; /* Prevent grid overflow */
}

.jjcp-column-left {
    /* Left column for inputs */
}

.jjcp-column-center {
    /* Center column for preview */
}

.jjcp-column-right {
    /* Right column for results */
}

/* --- Sections --- */
.jjcp-section {
    background: var(--jjcp-bg-cream);
    border: 1px solid var(--jjcp-border);
    border-radius: 4px;
    padding: 1.5em;
    margin-bottom: 1.5em;
}

.jjcp-section-title {
    font-size: 1.4em;
    font-weight: 600;
    color: var(--jjcp-primary);
    margin: 0 0 0.5em 0;
    padding-bottom: 0.4em;
    border-bottom: 1px solid var(--jjcp-border);
}

.jjcp-section-desc {
    font-size: 0.95em;
    font-style: italic;
    color: var(--jjcp-secondary);
    margin: 0 0 1.2em 0;
    line-height: 1.5;
}

/* --- Tier Badges --- */
.jjcp-tier-badge {
    display: inline-block;
    font-size: 0.7em;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 0.3em 0.7em;
    border-radius: 3px;
    margin-right: 0.5em;
    vertical-align: middle;
}

.jjcp-tier-required {
    background: #6a8b5f;
    color: white;
}

.jjcp-tier-optional {
    background: #c4914b;
    color: white;
}

.jjcp-tier-advanced {
    background: #8b7355;
    color: white;
}

/* --- Tier Specific Sections --- */
.jjcp-tier-1 {
    background: #f0f8e8;
    border-color: #6a8b5f;
}

.jjcp-tier-2 {
    background: var(--jjcp-bg-cream);
}

.jjcp-tier-3 {
    background: #f5f0e8;
}

/* --- Form Fields --- */
.jjcp-field-group {
    margin-bottom: 1.2em;
}

.jjcp-label {
    display: block;
    font-weight: 600;
    color: var(--jjcp-primary);
    margin-bottom: 0.4em;
    font-size: 0.95em;
}

.jjcp-required {
    color: #a64b4b;
    font-weight: bold;
}

.jjcp-optional {
    font-size: 0.85em;
    font-style: italic;
    color: var(--jjcp-secondary);
    font-weight: normal;
}

.jjcp-help {
    display: inline-block;
    width: 16px;
    height: 16px;
    line-height: 16px;
    text-align: center;
    background: var(--jjcp-secondary);
    color: white;
    border-radius: 50%;
    font-size: 0.8em;
    cursor: help;
    margin-left: 0.3em;
}

.jjcp-input,
.jjcp-input-sm {
    width: 100%;
    padding: 0.6em;
    border: 1px solid var(--jjcp-border);
    border-radius: 3px;
    font-family: 'Garamond', 'Georgia', serif;
    font-size: 1em;
    background: white;
    color: var(--jjcp-text);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.jjcp-input:focus,
.jjcp-input-sm:focus {
    outline: none;
    border-color: var(--jjcp-secondary);
    box-shadow: 0 0 0 3px rgba(139, 115, 85, 0.1);
}

.jjcp-input-sm {
    width: 120px;
}

.jjcp-field-hint {
    font-size: 0.85em;
    font-style: italic;
    color: var(--jjcp-secondary);
    margin: 0.4em 0 0 0;
}

/* --- Custom Fields --- */
.jjcp-custom-dimensions,
.jjcp-custom-field {
    margin-top: 0.8em;
    padding: 0.8em;
    background: white;
    border: 1px dashed var(--jjcp-border);
    border-radius: 3px;
}

.jjcp-inline-fields {
    display: flex;
    gap: 1em;
}

.jjcp-inline-field {
    flex: 1;
}

.jjcp-inline-field label {
    display: block;
    font-size: 0.85em;
    font-weight: 600;
    color: var(--jjcp-primary);
    margin-bottom: 0.3em;
}

/* --- Auto-Calculation Notice --- */
.jjcp-auto-calc-notice {
    margin-top: 1.5em;
    padding: 0.8em;
    background: white;
    border-left: 3px solid var(--jjcp-success);
    font-size: 0.9em;
    color: var(--jjcp-secondary);
}

.jjcp-auto-calc-notice .dashicons {
    color: var(--jjcp-success);
    vertical-align: middle;
    margin-right: 0.3em;
}

/* --- Advanced Toggle --- */
.jjcp-toggle-advanced {
    width: 100%;
    padding: 1em;
    background: white;
    border: 1px solid var(--jjcp-border);
    border-radius: 3px;
    font-family: 'Garamond', 'Georgia', serif;
    font-size: 1em;
    font-weight: 600;
    color: var(--jjcp-secondary);
    cursor: pointer;
    text-align: left;
    transition: background-color 0.2s;
}

.jjcp-toggle-advanced:hover {
    background: var(--jjcp-bg-cream);
}

.jjcp-toggle-advanced .dashicons {
    vertical-align: middle;
    margin-right: 0.5em;
}

.jjcp-advanced-content {
    margin-top: 1em;
}

.jjcp-warning {
    color: var(--jjcp-warning);
}

/* --- Validation Panel --- */
.jjcp-validation-panel {
    background: white;
    border: 2px solid var(--jjcp-border);
}

.jjcp-validation-status {
    padding: 1em;
    border-radius: 3px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 0.5em;
}

.jjcp-status-icon::before {
    content: '';
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
}

.jjcp-status-pending {
    background: #f5f5f5;
    color: #666;
}

.jjcp-status-pending .jjcp-status-icon::before {
    background: #999;
}

.jjcp-status-calculating {
    background: #fff3cd;
    color: var(--jjcp-warning);
}

.jjcp-status-calculating .jjcp-status-icon::before {
    background: var(--jjcp-warning);
    animation: pulse 1.5s infinite;
}

.jjcp-status-valid {
    background: #e8f4e5;
    color: var(--jjcp-success);
}

.jjcp-status-valid .jjcp-status-icon::before {
    background: var(--jjcp-success);
}

.jjcp-status-invalid,
.jjcp-status-error {
    background: #f8d7da;
    color: var(--jjcp-error);
}

.jjcp-status-invalid .jjcp-status-icon::before,
.jjcp-status-error .jjcp-status-icon::before {
    background: var(--jjcp-error);
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

.jjcp-validation-messages {
    margin-top: 1em;
}

.jjcp-warnings {
    background: #fff3cd;
    border: 1px solid var(--jjcp-warning);
    border-radius: 3px;
    padding: 0.5em;
}

.jjcp-warning-item {
    padding: 0.5em;
    font-size: 0.9em;
    color: var(--jjcp-warning);
}

.jjcp-warning-item .dashicons {
    vertical-align: middle;
    margin-right: 0.3em;
}

/* --- Results Panel --- */
.jjcp-results-panel {
    background: white;
    border: 2px solid var(--jjcp-border);
    transition: opacity 0.3s;
}

.jjcp-results-grid {
    display: grid;
    gap: 0.8em;
}

.jjcp-result-item {
    padding: 0.8em;
    background: var(--jjcp-bg-cream);
    border-radius: 3px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.jjcp-result-label {
    font-weight: 600;
    color: var(--jjcp-primary);
    font-size: 0.9em;
}

.jjcp-result-value {
    font-weight: 600;
    color: var(--jjcp-text);
    font-family: 'Courier New', monospace;
    font-size: 1em;
}

.jjcp-result-highlight {
    background: #fff3e6;
    border: 1px solid var(--jjcp-warning);
}

.jjcp-result-highlight .jjcp-result-value {
    color: var(--jjcp-warning);
    font-size: 1.1em;
}

/* --- Production Summary --- */
.jjcp-production-summary {
    margin-top: 1.5em;
    padding-top: 1.5em;
    border-top: 2px solid var(--jjcp-border);
}

.jjcp-summary-title {
    font-size: 1.1em;
    font-weight: 600;
    color: var(--jjcp-primary);
    margin: 0 0 0.8em 0;
}

.jjcp-summary-content {
    background: var(--jjcp-bg-cream);
    padding: 1em;
    border-radius: 3px;
    font-size: 0.9em;
    line-height: 1.8;
}

/* --- Preview Canvas --- */
.jjcp-preview-canvas {
    min-height: 400px;
    background: white;
    border: 1px solid var(--jjcp-border);
    border-radius: 3px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2em;
}

.jjcp-preview-placeholder {
    text-align: center;
    color: var(--jjcp-secondary);
}

.jjcp-preview-placeholder .dashicons {
    font-size: 4em;
    width: 1em;
    height: 1em;
    opacity: 0.3;
}

.jjcp-preview-placeholder p {
    font-style: italic;
    margin-top: 1em;
}

.jjcp-preview-svg {
    display: block;
    margin: 0 auto;
}

/* --- Action Buttons --- */
.jjcp-actions {
    display: flex;
    gap: 1em;
    margin-top: 2em;
    padding-top: 1.5em;
    border-top: 1px solid var(--jjcp-border);
}

.jjcp-btn-save {
    background: var(--jjcp-success) !important;
    border-color: var(--jjcp-success) !important;
    color: white !important;
    font-family: 'Garamond', 'Georgia', serif !important;
    font-size: 1em !important;
    padding: 0.8em 1.5em !important;
    height: auto !important;
}

.jjcp-btn-save:hover {
    background: #5a7750 !important;
    border-color: #5a7750 !important;
}

.jjcp-btn-export {
    font-family: 'Garamond', 'Georgia', serif !important;
    font-size: 1em !important;
}

/* --- Journal List --- */
.jjcp-journals-list {
    margin-top: 1.5em;
}

.jjcp-empty-state {
    text-align: center;
    padding: 4em 2em;
    background: var(--jjcp-bg-cream);
    border: 1px solid var(--jjcp-border);
    border-radius: 3px;
}

.jjcp-empty-state .dashicons {
    font-size: 4em;
    width: 1em;
    height: 1em;
    color: var(--jjcp-secondary);
    opacity: 0.5;
}

.jjcp-empty-state p {
    font-size: 1.1em;
    color: var(--jjcp-secondary);
    margin: 1em 0 1.5em 0;
}

/* --- Responsive Design --- */
@media (max-width: 1400px) {
    .jjcp-layout {
        grid-template-columns: 1fr 1fr;
    }
    
    .jjcp-column-right {
        grid-column: 1 / -1;
    }
}

@media (max-width: 960px) {
    .jjcp-layout {
        grid-template-columns: 1fr;
    }
    
    .jjcp-actions {
        flex-direction: column;
    }
}

/* --- Utility Classes --- */
.jjcp-mt-1 { margin-top: 1em; }
.jjcp-mb-1 { margin-bottom: 1em; }
.jjcp-mt-2 { margin-top: 2em; }
.jjcp-mb-2 { margin-bottom: 2em; }


/* --- Frontend Specific Overrides --- */
/* These rules have higher specificity to override theme CSS */

.jjcp-frontend-wrap .jjcp-wrap {
    max-width: 100% !important;
    margin: 20px auto !important;
}

/* Ensure tier colors show properly */
.jjcp-frontend-wrap .jjcp-tier-1,
.jjcp-tier-1 {
    background: #f0f8e8 !important;
    border-color: #6a8b5f !important;
}

.jjcp-frontend-wrap .jjcp-tier-2,
.jjcp-tier-2 {
    background: var(--jjcp-bg-cream) !important;
    background: #f9f7f4 !important;
}

.jjcp-frontend-wrap .jjcp-tier-3,
.jjcp-tier-3 {
    background: #f5f0e8 !important;
}

/* Ensure sections have proper backgrounds */
.jjcp-frontend-wrap .jjcp-section,
.jjcp-section {
    background: var(--jjcp-bg-cream) !important;
    background: #f9f7f4 !important;
    border: 1px solid var(--jjcp-border) !important;
    border: 1px solid #d4c4b0 !important;
}

/* Override tier backgrounds on sections */
.jjcp-frontend-wrap .jjcp-section.jjcp-tier-1 {
    background: #f0f8e8 !important;
}

.jjcp-frontend-wrap .jjcp-section.jjcp-tier-2 {
    background: #f9f7f4 !important;
}

.jjcp-frontend-wrap .jjcp-section.jjcp-tier-3 {
    background: #f5f0e8 !important;
}

/* Fix layout truncation */
.jjcp-frontend-wrap .jjcp-layout {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr !important;
    gap: 2em !important;
    max-width: 100% !important;
    width: 100% !important;
}

.jjcp-frontend-wrap .jjcp-column {
    min-width: 0 !important;
    overflow: visible !important;
}

/* Ensure preview canvas doesn't truncate */
.jjcp-frontend-wrap .jjcp-preview-canvas {
    width: 100% !important;
    overflow: visible !important;
}

.jjcp-frontend-wrap .jjcp-preview-svg {
    max-width: 100% !important;
    height: auto !important;
}

/* Ensure validation and results panels have proper styling */
.jjcp-frontend-wrap .jjcp-validation-panel {
    background: white !important;
    border: 2px solid #d4c4b0 !important;
}

.jjcp-frontend-wrap .jjcp-results-panel {
    background: white !important;
    border: 2px solid #d4c4b0 !important;
}

/* Fix any theme overrides on form inputs */
.jjcp-frontend-wrap select.jjcp-input,
.jjcp-frontend-wrap input.jjcp-input,
.jjcp-frontend-wrap input.jjcp-input-sm {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Responsive fixes */
@media (max-width: 1400px) {
    .jjcp-frontend-wrap .jjcp-layout {
        grid-template-columns: 1fr 1fr !important;
    }
    
    .jjcp-frontend-wrap .jjcp-column-right {
        grid-column: 1 / -1 !important;
    }
}

@media (max-width: 960px) {
    .jjcp-frontend-wrap .jjcp-layout {
        grid-template-columns: 1fr !important;
    }
}

/* Center column Visual Schematic section */
.jjcp-frontend-wrap .jjcp-column-center .jjcp-section {
    background: #f9f7f4 !important;
    border: 1px solid #d4c4b0 !important;
}

/* Right column sections */
.jjcp-frontend-wrap .jjcp-column-right .jjcp-section {
    background: #f9f7f4 !important;
}

.jjcp-frontend-wrap .jjcp-column-right .jjcp-validation-panel {
    background: white !important;
}

.jjcp-frontend-wrap .jjcp-column-right .jjcp-results-panel {
    background: white !important;
}

/* Make sure all section titles are visible */
.jjcp-frontend-wrap .jjcp-section-title {
    font-size: 1.4em !important;
    font-weight: 600 !important;
    color: #5a4a3a !important;
    font-family: 'Garamond', 'Georgia', serif !important;
}

/* Ensure tier badges show properly */
.jjcp-frontend-wrap .jjcp-tier-badge {
    display: inline-block !important;
    font-size: 0.7em !important;
    padding: 0.3em 0.7em !important;
    border-radius: 3px !important;
    margin-right: 0.5em !important;
}

.jjcp-frontend-wrap .jjcp-tier-required {
    background: #6a8b5f !important;
    color: white !important;
}

.jjcp-frontend-wrap .jjcp-tier-optional {
    background: #c4914b !important;
    color: white !important;
}

.jjcp-frontend-wrap .jjcp-tier-advanced {
    background: #8b7355 !important;
    color: white !important;
}

/* Force box-sizing for all elements */
.jjcp-frontend-wrap,
.jjcp-frontend-wrap * {
    box-sizing: border-box !important;
}

/* --- Dropdown Arrow Styling --- */
/* Add visible dropdown arrows to all select elements */
.jjcp-frontend-wrap select.jjcp-input,
select.jjcp-input {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    background-image: url('data:image/svg+xml;charset=UTF-8,%3Csvg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12"%3E%3Cpath fill="%235a4a3a" d="M6 9L1 4h10z"/%3E%3C/svg%3E') !important;
    background-repeat: no-repeat !important;
    background-position: right 0.7em center !important;
    background-size: 12px !important;
    padding-right: 2.5em !important;
}

/* Ensure select elements are clearly interactive */
.jjcp-frontend-wrap select.jjcp-input:hover,
select.jjcp-input:hover {
    border-color: #8b7355 !important;
    cursor: pointer !important;
}

.jjcp-frontend-wrap select.jjcp-input:focus,
select.jjcp-input:focus {
    border-color: #8b7355 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(139, 115, 85, 0.1) !important;
}

/* ===================================
/* ===================================
   INLINE HELP TEXT v1.3.1 (Frontend)
   =================================== */

.jjcp-help-text,
.jjcp-frontend-wrap .jjcp-help-text {
    font-size: 0.85em !important;
    color: #666 !important;
    font-weight: normal !important;
    font-style: italic !important;
}

/* Fix hover visibility for toggle buttons */
.jjcp-toggle-advanced:hover,
.jjcp-frontend-wrap .jjcp-toggle-advanced:hover {
    background: #f0e8dc !important;
    color: #5a4a3a !important;
    border-color: #8b7355 !important;
}






































































































/* Readonly Fields */
.jjcp-readonly-field,
.jjcp-frontend-wrap .jjcp-readonly-field {
    background: #f5f5f5 !important;
    border: 1px solid #d4c4b0 !important;
    border-radius: 3px !important;
    padding: 0.6em !important;
    font-family: 'Courier New', monospace !important;
    font-size: 1em !important;
    color: #5a4a3a !important;
    min-height: 2.5em !important;
    display: flex !important;
    align-items: center !important;
}

.jjcp-readonly-highlight,
.jjcp-frontend-wrap .jjcp-readonly-highlight {
    background: #fff3e6 !important;
    border-color: #c4914b !important;
    font-weight: 600 !important;
}

/* Info Boxes */
.jjcp-info-box,
.jjcp-frontend-wrap .jjcp-info-box {
    background: #f0f8e8 !important;
    border: 1px solid #6a8b5f !important;
    border-radius: 4px !important;
    padding: 1em !important;
    margin-top: 1em !important;
}

.jjcp-info-content,
.jjcp-frontend-wrap .jjcp-info-content {
    margin-top: 0.5em !important;
    font-size: 0.9em !important;
    font-style: italic !important;
    color: #5a4a3a !important;
}

/* Spreadsheet Section Styling */
.jjcp-spreadsheet-section,
.jjcp-frontend-wrap .jjcp-spreadsheet-section {
    position: relative !important;
}

.jjcp-spreadsheet-section::before,
.jjcp-frontend-wrap .jjcp-spreadsheet-section::before {
    content: '' !important;
    position: absolute !important;
    left: -10px !important;
    top: 0 !important;
    bottom: 0 !important;
    width: 4px !important;
    background: #8b7355 !important;
    border-radius: 2px !important;
}

/* ===================================
   TOOLTIP SYSTEM v1.3.0 (Frontend)
   =================================== */

/* Tooltip Toggle Controls */
.jjcp-frontend-wrap .jjcp-tooltip-controls,
.jjcp-tooltip-controls {
    background: #f9f7f4 !important;
    border: 1px solid #d4c4b0 !important;
    border-radius: 4px !important;
    padding: 1em !important;
    margin-bottom: 1.5em !important;
    text-align: right !important;
}

.jjcp-frontend-wrap .jjcp-tooltip-toggle,
.jjcp-tooltip-toggle {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5em !important;
    cursor: pointer !important;
    font-size: 0.95em !important;
    color: #5a4a3a !important;
}

.jjcp-frontend-wrap .jjcp-tooltip-toggle input[type="checkbox"],
.jjcp-tooltip-toggle input[type="checkbox"] {
    width: auto !important;
    margin: 0 !important;
}

/* Tooltip Icons */
.jjcp-frontend-wrap .jjcp-tooltip-icon,
.jjcp-tooltip-icon {
    display: inline-block !important;
    width: 18px !important;
    height: 18px !important;
    line-height: 18px !important;
    text-align: center !important;
    background: #8b7355 !important;
    color: white !important;
    border-radius: 50% !important;
    font-size: 0.75em !important;
    font-weight: bold !important;
    cursor: help !important;
    margin-left: 0.3em !important;
    vertical-align: middle !important;
    position: relative !important;
}

.jjcp-frontend-wrap .jjcp-tooltip-icon:hover,
.jjcp-tooltip-icon:hover {
    background: #5a4a3a !important;
}

/* Tooltip Content */
.jjcp-frontend-wrap .jjcp-tooltip-content,
.jjcp-tooltip-content {
    position: absolute !important;
    bottom: 100% !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    margin-bottom: 8px !important;
    padding: 0.6em 0.9em !important;
    background: #2c2c2c !important;
    color: white !important;
    font-size: 0.85em !important;
    line-height: 1.4 !important;
    border-radius: 4px !important;
    max-width: 300px !important;
    white-space: normal !important;
    z-index: 1000 !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transition: opacity 0.2s !important;
}

.jjcp-frontend-wrap .jjcp-tooltip-icon:hover .jjcp-tooltip-content,
.jjcp-tooltip-icon:hover .jjcp-tooltip-content,
.jjcp-frontend-wrap .jjcp-tooltip-icon.jjcp-tooltip-active .jjcp-tooltip-content,
.jjcp-tooltip-icon.jjcp-tooltip-active .jjcp-tooltip-content {
    opacity: 1 !important;
    pointer-events: auto !important;
}

/* Tooltip Arrow */
.jjcp-frontend-wrap .jjcp-tooltip-content::after,
.jjcp-tooltip-content::after {
    content: '' !important;
    position: absolute !important;
    top: 100% !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    border: 6px solid transparent !important;
    border-top-color: #2c2c2c !important;
}

/* Hide tooltips when toggle is off */
body.jjcp-tooltips-hidden .jjcp-tooltip-icon .jjcp-tooltip-content {
    display: none !important;
}

/* Readonly Fields */
.jjcp-frontend-wrap .jjcp-readonly-field,
.jjcp-readonly-field {
    background: #f5f5f5 !important;
    border: 1px solid #d4c4b0 !important;
    border-radius: 3px !important;
    padding: 0.6em !important;
    font-family: 'Courier New', monospace !important;
    font-size: 1em !important;
    color: #5a4a3a !important;
    min-height: 2.5em !important;
    display: flex !important;
    align-items: center !important;
}

.jjcp-frontend-wrap .jjcp-readonly-highlight,
.jjcp-readonly-highlight {
    background: #fff3e6 !important;
    border-color: #c4914b !important;
    font-weight: 600 !important;
}

/* Info Boxes */
.jjcp-frontend-wrap .jjcp-info-box,
.jjcp-info-box {
    background: #f0f8e8 !important;
    border: 1px solid #6a8b5f !important;
    border-radius: 4px !important;
    padding: 1em !important;
    margin-top: 1em !important;
}

.jjcp-frontend-wrap .jjcp-info-content,
.jjcp-info-content {
    margin-top: 0.5em !important;
    font-size: 0.9em !important;
    font-style: italic !important;
    color: #5a4a3a !important;
}

/* Spreadsheet Section Styling */
.jjcp-frontend-wrap .jjcp-spreadsheet-section,
.jjcp-spreadsheet-section {
    position: relative !important;
}

.jjcp-frontend-wrap .jjcp-spreadsheet-section::before,
.jjcp-spreadsheet-section::before {
    content: '' !important;
    position: absolute !important;
    left: -10px !important;
    top: 0 !important;
    bottom: 0 !important;
    width: 4px !important;
    background: #8b7355 !important;
    border-radius: 2px !important;
}
