/* ==========================================================================
   DESIGN SYSTEM & VARIABLES
   ========================================================================== */
:root {
    /* App UI Theme Colors (Slate Dark Mode) */
    --app-bg: #0F172A;
    --sidebar-bg: #1E293B;
    --panel-bg: #1e293b;
    --input-bg: #0f172a;
    --border-color: rgba(6, 182, 212, 0.2);
    --text-main: #f8fafc;
    --text-muted: #94a3b8;
    --accent-color: #06B6D4; /* Default ServiceNow/AI green */
    --accent-hover: #0891B2;
    --error-color: #ef4444;

    /* Icon Pack Theming Custom Properties */
    --icon-gradient-start: #06B6D4;
    --icon-gradient-end: #3730A3;
    --icon-accent-cyan: #06B6D4;
    --icon-accent-indigo: #3730A3;
    --icon-accent-light: #7DD3FC;
    --icon-center-light: #F8FAFC;

    /* Card Variables (Default Values) */
    --card-width: 800px;
    --card-height: 800px; /* Default square 1:1 */
    --card-border-width: 8px;
    --card-border-radius: 20px;
    --card-padding: 48px;
    --card-bg-gradient: radial-gradient(circle at 10% 20%, #111827 0%, #030712 100%);
    --card-text-primary: #f8fafc;
    --card-text-secondary: #94a3b8;
    --card-accent: #06B6D4;
    --card-accent-bg: rgba(6, 182, 212, 0.1);
    
    /* Layout */
    --sidebar-width: 550px;
    --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    --font-card-title: 'Outfit', var(--font-sans);
}

/* Reset and Core Setup */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* ==========================================================================
   HEADER PROFILE MENU & INTERACTIVES
   ========================================================================== */
.header-profile-menu-container {
    position: relative;
    display: inline-block;
}

.header-profile-btn {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--text-main);
    width: 42px;
    height: 42px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 18px;
    padding: 0;
    overflow: hidden;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.header-profile-btn img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@media (hover: hover) {
    .header-profile-btn:hover {
        background: rgba(255, 255, 255, 0.1);
        border-color: rgba(6, 182, 212, 0.4);
        box-shadow: 0 0 12px rgba(6, 182, 212, 0.25);
        transform: translateY(-2px);
    }
}

.header-profile-btn:active {
    transform: translateY(0) scale(0.95);
}

.header-profile-dropdown {
    position: absolute;
    top: calc(100% + 12px);
    right: 0;
    width: 320px;
    background: rgba(15, 23, 42, 0.85);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid rgba(6, 182, 212, 0.25);
    border-radius: 16px;
    padding: 20px;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4), 0 0 24px rgba(6, 182, 212, 0.1);
    z-index: 1000;
    display: flex;
    flex-direction: column;
    gap: 16px;
    transform-origin: top right;
    transition: opacity 0.25s cubic-bezier(0.4, 0, 0.2, 1), transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

@media (max-width: 900px) {
    /* Center profile menu on mobile/tablets to prevent edge clipping */
    .header-profile-dropdown {
        right: -80px; /* offset slightly so it centers around the trigger */
        transform-origin: top center;
    }
}

@media (max-width: 480px) {
    .header-profile-dropdown {
        position: fixed;
        top: 60px;
        left: 16px;
        right: 16px;
        width: auto;
        transform-origin: top center;
    }
}

/* Recent Decks & Templates Grid Overrides */
.recent-drafts-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 16px;
    width: 100%;
}

@media (max-width: 1024px) {
    .recent-drafts-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 600px) {
    .recent-drafts-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Blank Launcher Special Design */
.recent-deck-card.blank-launcher {
    background: linear-gradient(135deg, rgba(6, 182, 212, 0.15) 0%, rgba(30, 41, 59, 0.4) 100%) !important;
    border: 1px dashed rgba(6, 182, 212, 0.4) !important;
}

@media (hover: hover) {
    .recent-deck-card.blank-launcher:hover {
        background: linear-gradient(135deg, rgba(6, 182, 212, 0.25) 0%, rgba(30, 41, 59, 0.6) 100%) !important;
        border-color: rgba(6, 182, 212, 0.7) !important;
        box-shadow: 0 10px 24px rgba(6, 182, 212, 0.2), 0 0 15px rgba(6, 182, 212, 0.15) !important;
    }
}

/* Active touch states for mobile/tablets where hover is ignored */
.recent-deck-card:active {
    transform: scale(0.98) !important;
    background: rgba(30, 41, 59, 0.7) !important;
}

.recent-deck-card.blank-launcher:active {
    background: linear-gradient(135deg, rgba(6, 182, 212, 0.35) 0%, rgba(30, 41, 59, 0.7) 100%) !important;
}

/* Interactive Onboarding Checklist Styling */
.checklist-item {
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

@media (hover: hover) {
    .checklist-item:hover {
        color: var(--text-main, #f8fafc) !important;
        transform: translateX(4px);
    }
}

.checklist-item:active {
    transform: scale(0.98);
}

body {
    background-color: var(--app-bg);
    color: var(--text-main);
    font-family: var(--font-sans);
    height: 100vh;
    overflow: hidden;
}

/* ==========================================================================
   APP LAYOUT Structure
   ========================================================================== */
.app-container {
    display: flex;
    height: 100vh;
    width: 100vw;
}

/* ==========================================================================
   SIDEBAR CONTROLS
   ========================================================================== */
.sidebar {
    width: var(--sidebar-width);
    background-color: var(--sidebar-bg);
    border-right: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    height: 100%;
    max-height: 100vh;
    overflow: hidden;
    z-index: 10;
    box-shadow: 10px 0 30px rgba(0, 0, 0, 0.3);
}

.sidebar-header {
    padding: 24px;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo-area {
    display: flex;
    align-items: center;
    gap: 10px;
}

.app-logo {
    width: 32px;
    height: 32px;
    color: var(--accent-color);
}

.logo-area h1 {
    font-size: 20px;
    font-weight: 700;
    background: linear-gradient(135deg, #06B6D4 0%, #3730A3 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    letter-spacing: -0.5px;
}

.badge {
    background-color: rgba(6, 182, 212, 0.1);
    color: var(--accent-color);
    border: 1px solid rgba(6, 182, 212, 0.2);
    padding: 4px 8px;
    border-radius: 9999px;
    font-size: 11px;
    font-weight: 600;
}

/* Scrollable Controls Area */
.controls-wrapper {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Styled Accordion Sections */
.control-section {
    background-color: var(--panel-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    overflow: hidden;
    transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
    flex-shrink: 0;
}

.control-section:hover {
    border-color: rgba(255, 255, 255, 0.1);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.25);
}

.control-section[open] {
    border-color: var(--accent-color, rgba(6, 182, 212, 0.4));
    box-shadow: 0 4px 20px rgba(6, 182, 212, 0.08);
}

.control-section summary {
    padding: 16px 20px;
    font-weight: 600;
    font-size: 15px;
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    gap: 12px;
    user-select: none;
    outline: none;
}

/* Hide default disclosure triangle */
.control-section summary::-webkit-details-marker {
    display: none;
}

.section-icon {
    width: 18px;
    height: 18px;
    color: var(--text-muted);
    transition: color 0.2s;
}

.control-section[open] summary .section-icon {
    color: var(--accent-color);
}

.control-section summary::after {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    border-right: 2px solid var(--text-muted);
    border-bottom: 2px solid var(--text-muted);
    transform: rotate(-45deg);
    margin-left: auto;
    margin-right: 4px;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.control-section[open] summary::after {
    transform: rotate(45deg);
    border-color: var(--accent-color);
}

.section-content {
    padding: 0 20px 20px 20px;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding-top: 16px;
}

/* Form Elements */
.form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.form-row {
    display: flex;
    gap: 16px;
}

.form-group.col {
    flex: 1;
}

label {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-muted);
}

.tip {
    font-size: 11px;
    color: var(--accent-color);
    text-transform: none;
    letter-spacing: 0;
    font-weight: 400;
}

input[type="text"],
input[type="password"],
select,
textarea {
    background-color: var(--input-bg);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 10px 14px;
    color: var(--text-main);
    font-size: 14px;
    outline: none;
    font-family: var(--font-sans);
    transition: all 0.2s;
}

input[type="text"]:focus,
input[type="password"]:focus,
select:focus,
textarea:focus {
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(6, 182, 212, 0.15);
}

textarea {
    resize: vertical;
    line-height: 1.5;
}

/* Custom File Upload Button */
.file-upload-wrapper {
    position: relative;
    width: 100%;
}

.btn-file-upload {
    width: 100%;
    background-color: var(--input-bg);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 10px 14px;
    color: var(--text-main);
    font-size: 14px;
    cursor: pointer;
    font-weight: 500;
    text-align: center;
    transition: background-color 0.2s;
}

.btn-file-upload:hover {
    background-color: rgba(255, 255, 255, 0.05);
}

.file-upload-wrapper input[type="file"] {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

/* Range sliders */
input[type="range"] {
    -webkit-appearance: none;
    width: 100%;
    height: 6px;
    border-radius: 3px;
    background: var(--input-bg);
    outline: none;
    margin: 12px 0;
}

input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--accent-color);
    cursor: pointer;
    transition: transform 0.1s;
}

input[type="range"]::-webkit-slider-thumb:hover {
    transform: scale(1.2);
}

/* Checkbox Style */
.checkbox-label {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-size: 13px;
    text-transform: none;
    color: var(--text-main);
    letter-spacing: 0;
    user-select: none;
}

.checkbox-label input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--accent-color);
}

/* Theme Presets Styling */
.theme-presets {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}

.theme-btn {
    background-color: var(--input-bg);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 8px 10px;
    color: var(--text-main);
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: all 0.2s;
    text-align: left;
}

.theme-btn:hover {
    border-color: var(--text-muted);
}

.theme-btn.active {
    border-color: var(--accent-color);
    background-color: rgba(6, 182, 212, 0.05);
}

.preview-dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    flex-shrink: 0;
}

/* Signature Panel Modes */
.sig-modes {
    display: flex;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
}

.sig-mode-btn {
    flex: 1;
    background: var(--input-bg);
    border: none;
    color: var(--text-muted);
    padding: 8px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.2s;
}

.sig-mode-btn:not(:last-child) {
    border-right: 1px solid var(--border-color);
}

.sig-mode-btn.active {
    background-color: var(--accent-color);
    color: #0f172a;
}

.sig-content-area {
    margin-top: 12px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.sig-content-area.hidden {
    display: none !important;
}

/* Signature Drawing Canvas */
.signature-pad-container {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

#signature-pad {
    background-color: var(--input-bg);
    border: 1px dashed var(--border-color);
    border-radius: 8px;
    cursor: crosshair;
    touch-action: none;
    width: 100%;
    height: 120px;
}

.pad-actions {
    display: flex;
    gap: 8px;
}

.btn-secondary {
    flex: 1;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.03) 0%, rgba(255, 255, 255, 0.01) 100%);
    border: 1px solid var(--border-color);
    color: var(--text-muted);
    padding: 8px 14px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.btn-secondary:hover {
    border-color: var(--accent-color, #06B6D4);
    color: var(--text-main);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(6, 182, 212, 0.15);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.02) 100%);
}

/* Color picker styling */
.color-picker-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

input[type="color"] {
    -webkit-appearance: none;
    border: none;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    cursor: pointer;
    background: none;
}

input[type="color"]::-webkit-color-swatch-wrapper {
    padding: 0;
}

input[type="color"]::-webkit-color-swatch {
    border: 2px solid var(--border-color);
    border-radius: 50%;
}

.color-hex {
    font-family: 'Fira Code', monospace;
    font-size: 13px;
    color: var(--text-muted);
}

/* Color Presets Row & Swatches */
.color-presets-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

.color-preset-btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid var(--border-color);
    cursor: pointer;
    padding: 0;
    transition: all 0.2s ease;
    position: relative;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.color-preset-btn:hover {
    transform: scale(1.1);
    border-color: var(--text-main);
}

.color-preset-btn.active {
    border-color: var(--accent-color, #06B6D4);
    box-shadow: 0 0 10px var(--accent-color, #06B6D4);
    transform: scale(1.1);
}

.custom-color-picker-wrapper {
    position: relative;
    width: 32px;
    height: 32px;
}

.custom-color-picker-wrapper .color-preset-btn.custom-preset {
    width: 100%;
    height: 100%;
}

/* Sidebar Footer (Aspect Ratios and Export) */
.sidebar-footer {
    padding: 24px;
    border-top: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.export-options {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.ratio-toggle {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    border: none;
    background: transparent;
    overflow: visible;
}

.ratio-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: var(--input-bg);
    border: 2px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-muted);
    padding: 12px;
    font-size: 11px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.25s ease;
}

.ratio-btn svg {
    color: var(--text-muted);
    transition: color 0.25s ease, stroke 0.25s ease;
}

.ratio-btn:first-child {
    border-right: 2px solid var(--border-color);
}

.ratio-btn.active {
    background-color: var(--panel-bg);
    border-color: var(--accent-color, #06B6D4);
    color: var(--text-main);
    box-shadow: 0 0 12px rgba(6, 182, 212, 0.15);
}

.ratio-btn.active svg {
    color: var(--accent-color, #06B6D4);
}

.scale-selector {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 12px;
    color: var(--text-muted);
}

.scale-selector select {
    padding: 6px 12px;
    font-size: 12px;
    background-color: var(--panel-bg);
}

.btn-primary {
    background: linear-gradient(135deg, #06B6D4 0%, #3730A3 100%);
    border: none;
    color: #0f172a;
    padding: 14px 20px;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: all 0.2s;
    box-shadow: 0 4px 12px rgba(6, 182, 212, 0.3);
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(6, 182, 212, 0.4);
}

.btn-icon {
    width: 18px;
    height: 18px;
}

/* ==========================================================================
   MAIN PREVIEW AREA
   ========================================================================== */
.preview-pane {
    flex: 1;
    background-color: var(--app-bg);
    display: flex;
    flex-direction: column;
    padding: 40px;
    overflow-y: auto;
    position: relative;
    align-items: center;
    justify-content: flex-start;
}

/* Tech-y Grid Background behind card preview */
.preview-pane::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: 
        radial-gradient(var(--border-color) 1px, transparent 1px),
        linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
    background-size: 32px 32px, 32px 32px, 32px 32px;
    background-position: center;
    z-index: 1;
    pointer-events: none;
}

.preview-header {
    text-align: center;
    margin-bottom: 30px;
    z-index: 2;
}

.preview-header h2 {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 6px;
    color: var(--text-main);
}

.preview-header p {
    font-size: 14px;
    color: var(--text-muted);
}

/* Outer scaling box for the live card */
.preview-container {
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2;
    transform-origin: top center;
    transition: transform 0.2s ease;
    box-shadow: 0 25px 60px -10px rgba(0, 0, 0, 0.8), 0 0 1px rgba(255, 255, 255, 0.12);
    flex-shrink: 0;
}

.preview-container.ratio-1-1 {
    width: var(--card-width);
    height: var(--card-width);
}

.preview-container.ratio-4-5 {
    width: var(--card-width);
    height: calc(var(--card-width) * 1.25);
}

/* ==========================================================================
   THE BRAND CARD (HTML ELEMENT EXPORTED BY HTML2CANVAS)
   ========================================================================== */
.brand-card {
    /* Critical settings for pixel-perfect reproduction */
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
    
    /* Variable controlled styles */
    border-radius: var(--card-border-radius);
    padding: var(--card-padding);
    background: var(--card-bg-gradient);
    color: var(--card-text-primary);
    
    /* Layout border rendering wrapper */
    border: var(--card-border-width) solid transparent;
}

/* BORDER STYLES */
/* 1. Neon Gradient */
.brand-card.border-neon-gradient {
    border-color: transparent;
    background-image: 
        var(--card-bg-gradient), 
        linear-gradient(135deg, #06B6D4 0%, #3730A3 100%);
    background-origin: border-box;
    background-clip: padding-box, border-box;
}

/* 2. Champagne Gold / Accent */
.brand-card.border-servicenow-green,
.brand-card.border-champagne-gold {
    border-color: transparent;
    /* Draws gold frame only on top, bottom and sides */
    background-image: 
        var(--card-bg-gradient), 
        linear-gradient(to right, #e8c894 0%, #a38f6d 100%);
    background-origin: border-box;
    background-clip: padding-box, border-box;
}

/* 3. Solid slate border */
.brand-card.border-solid {
    border-color: var(--border-color);
}

/* 4. Double Gold */
.brand-card.border-double-gold {
    border: calc(var(--card-border-width) + 2px) double #d4af37;
}

/* 5. Dashed Line */
.brand-card.border-dashed {
    border: var(--card-border-width) dashed var(--card-accent);
}

/* 6. Inset Glass Glow */
.brand-card.border-inset-glow {
    border: 1px solid rgba(255, 255, 255, 0.15);
    box-shadow: inset 0 0 30px rgba(255, 255, 255, 0.05);
}

.brand-card.border-none {
    border: none;
}

/* TYPOGRAPHY FAMILY OVERRIDES */
.font-modern {
    font-family: 'Outfit', sans-serif;
}
.font-modern .article-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
}

.font-clean {
    font-family: 'Inter', sans-serif;
}
.font-clean .article-title {
    font-family: 'Inter', sans-serif;
    font-weight: 700;
}

.font-editorial {
    font-family: 'Alegreya Sans', sans-serif;
}
.font-editorial .article-title {
    font-family: 'Playfair Display', serif;
    font-weight: 700;
    line-height: 1.3;
}

.font-monopad {
    font-family: 'Fira Code', monospace;
}
.font-monopad .article-title {
    font-family: 'Fira Code', monospace;
    font-weight: 600;
}

.font-custom {
    font-family: var(--card-custom-font), sans-serif !important;
}
.font-custom .article-title {
    font-family: var(--card-custom-font), sans-serif !important;
    font-weight: 700;
}

/* CARD DETAILS */

/* Top Header */
.card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
}

.profile-group {
    display: flex;
    align-items: center;
    gap: 16px;
}

.avatar-container {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    overflow: hidden;
    background-color: var(--panel-bg);
    border: 2px solid var(--card-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all 0.3s;
    cursor: pointer;
}
.avatar-container:hover {
    transform: scale(1.05);
    box-shadow: 0 0 12px var(--card-accent);
    border-color: var(--card-accent);
}

.avatar-container.shape-circle {
    border-radius: 50% !important;
    clip-path: none !important;
}
.avatar-container.shape-square {
    border-radius: 0 !important;
    clip-path: none !important;
}
.avatar-container.shape-rounded {
    border-radius: 12px !important;
    clip-path: none !important;
}
.avatar-container.shape-hex {
    border-radius: 0 !important;
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%) !important;
}

#card-avatar-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

#card-logo-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    background: transparent;
}

.avatar-fallback {
    width: 40px;
    height: 40px;
    color: var(--card-text-secondary);
}

.profile-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.profile-name {
    font-size: 18px;
    font-weight: 700;
    color: var(--card-text-primary);
}

.profile-headline {
    font-size: var(--brand-headline-size, 13px);
    color: var(--card-text-secondary);
    line-height: 1.4;
    max-width: var(--brand-headline-width, 320px);
    word-break: break-word;
}

.badge-tag {
    background-color: var(--card-accent-bg);
    color: var(--card-accent);
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

/* Middle Content Area */
.card-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin: 20px 0;
    gap: 16px;
}

.article-title {
    font-size: var(--card-title-size, 32px);
    line-height: 1.35;
    color: var(--card-text-primary);
    margin-bottom: 12px;
    letter-spacing: -0.5px;
}

.article-content {
    font-size: var(--card-content-size, 18px);
    line-height: 1.6;
    color: var(--card-text-secondary);
    white-space: pre-line;
}

.article-content strong {
    color: var(--card-text-primary);
    font-weight: 600;
    background: linear-gradient(120deg, rgba(6, 182, 212, 0.15) 0%, rgba(6, 182, 212, 0.15) 100%);
    padding: 2px 4px;
    border-radius: 4px;
}

.article-content-hashtags {
    font-size: 15px;
    color: var(--card-accent);
    margin-top: 16px;
    font-weight: 500;
    letter-spacing: 0.2px;
}

/* Bottom Footer */
.card-footer {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    width: 100%;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 16px;
}

.social-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--card-text-secondary);
    background-color: rgba(255, 255, 255, 0.03);
    padding: 6px 12px;
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.linkedin-icon {
    width: 16px;
    height: 16px;
    color: #0a66c2; /* Standard linkedin blue for professional visual cues */
}

.footer-right {
    display: flex;
    align-items: center;
    gap: 20px;
}

.monogram-badge {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--card-accent) 0%, #06b6d4 100%);
    color: #0f172a;
    font-weight: 800;
    font-size: 15px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.signature-container {
    height: 48px;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
}

.signature-text {
    font-size: 32px;
    font-family: 'Caveat', cursive;
    color: var(--card-accent);
    user-select: none;
    transform: rotate(-3deg);
    display: inline-block;
    cursor: pointer;
    transition: all 0.2s;
}
.signature-text:hover {
    outline: 2px dashed var(--card-accent, #06B6D4);
    outline-offset: 2px;
}

#card-signature-img {
    max-height: 100%;
    max-width: 280px;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0px 2px 4px rgba(0,0,0,0.3));
    cursor: pointer;
    transition: all 0.2s;
}
#card-signature-img:hover {
    outline: 2px dashed var(--card-accent, #06B6D4);
    outline-offset: 2px;
}

.hidden {
    display: none !important;
}

/* ==========================================================================
   THEME STYLE DEFINITIONS (Variables bindings)
   ========================================================================== */

/* 1. AI GLOW (Obsidian Dark, Emerald & Teal Highlights) */
.brand-card.theme-ai-glow {
    --card-bg-gradient: radial-gradient(circle at 10% 20%, #0f172a 0%, #020617 100%);
    --card-text-primary: #f8fafc;
    --card-text-secondary: #94a3b8;
    --card-accent: #06B6D4;
    --card-accent-bg: rgba(6, 182, 212, 0.1);
}

/* 2. CHAMPAGNE & CHARCOAL (Deep Charcoal & Soft Metallic Gold Accent) */
.brand-card.theme-servicenow-slate,
.brand-card.theme-champagne-charcoal {
    --card-bg-gradient: linear-gradient(135deg, #1c1c24 0%, #0f0f15 100%);
    --card-text-primary: #fcfbfa;
    --card-text-secondary: #9ca3af;
    --card-accent: #e8c894; /* Champagne Gold */
    --card-accent-bg: rgba(232, 200, 148, 0.1);
}
.brand-card.theme-servicenow-slate .monogram-badge,
.brand-card.theme-champagne-charcoal .monogram-badge {
    background: linear-gradient(135deg, #e8c894 0%, #a38f6d 100%);
    color: #1c1c24;
}
.brand-card.theme-servicenow-slate .article-content strong,
.brand-card.theme-champagne-charcoal .article-content strong {
    background: linear-gradient(120deg, rgba(232, 200, 148, 0.15) 0%, rgba(163, 143, 109, 0.15) 100%);
}

/* 3. ADVISORY NAVY (Royal Midnight Blue, Metallic Gold Accent) */
.brand-card.theme-advisory-navy {
    --card-bg-gradient: linear-gradient(135deg, #0b132b 0%, #1c2541 100%);
    --card-text-primary: #ffffff;
    --card-text-secondary: #cbd5e1;
    --card-accent: #d4af37; /* Metallic Gold */
    --card-accent-bg: rgba(212, 175, 55, 0.12);
}
.brand-card.theme-advisory-navy .monogram-badge {
    background: linear-gradient(135deg, #d4af37 0%, #f3e5ab 100%);
    color: #0b132b;
}
.brand-card.theme-advisory-navy .article-content strong {
    background: linear-gradient(120deg, rgba(212, 175, 55, 0.15) 0%, rgba(243, 229, 171, 0.15) 100%);
}

/* 4. GLASS OBSIDIAN (Ultra Translucent Dark Mode) */
.brand-card.theme-glass-obsidian {
    --card-bg-gradient: linear-gradient(135deg, rgba(15, 23, 42, 0.95) 0%, rgba(2, 6, 17, 0.98) 100%);
    --card-text-primary: #ffffff;
    --card-text-secondary: #cbd5e1;
    --card-accent: #38bdf8; /* Sky Blue */
    --card-accent-bg: rgba(56, 189, 248, 0.1);
}
.brand-card.theme-glass-obsidian .monogram-badge {
    background: linear-gradient(135deg, #38bdf8 0%, #ec4899 100%);
    color: #ffffff;
}

/* 5. MINIMALIST LIGHT (Editorial Light, Charcoal Accents) */
.brand-card.theme-minimalist-light {
    --card-bg-gradient: linear-gradient(135deg, #fafaf9 0%, #f5f5f4 100%);
    --card-text-primary: #1c1917;
    --card-text-secondary: #57534e;
    --card-accent: #1c1917;
    --card-accent-bg: #e7e5e4;
    border-color: #e7e5e4;
}
.brand-card.theme-minimalist-light .monogram-badge {
    background: #1c1917;
    color: #fafaf9;
}
.brand-card.theme-minimalist-light .article-content strong {
    color: #1c1917;
    background: rgba(0, 0, 0, 0.08);
}
.brand-card.theme-minimalist-light .linkedin-icon {
    color: #1c1917;
}

/* 6. TASMAN SERENE (Deep Pacific Navy, Clean Light Blue Accent) */
.brand-card.theme-tasman-serene {
    --card-bg-gradient: linear-gradient(135deg, #0a122c 0%, #040714 100%);
    --card-text-primary: #f1f5f9;
    --card-text-secondary: #94a3b8;
    --card-accent: #00b4d8;
    --card-accent-bg: rgba(0, 180, 216, 0.1);
}
.brand-card.theme-tasman-serene .monogram-badge {
    background: linear-gradient(135deg, #00b4d8 0%, #0077b6 100%);
    color: #f1f5f9;
}
.brand-card.theme-tasman-serene .article-content strong {
    color: #00b4d8;
    background: rgba(0, 180, 216, 0.08);
}

/* 7. OCEANIA WILDERNESS (Eucalyptus Teal & Ocean Blue) */
.brand-card.theme-oceania-wilderness {
    --card-bg-gradient: linear-gradient(135deg, #05101a 0%, #01050a 100%);
    --card-text-primary: #fafaf9;
    --card-text-secondary: #8ca1ad;
    --card-accent: #02c39a;
    --card-accent-bg: rgba(2, 195, 154, 0.1);
}
.brand-card.theme-oceania-wilderness .monogram-badge {
    background: linear-gradient(135deg, #02c39a 0%, #005f73 100%);
    color: #fafaf9;
}
.brand-card.theme-oceania-wilderness .article-content strong {
    color: #02c39a;
    background: rgba(2, 195, 154, 0.08);
}

/* 8. GLACIER QUIET (Alpine Mist & Glacial Ice Blue) */
.brand-card.theme-glacier-quiet {
    --card-bg-gradient: linear-gradient(135deg, #0d131f 0%, #05070a 100%);
    --card-text-primary: #f8fafc;
    --card-text-secondary: #cbd5e1;
    --card-accent: #93c5fd;
    --card-accent-bg: rgba(147, 197, 253, 0.12);
}
.brand-card.theme-glacier-quiet .monogram-badge {
    background: linear-gradient(135deg, #93c5fd 0%, #a5f3fc 100%);
    color: #0d131f;
}
.brand-card.theme-glacier-quiet .article-content strong {
    color: #93c5fd;
    background: rgba(147, 197, 253, 0.1);
}

/* 9. TASMAN BREEZE (Glacial White & Clear Pacific Blue) - Light Mode */
.brand-card.theme-tasman-breeze {
    --card-bg-gradient: linear-gradient(135deg, #ffffff 0%, #e6f0fa 100%);
    --card-text-primary: #0f172a;
    --card-text-secondary: #475569;
    --card-accent: #0077b6;
    --card-accent-bg: rgba(0, 119, 182, 0.1);
    border-color: #cbd5e1;
}
.brand-card.theme-tasman-breeze .monogram-badge {
    background: linear-gradient(135deg, #0077b6 0%, #0096c7 100%);
    color: #ffffff;
}
.brand-card.theme-tasman-breeze .article-content strong {
    color: #0077b6;
    background: rgba(0, 119, 182, 0.08);
}

/* ==========================================================================
   IMAGE LAYOUT STYLES
   ========================================================================== */
.layout-element-image {
    display: flex;
    flex-direction: column;
    height: 100%;
    box-sizing: border-box;
    gap: 12px;
}
.image-layout-title {
    font-size: calc(var(--card-title-size, 32px) * 0.6875);
    font-weight: 700;
    color: var(--card-text-primary);
    margin: 0;
    line-height: 1.25;
}
.image-layout-container {
    display: flex;
    justify-content: center;
    align-items: center;
    flex: 1;
    width: 100%;
    min-height: 120px;
    position: relative;
    overflow: hidden;
}
.slide-content-image {
    max-height: 380px;
    max-width: 100%;
    object-fit: contain;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    transition: max-height 0.2s ease, outline 0.2s;
    cursor: pointer;
}
.slide-content-image:hover {
    outline: 2px solid var(--card-accent, #06B6D4);
    outline-offset: 2px;
}
.brand-card.aspect-4-5 .slide-content-image {
    max-height: 480px;
}
.slide-content-image-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    height: 200px;
    border: 2px dashed rgba(255, 255, 255, 0.15);
    border-radius: 8px;
    padding: 20px;
    box-sizing: border-box;
    color: var(--card-text-secondary);
    text-align: center;
    font-size: 13px;
    cursor: pointer;
    transition: all 0.2s;
}
.slide-content-image-placeholder:hover {
    border-color: var(--card-accent, #06B6D4);
    background: rgba(6, 182, 212, 0.05);
    color: var(--card-text-primary);
}
.slide-content-image-placeholder:hover svg {
    color: var(--card-accent, #06B6D4);
    opacity: 1;
}
.slide-content-image-placeholder svg {
    width: 32px;
    height: 32px;
    opacity: 0.5;
    transition: all 0.2s;
}
.image-layout-caption {
    font-size: calc(var(--card-content-size, 18px) * 0.7778);
    line-height: 1.45;
    color: var(--card-text-secondary);
    white-space: pre-line;
}

/* ========================================================================== */
   SCROLLBAR STYLING
   ========================================================================== */
.controls-wrapper::-webkit-scrollbar {
    width: 6px;
}

.controls-wrapper::-webkit-scrollbar-track {
    background: var(--sidebar-bg);
}

.controls-wrapper::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 3px;
}

.controls-wrapper::-webkit-scrollbar-thumb:hover {
    background: var(--text-muted);
}

.preview-scale-wrapper {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    overflow: visible;
    transition: height 0.2s ease;
}

/* ==========================================================================
   RESPONSIVE MEDIA QUERIES (App Interface layout adjustments)
   ========================================================================== */
@media (max-width: 900px) {
    body {
        height: auto;
        overflow-y: auto;
    }

    .app-container {
        flex-direction: column;
        height: auto;
        min-height: 100vh;
        overflow-y: visible;
    }
    
    .sidebar {
        width: 100%;
        height: auto;
        max-height: none;
        overflow: visible;
        border-right: none;
        border-bottom: 1px solid var(--border-color);
    }

    .sidebar-header {
        padding: 16px;
    }

    .controls-wrapper {
        flex: none;
        height: auto;
        overflow: visible;
        padding: 16px;
        gap: 12px;
    }

    .sidebar-footer {
        padding: 16px;
        gap: 12px;
    }
    
    .preview-pane {
        padding: 16px;
        min-height: auto;
    }

    .login-box, .paywall-box {
        padding: 24px 16px;
        margin: 16px;
    }
}

/* Spinner Animation for Exporter Loading */
.animate-spin {
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

/* ==========================================================================
   ADDITIONAL ENHANCED FEATURES STYLING
   ========================================================================== */

/* Carousel Tabs Layout */
.carousel-manager {
    background-color: rgba(255,255,255,0.02);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 12px;
    margin-bottom: 12px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.slide-tabs-row {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
}

.slide-tabs {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    flex: 1;
    padding-bottom: 4px;
}

/* Hide scrollbar on tabs for cleaner UI */
.slide-tabs::-webkit-scrollbar {
    height: 4px;
}
.slide-tabs::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 2px;
}

.slide-tab {
    background-color: var(--input-bg);
    border: 1px solid var(--border-color);
    color: var(--text-muted);
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s;
}

.slide-tab:hover {
    border-color: var(--text-main);
    color: var(--text-main);
}

.slide-tab.active {
    background-color: var(--accent-color);
    color: #0f172a;
    border-color: var(--accent-color);
}

.btn-add-tab {
    width: 30px;
    height: 30px;
    background-color: var(--accent-color);
    color: #0f172a;
    border: none;
    border-radius: 6px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: transform 0.2s;
}

.btn-add-tab:hover {
    transform: scale(1.1);
}

.slide-order-actions {
    display: flex;
    gap: 8px;
}

.btn-mini-action {
    flex: 1;
    background: var(--input-bg);
    border: 1px solid var(--border-color);
    color: var(--text-muted);
    padding: 6px 8px;
    font-size: 11px;
    font-weight: 500;
    border-radius: 6px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    transition: all 0.2s;
}

.btn-mini-action svg {
    width: 12px;
    height: 12px;
}

.btn-mini-action:hover {
    border-color: var(--text-main);
    color: var(--text-main);
}

.btn-mini-action.danger {
    color: var(--error-color);
    border-color: rgba(239, 68, 68, 0.2);
}
.btn-mini-action.danger:hover {
    background-color: rgba(239, 68, 68, 0.1);
    border-color: var(--error-color);
}

/* Rich Text Formatting Toolbar */
.editor-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.global-formatting-bar {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 12px;
    background-color: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--border-color);
    padding: 10px 12px;
    border-radius: 10px;
    flex-shrink: 0;
}

.global-formatting-bar label {
    font-size: 11px;
    color: var(--text-muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.formatting-toolbar {
    display: flex;
    gap: 6px;
    flex-wrap: nowrap; /* Prevent wrapping so it remains horizontally readable */
    overflow-x: auto; /* Allow horizontal scroll if sidebar is very narrow */
}

.formatting-toolbar::-webkit-scrollbar {
    height: 3px;
}

.formatting-toolbar::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 1.5px;
}

.formatting-toolbar button {
    background-color: var(--input-bg);
    border: 1px solid var(--border-color);
    color: var(--text-muted);
    height: 28px;
    min-width: 28px;
    padding: 0 10px;
    font-size: 12px;
    cursor: pointer;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    white-space: nowrap; /* Prevent text inside buttons from wrapping */
}

.formatting-toolbar button:hover {
    border-color: var(--text-main);
    color: var(--text-main);
    background-color: rgba(255, 255, 255, 0.05);
}

.formatting-toolbar button:disabled {
    opacity: 0.3;
    cursor: not-allowed;
    border-color: var(--border-color) !important;
    color: var(--text-muted) !important;
    background-color: var(--input-bg) !important;
}

.formatting-toolbar button[data-tag="bold"],
.formatting-toolbar button[data-tag="italic"] {
    width: 28px;
    padding: 0;
}

.formatting-toolbar button[data-tag="highlight"] {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
}

.formatting-toolbar button[data-tag="bullet"] {
    font-size: 11px;
    font-weight: 500;
}

/* Layout overrides on capture-card */
.card-header, .card-body, .card-footer {
    position: relative;
    z-index: 2; /* Keep content above SVG background patterns */
}

/* Pattern Overlay Base */
.pattern-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    overflow: hidden;
    opacity: 0.15;
}

.pattern-overlay svg {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Highlighting tag rendering inside canvas card text */
mark.accent-highlight {
    background: var(--card-accent);
    color: #0f172a;
    padding: 2px 6px;
    border-radius: 4px;
    font-weight: 600;
}

/* Quote Layout Mode */
.brand-card.layout-quote .card-body {
    justify-content: center;
    align-items: center;
    margin: 60px 0;
}

.layout-element-quote {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 16px;
    max-width: 680px;
}

.quote-mark {
    font-size: 80px;
    font-family: 'Playfair Display', Georgia, serif;
    color: var(--card-accent);
    line-height: 0.2;
    opacity: 0.3;
}
.quote-mark.open-quote {
    margin-bottom: -15px;
}
.quote-mark.close-quote {
    margin-top: 15px;
}

.quote-text {
    font-size: calc(var(--card-title-size, 32px) * 0.8125);
    line-height: 1.5;
    font-style: italic;
    color: var(--card-text-primary);
    font-family: 'Playfair Display', serif;
}

.brand-card.layout-quote .social-badge {
    opacity: 0.7;
}

/* Metric Focus Layout Mode */
.brand-card.layout-metric .layout-element-metric {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
    width: 100%;
}

.metric-left {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 240px;
    border-right: 1px solid rgba(255, 255, 255, 0.08);
    padding-right: 20px;
}

.brand-card.theme-minimalist-light.layout-metric .metric-left {
    border-right-color: rgba(0, 0, 0, 0.08);
}

.metric-number {
    font-size: 82px;
    font-weight: 800;
    color: var(--card-accent);
    line-height: 1;
    letter-spacing: -2px;
}

.metric-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--card-text-primary);
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-top: 6px;
    text-align: center;
}

.metric-right {
    flex: 1;
}

/* Comparison Layout Mode */
.brand-card.layout-comparison .layout-element-comparison {
    display: grid;
    grid-template-columns: 1fr 1px 1fr;
    gap: 20px;
    align-items: stretch;
    width: 100%;
}

.comparison-col {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 10px;
}

.comparison-col.highlighted {
    background-color: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.04);
    border-radius: 12px;
    padding: 16px;
}

.brand-card.theme-minimalist-light .comparison-col.highlighted {
    background-color: rgba(0, 0, 0, 0.02);
    border-color: rgba(0, 0, 0, 0.04);
}

.comparison-col-title {
    font-size: calc(var(--card-title-size, 32px) * 0.5);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--card-text-primary);
}

.comparison-col.highlighted .comparison-col-title {
    color: var(--card-accent);
}

.comparison-divider {
    background-color: rgba(255, 255, 255, 0.08);
    width: 1px;
}
.brand-card.theme-minimalist-light .comparison-divider {
    background-color: rgba(0, 0, 0, 0.08);
}

.comparison-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.comparison-list li {
    font-size: calc(var(--card-content-size, 18px) * 0.7778);
    line-height: 1.4;
    color: var(--card-text-secondary);
    padding-left: 20px;
    position: relative;
}

.comparison-col li::before {
    content: "✕";
    color: var(--error-color);
    position: absolute;
    left: 0;
    top: 0;
    font-weight: 700;
}

.comparison-col.highlighted li::before {
    content: "✓";
    color: var(--card-accent);
}

/* ==========================================================================
   LINKEDIN MOCKUP OVERLAY SYSTEM
   ========================================================================== */
.mockup-overlay {
    position: fixed;
    inset: 0;
    background-color: rgba(9, 13, 22, 0.85);
    backdrop-filter: blur(10px);
    z-index: 999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.mockup-modal {
    background-color: var(--sidebar-bg);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    width: 100%;
    max-width: 680px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.8);
}

.mockup-modal-header {
    padding: 16px 24px;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: var(--panel-bg);
}

.mockup-title-area h3 {
    font-size: 16px;
    font-weight: 700;
}
.mockup-title-area p {
    font-size: 12px;
    color: var(--text-muted);
    margin-top: 2px;
}

.mockup-controls {
    display: flex;
    align-items: center;
    gap: 12px;
}

.btn-close-modal {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 28px;
    cursor: pointer;
    line-height: 1;
}
.btn-close-modal:hover {
    color: var(--text-main);
}

.mockup-viewport {
    flex: 1;
    overflow-y: auto;
    padding: 30px;
    display: flex;
    justify-content: center;
    transition: background-color 0.2s;
}

/* Light Feed styling values matching LinkedIn web app */
.mockup-viewport.light-feed {
    background-color: #f3f2ef;
}
.mockup-viewport.light-feed .mock-post {
    background-color: #ffffff;
    border: 1px solid #e0e0e0;
    color: #191919;
}
.mockup-viewport.light-feed .mock-post-name { color: rgba(0,0,0,0.9); }
.mockup-viewport.light-feed .mock-post-headline { color: rgba(0,0,0,0.6); }
.mockup-viewport.light-feed .mock-post-time { color: rgba(0,0,0,0.5); }
.mockup-viewport.light-feed .mock-post-text { color: rgba(0,0,0,0.9); }
.mockup-viewport.light-feed .mock-post-social-info { border-bottom: 1px solid #f3f2ef; color: rgba(0,0,0,0.6); }
.mockup-viewport.light-feed .mock-post-actions { color: rgba(0,0,0,0.6); }
.mockup-viewport.light-feed .mock-post-actions button:hover { background-color: rgba(0,0,0,0.08); }

/* Dark Feed styling values matching LinkedIn web app */
.mockup-viewport.dark-feed {
    background-color: #0a0e12;
}
.mockup-viewport.dark-feed .mock-post {
    background-color: #1d2226;
    border: 1px solid #2f3539;
    color: #e1e9ee;
}
.mockup-viewport.dark-feed .mock-post-name { color: #f3f6f8; }
.mockup-viewport.dark-feed .mock-post-headline { color: #b1b8be; }
.mockup-viewport.dark-feed .mock-post-time { color: #868d92; }
.mockup-viewport.dark-feed .mock-post-text { color: #e1e9ee; }
.mockup-viewport.dark-feed .mock-post-social-info { border-bottom: 1px solid #2f3539; color: #868d92; }
.mockup-viewport.dark-feed .mock-post-actions { color: #b1b8be; }
.mockup-viewport.dark-feed .mock-post-actions button:hover { background-color: rgba(255,255,255,0.08); }

/* Simulated Post Container */
.mock-post {
    width: 100%;
    max-width: 550px;
    border-radius: 8px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    height: fit-content;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

.mock-post-header {
    display: flex;
    align-items: center;
    gap: 10px;
    position: relative;
}

.mock-post-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    overflow: hidden;
    background-color: #868d92;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.mock-post-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mock-post-avatar svg {
    width: 32px;
    height: 32px;
    color: #e0e0e0;
}

.mock-post-user-info {
    display: flex;
    flex-direction: column;
    flex: 1;
}

.mock-post-name {
    font-size: 14px;
    font-weight: 600;
}

.mock-post-headline {
    font-size: 11px;
    line-height: 1.3;
    margin-top: 1px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.mock-post-time {
    font-size: 10px;
    margin-top: 2px;
}

.mock-follow-btn {
    background: none;
    border: none;
    color: #0a66c2;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 4px;
    position: absolute;
    right: 0;
    top: 0;
}

.mock-post-text {
    font-size: 13.5px;
    line-height: 1.45;
    white-space: pre-wrap;
}

.mock-post-image-slot {
    width: 100%;
    border-radius: 4px;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 1px solid rgba(0,0,0,0.05);
}

/* When preview container is in mockup, override its scaling box */
.mock-post-image-slot #preview-container {
    transform: scale(var(--mock-scale, 0.68)) !important; /* Scale visual card to fit mock slot width dynamically */
    margin: var(--mock-margin, -130px) 0 !important; /* Negate white borders caused by scaling a fixed item */
    transform-origin: center center;
}

.mock-post-social-info {
    display: flex;
    justify-content: space-between;
    font-size: 10.5px;
    padding-bottom: 8px;
}

.mock-post-actions {
    display: flex;
    justify-content: space-between;
    padding: 2px 0;
}

.mock-post-actions button {
    flex: 1;
    background: none;
    border: none;
    color: inherit;
    padding: 10px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: background-color 0.1s;
}

.action-icon {
    width: 16px;
    height: 16px;
}

/* ==========================================================================
   LEADERSHIP PILLARS LAYOUT MODE
   ========================================================================== */
.brand-card.layout-leadership .layout-element-leadership {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 20px;
    width: 100%;
}

.leadership-insight {
    font-size: calc(var(--card-title-size, 32px) * 0.625);
    font-weight: 700;
    line-height: 1.4;
    color: var(--card-text-primary);
    border-left: 4px solid var(--card-accent);
    padding-left: 16px;
    margin-bottom: 8px;
    letter-spacing: -0.2px;
}

.leadership-pillars-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.leadership-pillar-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
}

.leadership-pillar-num {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background-color: var(--card-accent-bg);
    border: 1px solid var(--card-accent);
    color: var(--card-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 13px;
    flex-shrink: 0;
    margin-top: 1px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}

.brand-card.theme-minimalist-light .leadership-pillar-num {
    background-color: rgba(0,0,0,0.05);
    border-color: #1c1917;
    color: #1c1917;
}

.leadership-pillar-text {
    font-size: calc(var(--card-content-size, 18px) * 0.8611);
    line-height: 1.5;
    color: var(--card-text-secondary);
    flex: 1;
}

.leadership-cta {
    margin-top: 12px;
    padding: 12px 18px;
    border-radius: 8px;
    background-color: rgba(255, 255, 255, 0.02);
    border-left: 3px solid var(--card-accent);
    font-style: italic;
    font-size: calc(var(--card-content-size, 18px) * 0.8056);
    line-height: 1.45;
    color: var(--card-text-primary);
}

.brand-card.theme-minimalist-light .leadership-cta {
    background-color: rgba(0, 0, 0, 0.02);
    border-left-color: #1c1917;
}

/* ==========================================================================
   THOUGHT LEADERSHIP (LONG READ) LAYOUT MODE
   ========================================================================== */
.brand-card.layout-thought .layout-element-thought {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 12px;
    width: 100%;
}

.thought-heading {
    font-size: calc(var(--card-title-size, 32px) * 0.8125);
    font-weight: 700;
    line-height: 1.35;
    color: var(--card-text-primary);
    margin-bottom: 2px;
    letter-spacing: -0.4px;
}

.thought-subheading {
    font-size: calc(var(--card-content-size, 18px) * 0.7222);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--card-accent);
    margin-bottom: 4px;
}

.brand-card.theme-minimalist-light .thought-subheading {
    color: #1c1917;
}

.thought-narrative {
    font-size: calc(var(--card-content-size, 18px) * 0.9167);
    line-height: 1.55;
    color: var(--card-text-secondary);
    margin-bottom: 8px;
    white-space: pre-line;
}

.thought-takeaway-container {
    padding: 16px 20px;
    border-radius: 8px;
    background-color: rgba(255, 255, 255, 0.025);
    border-left: 4px solid var(--card-accent);
    position: relative;
    margin-top: 10px;
}

.brand-card.theme-minimalist-light .thought-takeaway-container {
    background-color: rgba(0, 0, 0, 0.02);
    border-left-color: #1c1917;
    box-shadow: none;
}

.takeaway-badge {
    position: absolute;
    top: -8px;
    left: 20px;
    background-color: var(--card-accent);
    color: #0f172a;
    font-size: 8.5px;
    font-weight: 800;
    padding: 2px 8px;
    border-radius: 4px;
    letter-spacing: 0.5px;
}

.brand-card.theme-minimalist-light .takeaway-badge {
    background-color: #1c1917;
    color: #fafaf9;
}

.thought-takeaway {
    font-size: calc(var(--card-content-size, 18px) * 0.8056);
    font-weight: 500;
    line-height: 1.45;
    color: var(--card-text-primary);
}

/* Custom Presets Style Panel */
.custom-presets-manager {
    border-top: 1px dashed var(--border-color);
    padding-top: 16px;
    margin-top: 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.preset-save-row {
    display: flex;
    gap: 8px;
}

.preset-save-row input {
    flex: 1;
    min-width: 0;
}

.preset-save-row button {
    background-color: var(--accent-color);
    color: #0f172a;
    border: none;
    padding: 10px 14px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    transition: background-color 0.2s;
}

.preset-save-row button:hover {
    background-color: var(--accent-hover);
}

.presets-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-height: 140px;
    overflow-y: auto;
    padding-right: 4px;
}

.preset-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: var(--input-bg);
    border: 1px solid var(--border-color);
    padding: 6px 10px;
    border-radius: 8px;
    gap: 10px;
}

.preset-item span {
    font-size: 13px;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--text-main);
}

.preset-item-actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

.preset-btn-load,
.preset-btn-delete {
    border: none;
    padding: 4px 8px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s;
}

.preset-btn-load {
    background-color: var(--panel-bg);
    color: var(--text-main);
    border: 1px solid var(--border-color);
}
.preset-btn-load:hover {
    border-color: var(--text-muted);
}

.preset-btn-delete {
    background-color: rgba(239, 68, 68, 0.1);
    color: var(--error-color);
    border: 1px solid rgba(239, 68, 68, 0.15);
}
.preset-btn-delete:hover {
    background-color: var(--error-color);
    color: #ffffff;
}

/* ==========================================================================
   GOOGLE DRIVE CLOUD SYNC UI STYLING
   ========================================================================== */
.sync-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-left: auto;
    margin-right: 12px;
    transition: background-color 0.3s, box-shadow 0.3s;
}
.sync-status-dot.disconnected {
    background-color: var(--error-color);
    box-shadow: 0 0 8px var(--error-color);
}
.sync-status-dot.connected {
    background-color: var(--accent-color);
    box-shadow: 0 0 8px var(--accent-color);
    animation: pulse-sync-connected 2s infinite;
}
.sync-status-dot.saving {
    background-color: #3b82f6;
    box-shadow: 0 0 10px #3b82f6;
    animation: pulse-sync-saving 1s infinite linear;
}

@keyframes pulse-sync-connected {
    0% {
        transform: scale(1);
        box-shadow: 0 0 8px var(--accent-color);
    }
    50% {
        transform: scale(1.2);
        box-shadow: 0 0 16px var(--accent-color);
    }
    100% {
        transform: scale(1);
        box-shadow: 0 0 8px var(--accent-color);
    }
}

@keyframes pulse-sync-saving {
    0% {
        transform: scale(1);
        box-shadow: 0 0 8px #3b82f6;
    }
    50% {
        transform: scale(1.3);
        box-shadow: 0 0 18px #3b82f6;
    }
    100% {
        transform: scale(1);
        box-shadow: 0 0 8px #3b82f6;
    }
}

.password-input-wrapper {
    position: relative;
    display: flex;
    width: 100%;
}
.password-input-wrapper input {
    width: 100%;
    padding-right: 40px !important;
}
.btn-toggle-visibility {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    font-size: 14px;
    color: var(--text-muted);
    padding: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    outline: none;
}
.btn-toggle-visibility:hover {
    color: var(--text-main);
}

.btn-gdrive-auth {
    width: 100%;
    background-color: #ffffff;
    color: #1f2937;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: all 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    font-family: var(--font-sans);
}
.btn-gdrive-auth:hover {
    background-color: #f9fafb;
    border-color: #9ca3af;
    transform: translateY(-1px);
}
.btn-gdrive-auth svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.gdrive-user-profile {
    display: flex;
    align-items: center;
    gap: 12px;
    background-color: var(--input-bg);
    border: 1px solid var(--border-color);
    padding: 10px 14px;
    border-radius: 8px;
    width: 100%;
}
.gdrive-user-profile .user-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    border: 1.5px solid var(--accent-color);
}
.gdrive-user-profile .user-info {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
}
.gdrive-user-profile .user-name {
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--text-main);
}
.gdrive-user-profile .user-status {
    font-size: 11px;
    font-weight: 500;
}
.text-success {
    color: var(--accent-color);
}

.btn-disconnect {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 14px;
    cursor: pointer;
    padding: 4px;
    transition: color 0.2s;
    outline: none;
}
.btn-disconnect:hover {
    color: var(--error-color);
}

.workspace-save-row {
    display: flex;
    gap: 8px;
    width: 100%;
}
.workspace-save-row input {
    flex: 1;
    min-width: 0;
}
.workspace-save-row button {
    background-color: var(--accent-color);
    color: #0f172a;
    border: none;
    padding: 10px 14px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    transition: background-color 0.2s;
}
.workspace-save-row button:hover {
    background-color: var(--accent-hover);
}

.cloud-drafts-section {
    border-top: 1px dashed var(--border-color);
    padding-top: 14px;
    margin-top: 6px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.gdrive-drafts-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-height: 160px;
    overflow-y: auto;
    padding-right: 4px;
}

/* ==========================================================================
   CAROUSEL EXPORT BUTTONS & PROGRESS / SWIPE INDICATORS
   ========================================================================== */

.btn-outline {
    background: transparent;
    border: 2px solid var(--border-color);
    color: var(--text-main);
    padding: 12px 20px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: all 0.2s;
}
.btn-outline:hover {
    background: rgba(255, 255, 255, 0.04);
    color: var(--text-bright);
    border-color: var(--text-muted);
    transform: translateY(-2px);
}
.btn-outline svg {
    color: var(--text-muted);
}

/* Progress Indicator */
.slide-progress-indicator {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 10;
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
}

/* Thin Line Progress Bar */
.slide-progress-indicator.type-line {
    height: 6px;
    background-color: rgba(255, 255, 255, 0.08);
}
.slide-progress-indicator.type-line .progress-bar-fill {
    height: 100%;
    width: 0%;
    background: var(--border-color, var(--primary-accent, #06B6D4));
    align-self: flex-start;
    transition: width 0.3s ease;
}

/* Dots Progress Bar */
.slide-progress-indicator.type-dots {
    height: 24px;
    top: 10px;
    gap: 8px;
}
.slide-progress-indicator.type-dots .progress-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.2);
    transition: background-color 0.3s ease, transform 0.2s;
}
.slide-progress-indicator.type-dots .progress-dot.active {
    background-color: var(--border-color, var(--primary-accent, #06B6D4));
    box-shadow: 0 0 8px var(--border-color, var(--primary-accent, #06B6D4));
    transform: scale(1.2);
}

/* Numbers Progress Bar */
.slide-progress-indicator.type-numbers {
    height: 24px;
    top: 10px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.05em;
    color: var(--text-muted);
}

/* Swipe Indicator Badge */
.swipe-indicator {
    position: absolute;
    right: 48px;
    bottom: 96px; /* Positioned floating right, above the footer */
    display: flex;
    align-items: center;
    gap: 6px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.12);
    padding: 8px 14px;
    border-radius: 30px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--border-color, var(--primary-accent, #06B6D4));
    z-index: 10;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    transition: opacity 0.3s ease;
}
.swipe-icon {
    width: 14px;
    height: 14px;
}

/* Theme Light Mode Modifier Rules */
.brand-card.theme-minimalist-light .slide-progress-indicator.type-line {
    background-color: rgba(0, 0, 0, 0.06);
}
.brand-card.theme-minimalist-light .slide-progress-indicator.type-line .progress-bar-fill {
    background-color: var(--text-bright, #000);
}
.brand-card.theme-minimalist-light .slide-progress-indicator.type-dots .progress-dot {
    background-color: rgba(0, 0, 0, 0.15);
}
.brand-card.theme-minimalist-light .slide-progress-indicator.type-dots .progress-dot.active {
    background-color: var(--text-bright, #000);
    box-shadow: none;
}
.brand-card.theme-minimalist-light .slide-progress-indicator.type-numbers {
    color: rgba(0, 0, 0, 0.4);
}
.brand-card.theme-minimalist-light .swipe-indicator {
    background: rgba(0, 0, 0, 0.03);
    border: 1px solid rgba(0, 0, 0, 0.08);
    color: var(--text-bright, #000);
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

/* ==========================================================================
   LIVE CANVAS INLINE EDITING STYLES
   ========================================================================== */
[contenteditable="true"] {
    outline: none;
    cursor: text;
    transition: background-color 0.2s ease, outline-color 0.2s ease, box-shadow 0.2s ease;
    border-radius: 4px;
    position: relative;
}

[contenteditable="true"]:hover {
    outline: 1.5px dashed var(--card-accent, #06B6D4);
    outline-offset: 3px;
    background-color: var(--card-accent-bg, rgba(6, 182, 212, 0.08));
}

[contenteditable="true"]:focus {
    outline: 2px solid var(--card-accent, #06B6D4);
    outline-offset: 3px;
    background-color: var(--card-accent-bg, rgba(6, 182, 212, 0.15));
}

/* Specific overlay adjustments for light theme inline edits */
.brand-card.theme-minimalist-light [contenteditable="true"]:hover {
    outline-color: var(--card-accent, #1c1917);
    background-color: rgba(28, 25, 23, 0.04);
}

.brand-card.theme-minimalist-light [contenteditable="true"]:focus {
    outline-color: var(--card-accent, #1c1917);
    background-color: rgba(28, 25, 23, 0.08);
}

/* Prevent empty contenteditable fields from disappearing/collapsing */
[contenteditable="true"]:empty:not(:focus)::before {
    content: "Type to edit...";
    color: var(--card-text-secondary, #cbd5e1);
    opacity: 0.6;
    font-style: italic;
}

.brand-card.theme-minimalist-light [contenteditable="true"]:empty:not(:focus)::before {
    color: var(--card-text-secondary, #57534e);
}

/* ==========================================================================
   AI ASSISTANT LOADING STATE AND ANIMATIONS
   ========================================================================== */
@keyframes ai-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.btn-ai-icon.spinning {
    animation: ai-spin 1.2s linear infinite;
}

#btn-generate-ai.loading {
    opacity: 0.85;
    cursor: not-allowed;
    background: linear-gradient(135deg, #06B6D4 0%, #3730A3 100%);
}

/* AI Proofreader Results Container */
.proofread-container {
    background-color: var(--input-bg);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 12px;
    font-size: 13px;
    margin-bottom: 15px;
    max-height: 300px;
    overflow-y: auto;
}

.proofread-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
    font-weight: 600;
    color: var(--text-main);
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 6px;
}

.proofread-header span {
    display: flex;
    align-items: center;
    gap: 6px;
}

.proofread-close {
    cursor: pointer;
    color: var(--text-muted);
    font-size: 16px;
    border: none;
    background: none;
    padding: 0 4px;
    line-height: 1;
}

.proofread-close:hover {
    color: var(--text-main);
}

.proofread-item {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 8px 10px;
    margin-bottom: 8px;
}

.proofread-item:last-child {
    margin-bottom: 0;
}

.proofread-item-field {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--card-accent, #06B6D4);
    margin-bottom: 4px;
}

.proofread-item-diff {
    margin-bottom: 6px;
    font-size: 12.5px;
    line-height: 1.4;
}

.proofread-original {
    text-decoration: line-through;
    color: #ef4444;
    margin-right: 6px;
    white-space: pre-wrap;
}

.proofread-corrected {
    color: #06B6D4;
    font-weight: 600;
    white-space: pre-wrap;
}

.proofread-reason {
    font-size: 11px;
    color: var(--text-muted);
    font-style: italic;
    margin-bottom: 6px;
}

.proofread-actions {
    display: flex;
    gap: 6px;
    justify-content: flex-end;
}

.proofread-btn-apply {
    background: #06B6D4;
    color: #0f172a;
    border: none;
    padding: 3px 8px;
    font-size: 11px;
    border-radius: 4px;
    cursor: pointer;
    font-weight: 600;
    transition: background 0.2s;
}

.proofread-btn-apply:hover {
    background: #34d399;
}

.proofread-empty {
    color: #06B6D4;
    text-align: center;
    padding: 10px 0;
    font-weight: 500;
}

.proofread-status-msg {
    color: var(--text-muted);
    font-size: 11px;
    text-align: center;
    padding: 6px 0;
}

/* Visual Layout Grid Selector */
.layout-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-top: 8px;
}

.layout-card {
    background-color: var(--input-bg);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 8px 4px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: center;
    color: var(--text-muted);
    user-select: none;
}

.layout-card:hover {
    border-color: var(--text-muted);
    background-color: rgba(255, 255, 255, 0.02);
}

.layout-card.active {
    border-color: #06B6D4;
    background-color: rgba(6, 182, 212, 0.08);
    color: var(--text-main);
    box-shadow: 0 0 8px rgba(6, 182, 212, 0.15);
}

.layout-icon {
    width: 32px;
    height: 24px;
    color: inherit;
    display: block;
    transition: transform 0.2s;
}

.layout-card:hover .layout-icon {
    transform: scale(1.05);
}

.layout-card span {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

/* Drag and Drop Tab Feedback */
.slide-tab.dragging {
    opacity: 0.4;
    border: 1px dashed #06B6D4 !important;
}

.slide-tab.drag-over {
    border-color: #06B6D4 !important;
    background-color: rgba(6, 182, 212, 0.05) !important;
    transform: translateY(-2px);
}

/* Brand Watermarks */
.card-watermark {
    position: absolute;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--card-text-primary);
    pointer-events: none;
    z-index: 10;
    white-space: nowrap;
    user-select: none;
    transition: opacity 0.3s;
}

.card-watermark.pos-top-right {
    top: calc(var(--card-padding) / 1.5);
    right: var(--card-padding);
}

.card-watermark.pos-bottom-left {
    bottom: calc(var(--card-padding) / 1.5);
    left: var(--card-padding);
}

.card-watermark.pos-bottom-right {
    bottom: calc(var(--card-padding) / 1.5);
    right: var(--card-padding);
}

/* Suggested Hashtag Badges */
.hashtag-badge {
    font-size: 11px;
    padding: 4px 8px;
    border-radius: 6px;
    background: var(--input-bg);
    border: 1px solid var(--border-color);
    color: var(--text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
    user-select: none;
    font-weight: 500;
}
.hashtag-badge:hover {
    border-color: var(--text-main);
    color: var(--text-main);
}
.hashtag-badge.active {
    background-color: var(--card-accent-bg);
    border-color: var(--card-accent);
    color: var(--card-accent);
}

/* Hook Option Styling */
.hook-option-item {
    font-size: 11.5px;
    line-height: 1.4;
    padding: 8px 10px;
    background-color: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    cursor: pointer;
    color: var(--text-main);
    transition: all 0.2s;
}
.hook-option-item:hover {
    border-color: var(--card-accent);
    background-color: rgba(6, 182, 212, 0.05);
}

/* Login Overlay Styling */
.login-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(15, 23, 42, 0.95);
    backdrop-filter: blur(8px);
    z-index: 10000;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: opacity 0.3s ease;
}

.login-overlay.hidden {
    opacity: 0;
    pointer-events: none;
}

.login-box {
    background: rgba(30, 41, 59, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    padding: 40px;
    width: 100%;
    max-width: 400px;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.5), 0 10px 10px -5px rgba(0, 0, 0, 0.5);
    text-align: center;
    box-sizing: border-box;
}

.login-header {
    margin-bottom: 30px;
}

.login-logo {
    width: 48px;
    height: 48px;
    color: #06B6D4;
    margin-bottom: 15px;
}

.login-header h2 {
    font-size: 24px;
    font-weight: 700;
    margin: 0 0 8px 0;
    color: #f8fafc;
    font-family: 'Outfit', sans-serif;
}

.login-header p {
    font-size: 14px;
    color: #94a3b8;
    margin: 0;
}

.login-buttons {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.btn-login {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 12px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    font-family: 'Inter', sans-serif;
}

.btn-login.google {
    background: #ffffff;
    color: #1f2937;
    border: none;
}

.btn-login.google:hover {
    background: #f3f4f6;
}

.btn-login.apple {
    background: #000000;
    color: #ffffff;
    border: none;
}

.btn-login.apple:hover {
    background: #111827;
}

.btn-login.guest {
    background: transparent;
    color: #94a3b8;
    border: 1px dashed rgba(255, 255, 255, 0.2);
}

.btn-login.guest:hover {
    background: rgba(255, 255, 255, 0.05);
    color: #f8fafc;
}

.btn-login.offline {
    background: rgba(30, 41, 59, 0.5);
    color: #94a3b8;
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.btn-login.offline:hover {
    background: rgba(30, 41, 59, 0.8);
    border-color: rgba(255, 255, 255, 0.15);
    color: #f8fafc;
}

.login-separator {
    font-size: 13px;
    color: #64748b;
    margin: 8px 0;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-separator::before,
.login-separator::after {
    content: '';
    flex-grow: 1;
    height: 1px;
    background: rgba(255, 255, 255, 0.08);
    margin: 0 10px;
}

/* Paywall overlay styling */
.paywall-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(15, 23, 42, 0.95);
    backdrop-filter: blur(8px);
    z-index: 9999;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: opacity 0.3s ease;
}

.paywall-overlay.hidden {
    opacity: 0;
    pointer-events: none;
}

.paywall-box {
    background: rgba(30, 41, 59, 0.7);
    border: 1px solid rgba(6, 182, 212, 0.3);
    border-radius: 16px;
    padding: 40px;
    width: 100%;
    max-width: 450px;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.5), 0 10px 10px -5px rgba(0, 0, 0, 0.5);
    text-align: center;
    box-sizing: border-box;
}

.paywall-crown {
    font-size: 40px;
    margin-bottom: 15px;
    display: inline-block;
}

.paywall-box h2 {
    font-size: 26px;
    font-weight: 700;
    margin: 0 0 8px 0;
    color: #f8fafc;
    font-family: 'Outfit', sans-serif;
}

.paywall-box p {
    font-size: 14px;
    color: #94a3b8;
    margin-bottom: 25px;
}

.paywall-features {
    text-align: left;
    margin-bottom: 30px;
    padding: 0 10px;
}

.paywall-feature-item {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
    font-size: 14px;
    color: #e2e8f0;
}

.paywall-feature-item svg {
    color: #06B6D4;
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.paywall-plans {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 20px;
}

.paywall-plan-option {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.2s;
    text-align: left;
}

.paywall-plan-option:hover,
.paywall-plan-option.selected {
    background: rgba(6, 182, 212, 0.05);
    border-color: #06B6D4;
}

.paywall-plan-details h4 {
    margin: 0 0 4px 0;
    font-size: 15px;
    color: #f8fafc;
}

.paywall-plan-details p {
    margin: 0;
    font-size: 12px;
    color: #94a3b8;
}

.paywall-plan-price {
    font-size: 16px;
    font-weight: 700;
    color: #06B6D4;
}

.btn-subscribe {
    background: #06B6D4;
    color: #0f172a;
    width: 100%;
    padding: 14px;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    border: none;
    transition: background 0.2s;
}

.btn-subscribe:hover {
    background: #0891B2;
}

.paywall-close-link {
    display: block;
    margin-top: 15px;
    font-size: 13px;
    color: #64748b;
    text-decoration: underline;
    cursor: pointer;
}

.paywall-close-link:hover {
    color: #94a3b8;
}

/* Bottom Navigation and Drawer defaults (hidden by default) */
.drawer-handle-bar {
    display: none !important;
}
.mobile-bottom-nav {
    display: none !important;
}
.mobile-top-header {
    display: none !important;
}

/* ==========================================================================
   PHONE BOTTOM-SHEET DRAWER & NAVIGATION SYSTEM (Viewport < 600px)
   ========================================================================== */
@media (max-width: 600px) {
    body {
        height: 100vh !important;
        overflow: hidden !important;
    }

    .app-container {
        flex-direction: column !important;
        height: 100vh !important;
        width: 100vw !important;
        overflow: hidden !important;
    }

    /* Mobile Pinned Top Header */
    .mobile-top-header {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        width: 100% !important;
        height: 50px !important;
        background-color: var(--sidebar-bg) !important;
        border-bottom: 1px solid var(--border-color) !important;
        padding: 0 16px !important;
        flex-shrink: 0 !important;
        z-index: 1001 !important;
        box-sizing: border-box !important;
        font-family: var(--font-sans) !important;
    }

    .mobile-top-header .logo-area {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
    }

    .mobile-top-header .app-logo {
        width: 24px !important;
        height: 24px !important;
        color: var(--accent-color) !important;
    }

    .mobile-top-header .logo-area h1 {
        font-size: 16px !important;
        font-weight: 700 !important;
        background: linear-gradient(135deg, #06B6D4 0%, #3730A3 100%) !important;
        -webkit-background-clip: text !important;
        -webkit-text-fill-color: transparent !important;
        letter-spacing: -0.5px !important;
        margin: 0 !important;
    }

    .mobile-top-header .badge {
        font-size: 10px !important;
        padding: 2px 8px !important;
        background-color: rgba(6, 182, 212, 0.1) !important;
        color: var(--accent-color) !important;
        border: 1px solid rgba(6, 182, 212, 0.2) !important;
        border-radius: 9999px !important;
        font-weight: 600 !important;
    }

    /* Pinned Slide Tabs Swapper at the top of mobile screen */
    .preview-pane .slide-tabs-row {
        width: calc(100% - 16px) !important;
        margin: 4px 8px 12px 8px !important;
        background-color: rgba(15, 23, 42, 0.6) !important;
        backdrop-filter: blur(12px) !important;
        -webkit-backdrop-filter: blur(12px) !important;
        border: 1px solid var(--border-color) !important;
        border-radius: 10px !important;
        padding: 6px 10px !important;
        z-index: 10 !important;
        flex-shrink: 0 !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
        box-sizing: border-box !important;
    }

    /* Fixed Bottom Nav Bar */
    .mobile-bottom-nav {
        display: flex !important;
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: calc(60px + env(safe-area-inset-bottom)) !important;
        background-color: rgba(15, 23, 42, 0.96) !important;
        backdrop-filter: blur(16px) !important;
        -webkit-backdrop-filter: blur(16px) !important;
        border-top: 1px solid var(--border-color) !important;
        z-index: 1001 !important;
        justify-content: space-around !important;
        align-items: center !important;
        box-sizing: border-box !important;
        padding: 0 8px env(safe-area-inset-bottom) 8px !important;
        box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.4) !important;
    }

    .nav-tab-btn {
        flex: 1 !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 3px !important;
        background: none !important;
        border: none !important;
        color: var(--text-muted) !important;
        font-size: 9px !important;
        font-weight: 700 !important;
        cursor: pointer !important;
        height: 100% !important;
        transition: all 0.2s ease !important;
        outline: none !important;
        padding: 4px 0 !important;
        font-family: var(--font-sans) !important;
        text-transform: uppercase !important;
        letter-spacing: 0.3px !important;
    }

    .nav-tab-btn .nav-icon {
        width: 18px !important;
        height: 18px !important;
        color: var(--text-muted) !important;
        transition: color 0.2s ease !important;
    }

    .nav-tab-btn.active {
        color: var(--accent-color) !important;
    }

    .nav-tab-btn.active .nav-icon {
        color: var(--accent-color) !important;
    }

    /* Floating Sliding Bottom Sheet (Drawer) */
    .sidebar {
        position: fixed !important;
        bottom: 60px !important; /* Pinned directly above bottom navigation bar */
        left: 0 !important;
        width: 100% !important;
        height: 62vh !important;
        transform: translateY(115%) !important; /* Slide down off-screen */
        z-index: 1000 !important;
        border-radius: 20px 20px 0 0 !important;
        border-top: 1px solid var(--border-color) !important;
        border-right: none !important;
        border-left: none !important;
        border-bottom: none !important;
        box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.6) !important;
        transition: transform 0.3s cubic-bezier(0.1, 0.76, 0.55, 0.94) !important;
        background-color: var(--sidebar-bg) !important;
        max-height: none !important;
        overflow: hidden !important;
        display: flex !important;
        flex-direction: column !important;
    }

    .sidebar.drawer-open {
        transform: translateY(0) !important; /* Slide up into view */
    }

    /* Drawer Top Handle Bar */
    .drawer-handle-bar {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        height: 36px !important;
        padding: 10px 16px !important;
        cursor: pointer !important;
        position: relative !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
        background-color: rgba(255, 255, 255, 0.01) !important;
        flex-shrink: 0 !important;
    }

    .drawer-handle-indicator {
        width: 36px !important;
        height: 4px !important;
        background-color: var(--border-color) !important;
        border-radius: 2px !important;
        opacity: 0.8 !important;
    }

    .btn-close-drawer {
        position: absolute !important;
        right: 16px !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        background: none !important;
        border: none !important;
        color: var(--text-muted) !important;
        font-size: 24px !important;
        cursor: pointer !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 24px !important;
        height: 24px !important;
        outline: none !important;
    }

    .btn-close-drawer:hover {
        color: var(--text-main) !important;
    }

    /* Hide standard sidebar header on phone drawers to maximize input space */
    .sidebar .sidebar-header {
        display: none !important;
    }

    /* Compact scrollable controls area */
    .sidebar .controls-wrapper {
        flex: 1 !important;
        min-height: 0 !important;
        overflow-y: auto !important;
        padding: 12px 16px 24px 16px !important;
        gap: 12px !important;
    }

    /* Compact sidebar footer inside drawer */
    .sidebar .sidebar-footer {
        padding: 14px 16px 24px 16px !important;
        margin-top: auto !important;
        background-color: rgba(15, 23, 42, 0.98) !important;
        border-top: 1px solid var(--border-color) !important;
        z-index: 10 !important;
    }

    /* Preview pane fills available viewport */
    .preview-pane {
        padding: 12px !important;
        height: calc(100vh - 110px) !important; /* Subtract mobile header (50px) and bottom nav (60px) */
        min-height: auto !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        justify-content: center !important;
        box-sizing: border-box !important;
    }

    .preview-header {
        margin-bottom: 12px !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 4px !important;
    }
    
    .preview-header h2 {
        font-size: 16px !important;
    }

    .preview-header p {
        font-size: 11px !important;
        display: none !important; /* Hide long description text on mobile */
    }

    /* Mobile active tab visibility logic */
    .sidebar[data-active-tab] .control-section {
        display: none !important;
    }

    .sidebar[data-active-tab] .sidebar-footer {
        display: none !important;
    }

    .sidebar[data-active-tab="content"] #section-branding,
    .sidebar[data-active-tab="content"] #section-slides,
    .sidebar[data-active-tab="content"] #section-signature {
        display: block !important;
    }

    .sidebar[data-active-tab="style"] #section-theme {
        display: block !important;
    }

    .sidebar[data-active-tab="ai"] #section-ai-generator,
    .sidebar[data-active-tab="ai"] #section-caption-generator {
        display: block !important;
    }

    .sidebar[data-active-tab="export"] .sidebar-footer {
        display: flex !important;
    }
}

/* ==========================================================================
   CLOUD SYNC STATUS BUTTON & PULSING STATUS INDICATORS
   ========================================================================== */
.cloud-status-btn {
    background: none;
    border: none;
    padding: 6px;
    cursor: pointer;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted, #94a3b8);
    transition: color 0.2s, background-color 0.2s;
    border-radius: 50%;
}

.cloud-status-btn:hover {
    color: var(--text-main, #f8fafc);
    background-color: rgba(255, 255, 255, 0.05);
}

.cloud-status-btn .cloud-icon {
    width: 20px;
    height: 20px;
}

/* Pulsing Status Dot */
.cloud-status-dot {
    position: absolute;
    bottom: 2px;
    right: 2px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: 1.5px solid #090d16;
    transition: background-color 0.3s;
}

.cloud-status-dot.connected {
    background-color: #06B6D4;
    box-shadow: 0 0 0 0 rgba(6, 182, 212, 0.7);
    animation: pulse-green 1.5s infinite;
}

.cloud-status-dot.connected-guest {
    background-color: #fbbf24;
    box-shadow: 0 0 0 0 rgba(251, 191, 36, 0.7);
    animation: pulse-orange 1.5s infinite;
}

.cloud-status-dot.disconnected {
    background-color: #ef4444;
    box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.7);
    animation: pulse-red 1.5s infinite;
}

/* Pulsing Animations */
@keyframes pulse-green {
    0% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(6, 182, 212, 0.7);
    }
    70% {
        transform: scale(1);
        box-shadow: 0 0 0 5px rgba(6, 182, 212, 0);
    }
    100% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(6, 182, 212, 0);
    }
}

@keyframes pulse-orange {
    0% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(251, 191, 36, 0.7);
    }
    70% {
        transform: scale(1);
        box-shadow: 0 0 0 5px rgba(251, 191, 36, 0);
    }
    100% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(251, 191, 36, 0);
    }
}

@keyframes pulse-red {
    0% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.7);
    }
    70% {
        transform: scale(1);
        box-shadow: 0 0 0 5px rgba(239, 68, 68, 0);
    }
    100% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(239, 68, 68, 0);
    }
}

/* Popover Profile Overlay */
.cloud-profile-popover {
    position: absolute;
    z-index: 10000;
    width: 250px;
    background: rgba(15, 23, 42, 0.95);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.6), 0 8px 10px -6px rgba(0, 0, 0, 0.6);
    padding: 16px;
    color: var(--text-main, #f8fafc);
    box-sizing: border-box;
}

.cloud-profile-popover.hidden {
    display: none;
}

/* Popover Content Details */
.cloud-profile-popover .user-info-row {
    margin-bottom: 12px;
}

.cloud-profile-popover .user-name {
    font-size: 13.5px;
    font-weight: 600;
    color: var(--text-main, #f8fafc);
    display: block;
    word-break: break-all;
}

.cloud-profile-popover .user-status {
    font-size: 11.5px;
    color: #06B6D4;
    display: block;
    margin-top: 4px;
}

.cloud-profile-popover .btn-disconnect-popover {
    width: 100%;
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.2);
    color: #fca5a5;
    padding: 8px 12px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    transition: all 0.2s;
    text-align: center;
}

.cloud-profile-popover .btn-disconnect-popover:hover {
    background: rgba(239, 68, 68, 0.2);
    border-color: rgba(239, 68, 68, 0.3);
}

.cloud-profile-popover .btn-primary-popover {
    width: 100%;
    background: linear-gradient(135deg, #06B6D4 0%, #3730A3 100%);
    border: none;
    color: white;
    padding: 8px 12px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 12.5px;
    font-weight: 600;
    transition: opacity 0.2s;
    text-align: center;
}

.cloud-profile-popover .btn-primary-popover:hover {
    opacity: 0.9;
}

/* ==========================================================================
   VIEW SWITCHING & GENERAL PANEL SETTINGS
   ========================================================================== */
.view-panel {
    width: 100%;
    height: 100%;
    transition: opacity 0.25s ease, transform 0.25s ease;
    box-sizing: border-box;
}

.view-panel.hidden {
    display: none !important;
    opacity: 0;
    transform: scale(0.98);
}

#view-editor {
    display: flex;
    flex-direction: row;
    height: 100%;
    width: 100%;
}

/* ==========================================================================
   DASHBOARD HUB STYLING
   ========================================================================== */
#view-dashboard {
    background-color: var(--app-bg, #0F172A);
    overflow-y: auto;
    padding: 40px 24px;
    display: flex;
    justify-content: center;
    box-sizing: border-box;
    width: 100%;
}

.dashboard-container {
    max-width: 1100px;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 32px;
}

/* Hero Section */
.dashboard-hero {
    display: flex;
    flex-direction: column;
    gap: 8px;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 24px;
}

.hero-logo-row {
    display: flex;
    align-items: center;
    gap: 16px;
}

.db-logo {
    width: 44px;
    height: 44px;
    filter: drop-shadow(0 0 12px rgba(6, 182, 212, 0.4));
}

.dashboard-hero h1 {
    font-size: 32px;
    font-weight: 800;
    margin: 0;
    background: linear-gradient(135deg, #06B6D4 0%, #3730A3 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-family: 'Outfit', sans-serif;
}

.hero-subtitle {
    color: var(--text-muted, #94a3b8);
    font-size: 16px;
    margin: 0;
    line-height: 1.5;
}

/* Responsive Grid */
.dashboard-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    width: 100%;
}

.dashboard-col {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

/* Glassmorphic Cards */
.dashboard-card {
    background: rgba(30, 41, 59, 0.3);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(6, 182, 212, 0.1);
    border-radius: 16px;
    padding: 24px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.card-header-icon {
    display: flex;
    align-items: center;
    gap: 12px;
    color: #06B6D4;
}

.card-header-icon svg {
    filter: drop-shadow(0 0 4px rgba(6, 182, 212, 0.4));
}

.card-header-icon h3 {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-main, #f8fafc);
    margin: 0;
    font-family: 'Outfit', sans-serif;
}

.card-body {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.card-desc {
    color: var(--text-muted, #94a3b8);
    font-size: 13.5px;
    margin: 0;
    line-height: 1.5;
}

/* Forms and Inputs */
.db-form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.db-form-group label {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--text-muted, #94a3b8);
}

.db-form-group input[type="text"] {
    background: rgba(15, 23, 42, 0.6);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-main, #f8fafc);
    padding: 10px 14px;
    font-size: 14px;
    transition: all 0.2s;
    width: 100%;
    box-sizing: border-box;
}

.db-form-group input[type="text"]:focus {
    outline: none;
    border-color: #06B6D4;
    box-shadow: 0 0 8px rgba(6, 182, 212, 0.25);
}

.db-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}



/* Custom Swatches Grid */
.swatches-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 12px;
    margin-bottom: 8px;
}

.theme-swatch {
    background: rgba(15, 23, 42, 0.4);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
}

.theme-swatch:hover {
    border-color: #06B6D4;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(6, 182, 212, 0.15);
}

.swatch-preview-circle {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.swatch-accent-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: 1px solid white;
}

.swatch-name {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-main, #f8fafc);
    text-align: center;
    max-width: 90px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.btn-delete-swatch {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: rgba(239, 68, 68, 0.2);
    border: 1px solid rgba(239, 68, 68, 0.3);
    color: #fca5a5;
    font-size: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.2s;
}

.theme-swatch:hover .btn-delete-swatch {
    opacity: 1;
}

.btn-delete-swatch:hover {
    background: rgba(239, 68, 68, 0.6);
    color: white;
}

/* Avatar Row Styles */
.db-avatar-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
    background: rgba(15, 23, 42, 0.4);
    padding: 12px;
    border-radius: 8px;
    border: 1px solid var(--border-color);
    width: 100%;
    box-sizing: border-box;
}

.db-avatar-preview-container {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(6, 182, 212, 0.1);
    border: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.db-avatar-preview-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.db-avatar-preview-container span {
    font-size: 24px;
}

.btn-avatar-upload {
    background: var(--border-color);
    border: 1px solid var(--border-color);
    color: var(--text-main, #f8fafc);
    padding: 8px 16px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    transition: all 0.2s;
}

.btn-avatar-upload:hover {
    background: rgba(255, 255, 255, 0.15);
}

/* Auth Profile Widget */
.user-profile-widget {
    display: flex;
    align-items: center;
    gap: 16px;
    background: rgba(6, 182, 212, 0.05);
    border: 1px solid rgba(6, 182, 212, 0.15);
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 12px;
}

.user-avatar-placeholder {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, #06B6D4 0%, #3730A3 100%);
    color: white;
    font-size: 20px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.user-details-widget {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.user-email-text {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-main, #f8fafc);
    word-break: break-all;
}

.user-badge {
    font-size: 11px;
    background: rgba(6, 182, 212, 0.2);
    color: #22d3ee;
    padding: 2px 8px;
    border-radius: 4px;
    font-weight: 600;
    align-self: flex-start;
}

/* Buttons */
.btn-primary-db {
    background: linear-gradient(135deg, #06B6D4 0%, #3730A3 100%);
    color: white;
    border: none;
    padding: 11px 20px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    text-align: center;
}

.btn-primary-db:hover {
    transform: translateY(-2px) scale(1.025);
    box-shadow: 0 8px 20px rgba(6, 182, 212, 0.4), 0 0 12px rgba(6, 182, 212, 0.2);
    opacity: 0.98;
}

.btn-primary-db:active {
    transform: translateY(0) scale(1);
    box-shadow: 0 4px 10px rgba(6, 182, 212, 0.2);
}

.btn-secondary-db {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--border-color);
    color: var(--text-main, #f8fafc);
    padding: 10px 20px;
    border-radius: 8px;
    font-size: 13.5px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    text-align: center;
}

.btn-secondary-db:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.25);
    transform: translateY(-2px) scale(1.025);
    box-shadow: 0 8px 20px rgba(255, 255, 255, 0.08), 0 0 12px rgba(255, 255, 255, 0.04);
}

.btn-secondary-db:active {
    transform: translateY(0) scale(1);
    box-shadow: 0 4px 10px rgba(255, 255, 255, 0.03);
}

.btn-danger-db {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.2);
    color: #fca5a5;
    padding: 10px 20px;
    border-radius: 8px;
    font-size: 13.5px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    text-align: center;
}

.btn-danger-db:hover {
    background: rgba(239, 68, 68, 0.2);
    border-color: rgba(239, 68, 68, 0.35);
    transform: translateY(-2px) scale(1.025);
    box-shadow: 0 8px 20px rgba(239, 68, 68, 0.25), 0 0 12px rgba(239, 68, 68, 0.1);
}

.btn-danger-db:active {
    transform: translateY(0) scale(1);
    box-shadow: 0 4px 10px rgba(239, 68, 68, 0.15);
}

.btn-upgrade-db {
    background: linear-gradient(135deg, #fbbf24 0%, #d97706 100%);
    color: #1e1b4b;
    border: none;
    padding: 11px 20px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    text-align: center;
    box-shadow: 0 4px 12px rgba(251, 191, 36, 0.2);
}

.btn-upgrade-db:hover {
    transform: translateY(-2px) scale(1.025);
    box-shadow: 0 8px 20px rgba(251, 191, 36, 0.45), 0 0 12px rgba(251, 191, 36, 0.2);
}

.btn-upgrade-db:active {
    transform: translateY(0) scale(1);
    box-shadow: 0 4px 10px rgba(251, 191, 36, 0.15);
}

/* Cloud Sync Status Indicator */
#cloud-sync-status {
    display: flex;
    align-items: center;
    gap: 8px;
    border-radius: 20px;
    padding: 6px 14px;
    font-size: 12px;
    font-weight: 600;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    opacity: 1;
    transform: scale(1);
}

#cloud-sync-status.hidden {
    opacity: 0 !important;
    transform: scale(0.9) !important;
    pointer-events: none !important;
    display: none !important;
}

#cloud-sync-status.saving {
    background: rgba(34, 211, 238, 0.08) !important;
    border: 1px solid rgba(34, 211, 238, 0.25) !important;
    color: #22d3ee !important;
    box-shadow: 0 0 12px rgba(34, 211, 238, 0.2);
}

#cloud-sync-status.saving .sync-dot {
    background: #22d3ee !important;
    box-shadow: 0 0 8px #22d3ee;
    animation: blinkDot 1s infinite alternate;
}

#cloud-sync-status.success {
    background: rgba(16, 185, 129, 0.08) !important;
    border: 1px solid rgba(16, 185, 129, 0.25) !important;
    color: #10b981 !important;
    box-shadow: 0 0 12px rgba(16, 185, 129, 0.2);
}

#cloud-sync-status.success .sync-dot {
    background: #10b981 !important;
    box-shadow: 0 0 8px #10b981;
}

#cloud-sync-status.error {
    background: rgba(239, 68, 68, 0.08) !important;
    border: 1px solid rgba(239, 68, 68, 0.25) !important;
    color: #ef4444 !important;
    box-shadow: 0 0 12px rgba(239, 68, 68, 0.2);
}

#cloud-sync-status.error .sync-dot {
    background: #ef4444 !important;
    box-shadow: 0 0 8px #ef4444;
}

@keyframes blinkDot {
    0% { opacity: 0.2; }
    100% { opacity: 1; }
}

/* Login Swatch inside Dashboard */
.db-login-buttons {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.btn-login-db {
    width: 100%;
    padding: 11px 16px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    cursor: pointer;
    transition: all 0.2s;
    border: none;
}

.btn-login-db.google {
    background: white;
    color: #1e293b;
}

.btn-login-db.google:hover {
    background: #f1f5f9;
}

.btn-login-db.apple {
    background: #000000;
    color: white;
    border: 1px solid rgba(255, 255, 255, 0.15);
}

.btn-login-db.apple:hover {
    background: #111111;
}

.db-separator {
    display: flex;
    align-items: center;
    text-align: center;
    color: var(--text-muted, #94a3b8);
    font-size: 12px;
    margin: 4px 0;
}

.db-separator::before,
.db-separator::after {
    content: '';
    flex: 1;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.db-separator span {
    padding: 0 10px;
}

/* Subscription Perks List */
.subscription-status-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 14px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    padding-bottom: 12px;
}

.sub-status-label {
    color: var(--text-muted, #94a3b8);
    font-weight: 600;
}

.sub-status-val {
    color: #fbbf24;
    font-weight: 700;
}

.sub-perks-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 8px 0;
}

.perk-item {
    font-size: 13px;
    color: var(--text-muted, #94a3b8);
}

.perk-item.active {
    color: var(--text-main, #f8fafc);
}

/* Collapsible Theme Builder Panel styling */
.theme-builder-panel {
    background: rgba(15, 23, 42, 0.4);
    border: 1px solid rgba(6, 182, 212, 0.2);
    border-radius: 12px;
    padding: 20px;
    margin-top: 16px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    animation: slideDown 0.3s ease-out;
}

@keyframes slideDown {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

.theme-builder-panel.hidden {
    display: none !important;
}

.theme-builder-inner {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 24px;
}

.theme-builder-inner .db-form-group label {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
}

.builder-inputs {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.builder-preview {
    display: flex;
    flex-direction: column;
    gap: 8px;
    justify-content: center;
}

.builder-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    padding-top: 16px;
}

/* Miniature Card Preview */
.mini-card-preview {
    border-radius: 8px;
    padding: 16px;
    aspect-ratio: 1.25 / 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.05);
    position: relative;
    overflow: hidden;
    box-sizing: border-box;
}

.mini-header {
    display: flex;
    align-items: center;
    gap: 6px;
}

.mini-logo-avatar {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 8px;
}

.mini-handle {
    font-size: 8px;
    opacity: 0.8;
}

.mini-body {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin: 8px 0;
}

.mini-badge {
    align-self: flex-start;
    font-size: 7px;
    font-weight: 700;
    padding: 1px 4px;
    border-radius: 2px;
}

.mini-title {
    font-size: 13px;
    font-weight: 800;
    line-height: 1.2;
}

.mini-desc {
    font-size: 8px;
    line-height: 1.3;
    opacity: 0.8;
}

.mini-footer {
    display: flex;
    justify-content: space-between;
    font-size: 7px;
    opacity: 0.7;
}

/* Launcher Banner Styling */
.dashboard-footer-banner {
    display: flex;
    justify-content: center;
    width: 100%;
    margin-top: 8px;
}

.btn-launcher-banner {
    width: 100%;
    background: linear-gradient(135deg, #06B6D4 0%, #3730A3 100%);
    border: none;
    color: white;
    padding: 18px 24px;
    border-radius: 16px;
    font-size: 18px;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    box-shadow: 0 8px 24px rgba(6, 182, 212, 0.25);
    transition: all 0.3s ease;
    font-family: 'Outfit', sans-serif;
}

.btn-launcher-banner:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(6, 182, 212, 0.4);
}

.btn-launcher-banner svg {
    transition: transform 0.2s ease;
}

.btn-launcher-banner:hover svg {
    transform: translateX(4px);
}

/* Custom Header Icon Button in Editor */
.btn-header-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--border-color);
    color: var(--text-main, #f8fafc);
    border-radius: 8px;
    width: 32px;
    height: 32px;
    cursor: pointer;
    transition: all 0.2s;
}

.btn-header-icon:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: #06B6D4;
    color: #06B6D4;
}

/* ==========================================================================
   MOBILE & TABLET RESPONSIVE OVERRIDES
   ========================================================================== */
@media (max-width: 900px) {
    #view-editor {
        flex-direction: column;
        height: auto;
        min-height: 100vh;
        overflow-y: visible;
    }
    
    #view-dashboard {
        padding: 24px 16px;
    }

    .dashboard-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    .theme-builder-inner {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    
    .builder-preview {
        max-width: 300px;
        align-self: center;
        width: 100%;
    }

    /* Collapsible Dashboard Cards on Mobile */
    .dashboard-card {
        transition: padding 0.3s ease, gap 0.3s ease;
    }
    
    .dashboard-card.collapsed {
        gap: 0 !important;
        padding-top: 16px;
        padding-bottom: 16px;
        cursor: pointer;
    }
    
    .dashboard-card .card-body {
        max-height: 3000px;
        opacity: 1;
        overflow: hidden;
        transition: max-height 0.5s ease-out, opacity 0.3s ease-out;
    }
    
    .dashboard-card.collapsed .card-body {
        max-height: 0;
        opacity: 0;
        pointer-events: none;
    }
    
    .dashboard-card .card-header-icon {
        cursor: pointer;
        position: relative;
        padding-right: 24px;
        user-select: none;
        width: 100%;
    }
    
    .dashboard-card .card-header-icon::after {
        content: '';
        position: absolute;
        right: 4px;
        top: 50%;
        width: 6px;
        height: 6px;
        border-right: 2px solid var(--text-muted, #94a3b8);
        border-bottom: 2px solid var(--text-muted, #94a3b8);
        transform: translateY(-70%) rotate(45deg);
        transition: transform 0.3s ease;
    }
    
    .dashboard-card.collapsed .card-header-icon::after {
        transform: translateY(-50%) rotate(-135deg);
    }
}

.layout-choice-btn:hover {
    border-color: var(--accent-color, #06B6D4) !important;
    background: rgba(6, 182, 212, 0.05) !important;
}

#sig-ai-svg-holder svg,
#db-sig-ai-svg-holder svg {
    max-height: 80px;
    width: auto;
    display: block;
}

.db-sig-mode-btn {
    flex: 1;
    background: var(--input-bg);
    border: none;
    color: var(--text-muted);
    padding: 8px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.2s;
    text-align: center;
}

.db-sig-mode-btn:not(:last-child) {
    border-right: 1px solid var(--border-color);
}

.db-sig-mode-btn.active {
    background-color: var(--accent-color);
    color: #0f172a;
}

/* ==========================================================================
   BRAND PERSONA SETUP WIZARD (IMMERSE DIALOG)
   ========================================================================== */
.progress-step {
    transition: all 0.3s ease;
}
.progress-step.active .step-num {
    background-color: #22d3ee !important;
    border-color: #22d3ee !important;
    color: #0f172a !important;
    box-shadow: 0 0 12px rgba(34, 211, 238, 0.4);
}
.progress-step.active .step-label {
    color: var(--text-main) !important;
    font-weight: 600 !important;
}
.progress-step.completed .step-num {
    background-color: #10b981 !important;
    border-color: #10b981 !important;
    color: white !important;
}
.progress-step.completed .step-label {
    color: #10b981 !important;
}

.wiz-headline-chip {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 10px 14px;
    color: var(--text-main);
    font-size: 13px;
    cursor: pointer;
    text-align: left;
    transition: all 0.2s ease;
    line-height: 1.4;
}
.wiz-headline-chip:hover {
    background: rgba(34, 211, 238, 0.1);
    border-color: #22d3ee;
    transform: translateY(-1px);
}

.wiz-theme-chip {
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 8px 12px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: all 0.2s ease;
    background: rgba(15, 23, 42, 0.4);
}
.wiz-theme-chip:hover {
    border-color: #22d3ee;
    background: rgba(15, 23, 42, 0.6);
}
.wiz-theme-chip.active {
    border-color: #22d3ee;
    background: rgba(34, 211, 238, 0.08);
    box-shadow: 0 0 10px rgba(34, 211, 238, 0.15);
}

.wiz-sig-mode-btn {
    transition: all 0.2s ease;
}
.wiz-sig-mode-btn:hover {
    color: var(--text-main);
}
.wiz-sig-mode-btn.active {
    background: rgba(255, 255, 255, 0.08) !important;
    color: var(--text-main) !important;
}

/* Responsive Scaling for the Wizard Modal Split Panel */
@media (max-width: 800px) {
    .wizard-box {
        height: 95vh !important;
        max-width: 100% !important;
        width: 98% !important;
    }
    .wizard-split-content {
        flex-direction: column !important;
        overflow-y: auto !important;
    }
    .wizard-left-panel {
        flex: none !important;
        border-right: none !important;
        border-bottom: 1px solid var(--border-color);
        overflow-y: visible !important;
    }
    .wizard-right-panel {
        flex: none !important;
        padding: 24px 16px !important;
    }
    .wizard-progress-bar {
        padding: 12px 16px !important;
    }
    .wizard-progress-track, .wizard-progress-fill {
        top: 26px !important;
        left: 16px !important;
        right: 16px !important;
    }
}

/* Recent Deck Cards on Dashboard */
.recent-deck-card {
    background: rgba(30, 41, 59, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 12px;
    padding: 16px;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 120px;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
    position: relative;
    overflow: hidden;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
    box-sizing: border-box;
}

.recent-deck-card:hover {
    transform: translateY(-4px) scale(1.02);
    border-color: rgba(6, 182, 212, 0.35) !important;
    background: rgba(30, 41, 59, 0.55) !important;
    box-shadow: 0 10px 24px rgba(6, 182, 212, 0.15), 0 0 15px rgba(6, 182, 212, 0.1) !important;
}

.recent-deck-card:hover .resume-edit-label {
    opacity: 1 !important;
    transform: translateX(0) !important;
}

/* Onboarding Checklist Styling */
.checklist-item {
    transition: all 0.2s ease;
}

.checklist-item .check-box {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 4px;
    border: 1.5px solid rgba(255, 255, 255, 0.2);
    background: rgba(0, 0, 0, 0.2);
    transition: all 0.2s ease;
    cursor: default;
    flex-shrink: 0;
}

.checklist-item.checked {
    color: var(--text-main, #f8fafc) !important;
}

.checklist-item.checked .check-box {
    border-color: #10b981 !important;
    background: rgba(16, 185, 129, 0.15) !important;
}

.checklist-item.checked .check-box::after {
    content: "✔";
    color: #10b981;
    font-size: 11px;
    font-weight: 700;
}

/* Insight Tiles Micro-Hover */
.insight-tile {
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.insight-tile:hover {
    background: rgba(255, 255, 255, 0.06) !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
    transform: translateY(-1px);
}







