/**
 * Paragraph Block Styles
 * Uses theme design tokens from attributes.php
 * Only is-style-* classes - utility classes handled in format.php/blocks.php
 * @package MarketersDelight
 * @since 6.4.0
 */

/* ============================================
   ALERT & NOTICE BOXES
   ============================================ */

.is-style-callout,
.is-style-warning,
.is-style-error,
.is-style-info,
.is-style-note,
.is-style-notice,
.is-style-minimal {
    padding: var(--space-half) var(--space-single);
    border-radius: 0 var(--radius-m) var(--radius-m) 0;
    margin: 1.5em 0 1em;
    font-weight: 500;
    line-height: 1.6;
    border-left: 4px solid var(--color-border);
}

/* Callout - Primary accent */
/* bg: #fef2f2, text: inherits --color-text (#212121) = 14:1 contrast ✓ */
.is-style-callout {
    background: #fef2f2;
    border-left-color: var(--color-primary);
}

/* Warning - Orange */
/* bg: #fff7ed, text: #7c2d12 = 10:1 contrast ✓ */
.is-style-warning {
    background: #fff7ed;
    border-left-color: #ea580c;
    color: #7c2d12;
}

/* Error - Red */
/* bg: #fef2f2, text: #7f1d1d = 10:1 contrast ✓ */
.is-style-error {
    background: #fef2f2;
    border-left-color: #dc2626;
    color: #7f1d1d;
}

/* Info - Blue */
/* bg: #eff6ff, text: #1e3a8a = 9:1 contrast ✓ */
.is-style-info {
    background: #eff6ff;
    border-left-color: #2563eb;
    color: #1e3a8a;
}

/* Note - Green */
/* bg: #f0fdf4, text: #14532d = 10:1 contrast ✓ */
.is-style-note {
    background: #f0fdf4;
    border-left-color: #16a34a;
    color: #14532d;
}

/* Notice - Yellow */
/* bg: #fefce8, text: #713f12 = 8:1 contrast ✓ */
.is-style-notice {
    background: #fefce8;
    border-left-color: #ca8a04;
    color: #713f12;
}

/* Minimal - Subtle */
.is-style-minimal {
    background: var(--color-content-bg);
    border-left-color: var(--color-border);
    border-radius: 0;
}

/* Alert link styles */
.is-style-callout a,
.is-style-warning a,
.is-style-error a,
.is-style-info a,
.is-style-note a,
.is-style-notice a,
.is-style-minimal a {
    font-weight: var(--font-weight-bold);
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 3px;
}

.is-style-callout a {
    color: var(--color-primary);
}

/* Link colors darkened for contrast on light backgrounds */
.is-style-warning a {
    color: #9a3412;
}

.is-style-error a {
    color: #991b1b;
}

.is-style-info a {
    color: #1d4ed8;
}

.is-style-note a {
    color: #166534;
}

.is-style-notice a {
    color: #a16207;
}

.is-style-minimal a {
    color: var(--color-text);
}

/* ============================================
   TYPOGRAPHY STYLES
   ============================================ */

/* Intro - Lead paragraph */
.is-style-intro {
    font-size: clamp(1.125rem, 1rem + 0.5vw, 1.35rem);
    line-height: 1.6;
    color: var(--color-text-sec);
}

/* Serif - Elegant typography */
.is-style-serif,
p.is-style-serif {
    font-family: var(--font-serif);
    font-size: 1.1em;
    line-height: 1.8;
    letter-spacing: 0.01em;
}

/* Small - Fine print */
.is-style-small {
    font-size: var(--fs-s);
    color: var(--color-text-sec);
    line-height: 1.5;
}

/* Large - Emphasis */
.is-style-large {
    font-size: clamp(1.25rem, 1.1rem + 0.5vw, 1.5rem);
    font-weight: 500;
    line-height: 1.5;
}

/* Lead - Standout first paragraph */
.is-style-lead {
    font-size: clamp(1.125rem, 1rem + 0.4vw, 1.25rem);
    line-height: 1.7;
    color: var(--color-text);
    font-weight: 500;
    border-bottom: 2px solid var(--color-border);
    padding-bottom: var(--space-half);
    margin-bottom: var(--space-single);
}

/* ============================================
   CARD STYLES
   ============================================ */

/* Card - Basic card */
.is-style-card,
p.is-style-card {
    background: var(--color-content-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-m);
    padding: var(--space-half) var(--space-single);
    margin: 1.5em 0;
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition);
}

.is-style-card:hover,
p.is-style-card:hover {
    box-shadow: var(--shadow-md);
}

/* Glass Card - Glassmorphism effect */
.is-style-glass {
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: var(--radius-l);
    padding: var(--space-single);
    margin: 1.5em 0;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

/* ============================================
   HIGHLIGHT & FEATURE BOXES
   ============================================ */

/* Highlight Box - Primary gradient */
/* bg: #C0392B gradient, text: #fff = 5.5:1 contrast ✓ */
.is-style-highlight-box {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--accent-color-secondary) 100%);
    color: #fff;
    padding: var(--space-single);
    border-radius: var(--radius-l);
    font-size: var(--fs-m);
    line-height: 1.6;
    margin: 1.5em 0;
    box-shadow: var(--shadow-md);
}

.is-style-highlight-box a {
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* CTA Box - Attention grabbing */
/* bg: #c2410c (darkened), text: #fff = 5.9:1 contrast ✓ */
.is-style-cta-box {
    background: linear-gradient(135deg, #c2410c 0%, #ea580c 100%);
    color: #fff;
    padding: var(--space-single);
    border-radius: var(--radius-l);
    font-size: var(--fs-m);
    font-weight: var(--font-weight-bold);
    margin: 1.5em 0;
    text-align: center;
    box-shadow: var(--shadow-md);
    position: relative;
    overflow: hidden;
}

.is-style-cta-box::before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    animation: cta-shine 3s infinite;
}

.is-style-cta-box a {
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 3px;
}

@keyframes cta-shine {
    0% {
        left: -100%;
    }
    50%,
    100% {
        left: 100%;
    }
}

/* Urgent - Warning with icon */
/* bg: #fef2f2, text: #7f1d1d = 10:1 contrast ✓ */
.is-style-urgent {
    background: #fef2f2;
    color: #7f1d1d;
    padding: var(--space-half) var(--space-single) var(--space-half) 3.5rem;
    border-left: 4px solid #dc2626;
    border-radius: 0 var(--radius-m) var(--radius-m) 0;
    font-weight: 500;
    margin: 1.5em 0;
    position: relative;
}

.is-style-urgent::before {
    content: "⚠️";
    position: absolute;
    left: 0.875rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.25rem;
}

/* Success Box - Positive message */
/* bg: #f0fdf4, text: #14532d = 10:1 contrast ✓ */
.is-style-success-box {
    background: #f0fdf4;
    color: #14532d;
    padding: var(--space-half) var(--space-single) var(--space-half) 3.5rem;
    border-left: 4px solid #16a34a;
    border-radius: 0 var(--radius-m) var(--radius-m) 0;
    margin: 1.5em 0;
    font-weight: 500;
    position: relative;
}

.is-style-success-box::before {
    content: "✓";
    position: absolute;
    left: 0.875rem;
    top: 50%;
    transform: translateY(-50%);
    width: 1.5rem;
    height: 1.5rem;
    background: #16a34a;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: var(--font-weight-bold);
}

/* Tip - Helpful hint */
/* bg: #eff6ff, text: #1e3a8a = 9:1 contrast ✓ */
.is-style-tip {
    background: #eff6ff;
    color: #1e3a8a;
    padding: var(--space-half) var(--space-single) var(--space-half) 3.5rem;
    border-radius: var(--radius-m);
    border: 1px solid #bfdbfe;
    margin: 1.5em 0;
    position: relative;
    font-weight: 500;
}

.is-style-tip::before {
    content: "💡";
    position: absolute;
    left: 0.875rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.25rem;
}

/* ============================================
   PREMIUM MARKETING BOXES
   ============================================ */

/* Premium - Gold accent */
/* bg: #1e293b, text: #fcd34d = 8:1 contrast ✓ */
.is-style-premium {
    background: #1e293b;
    color: #fcd34d;
    padding: var(--space-single);
    border-radius: var(--radius-l);
    border: 2px solid #fcd34d;
    margin: 1.5em 0;
    font-size: var(--fs-m);
    font-weight: var(--font-weight-bold);
    text-align: center;
}

/* Stats - Big number display */
.is-style-stats {
    background: var(--color-content-bg);
    color: var(--color-text);
    padding: var(--space-single);
    border-radius: var(--radius-l);
    border: 2px solid var(--color-border);
    margin: 1.5em 0;
    text-align: center;
    font-size: clamp(1.5rem, 1.25rem + 1vw, 2.5rem);
    font-weight: var(--font-weight-bold);
    box-shadow: var(--shadow-sm);
}

/* Testimonial Snippet - Quote style */
.is-style-testimonial-snippet {
    background: var(--color-content-bg);
    color: var(--color-text-sec);
    padding: var(--space-half) var(--space-single) var(--space-half) 3.5rem;
    border-left: 4px solid var(--color-primary);
    border-radius: 0 var(--radius-m) var(--radius-m) 0;
    margin: 1.5em 0;
    font-style: italic;
    position: relative;
}

.is-style-testimonial-snippet::before {
    content: '"';
    position: absolute;
    left: 0.875rem;
    top: 0.5rem;
    font-size: 3rem;
    color: var(--color-primary);
    font-family: var(--font-serif);
    line-height: 1;
    opacity: 0.3;
}

/* Feature - Hover card */
.is-style-feature {
    background: var(--color-content-bg);
    color: var(--color-text);
    padding: var(--space-single);
    border-radius: var(--radius-l);
    border: 1px solid var(--color-border);
    margin: 1.5em 0;
    box-shadow: var(--shadow-sm);
    transition: all var(--transition);
}

.is-style-feature:hover {
    box-shadow: var(--shadow-lg);
    border-color: var(--color-primary);
}

/* Offer - Sales promotion */
/* bg: #be185d, text: #fff = 6.5:1 contrast ✓ */
.is-style-offer {
    background: linear-gradient(135deg, #be185d 0%, #db2777 100%);
    color: #fff;
    padding: var(--space-single);
    border-radius: var(--radius-l);
    margin: 1.5em 0;
    font-size: var(--fs-m);
    font-weight: var(--font-weight-bold);
    text-align: center;
    box-shadow: var(--shadow-md);
    position: relative;
    overflow: hidden;
}

.is-style-offer::before {
    content: "";
    position: absolute;
    inset: -50%;
    background: linear-gradient(45deg, transparent, rgba(255, 255, 255, 0.1), transparent);
    transform: rotate(45deg);
    animation: offer-shimmer 2s ease-in-out infinite;
}

.is-style-offer a {
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 3px;
}

@keyframes offer-shimmer {
    0%,
    100% {
        transform: rotate(45deg) translateX(-100%);
    }
    50% {
        transform: rotate(45deg) translateX(100%);
    }
}

/* ============================================
   SIMPLE UTILITY STYLES
   ============================================ */

/* Bordered - Simple border */
.is-style-bordered {
    padding: var(--space-half) var(--space-single);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-m);
    margin: 1.5em 0;
}

/* Dark - Inverted colors */
/* bg: #1e293b, text: #f1f5f9 = 12:1 contrast ✓ */
.is-style-dark {
    background: #1e293b;
    color: #f1f5f9;
    padding: var(--space-half) var(--space-single);
    border-radius: var(--radius-m);
    margin: 1.5em 0;
    font-weight: 500;
}

.is-style-dark a {
    color: #93c5fd;
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* Muted - Subdued text */
.is-style-muted {
    color: var(--color-text-sec);
    font-size: var(--fs-s);
    opacity: 0.8;
}

/* Highlighted - Text highlight effect */
.is-style-highlighted {
    background: linear-gradient(180deg, transparent 60%, #fde047 60%);
    display: inline;
    padding: 0 0.25rem;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}

/* Gradient Text - Gradient color text */
.is-style-gradient-text {
    background: linear-gradient(135deg, var(--color-primary) 0%, #7c3aed 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-weight: var(--font-weight-bold);
}

/* Quote - Inline quote styling */
.is-style-quote {
    font-style: italic;
    color: var(--color-text-sec);
    padding-left: var(--space-half);
    border-left: 3px solid var(--color-primary);
    margin: 1em 0;
}

/* Code-like - Monospace styling */
.is-style-code {
    font-family: var(--font-mono, monospace);
    background: #f8fafc;
    padding: var(--space-half) var(--space-single);
    border-radius: var(--radius-m);
    margin: 1em 0;
    font-size: 0.9em;
    border: 1px solid var(--color-border);
}

/* ============================================
   NEW PREMIUM STYLES
   ============================================ */

/* Spotlight - Subtle glow effect */
.is-style-spotlight {
    background: var(--color-content-bg);
    padding: var(--space-single);
    border-radius: var(--radius-l);
    margin: 1.5em 0;
    box-shadow: 0 0 0 1px var(--color-border);
    position: relative;
}

.is-style-spotlight::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary), #7c3aed);
    border-radius: var(--radius-l) var(--radius-l) 0 0;
}

/* Ribbon Banner - Side ribbon effect */
.is-style-ribbon-box {
    background: var(--color-content-bg);
    padding: var(--space-half) var(--space-single) var(--space-half) 4rem;
    border-radius: var(--radius-m);
    margin: 1.5em 0;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    position: relative;
}

.is-style-ribbon-box::before {
    content: "★";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3rem;
    background: var(--color-primary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    border-radius: var(--radius-m) 0 0 var(--radius-m);
}

/* Numbered - With counter */
.is-style-numbered-box {
    background: var(--color-content-bg);
    padding: var(--space-half) var(--space-single) var(--space-half) 4rem;
    border-radius: var(--radius-m);
    margin: 1.5em 0;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    position: relative;
    counter-increment: para-counter;
}

.is-style-numbered-box::before {
    content: counter(para-counter);
    position: absolute;
    left: 0.875rem;
    top: 50%;
    transform: translateY(-50%);
    width: 2rem;
    height: 2rem;
    background: var(--color-primary);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.875rem;
    font-weight: var(--font-weight-bold);
}

/* Key Point - Important takeaway */
/* bg: #fefce8, text: #713f12 = 8:1 contrast ✓ */
.is-style-key-point {
    background: #fefce8;
    color: #713f12;
    padding: var(--space-half) var(--space-single) var(--space-half) 3.5rem;
    border-radius: var(--radius-m);
    margin: 1.5em 0;
    font-weight: 500;
    position: relative;
    border: 1px solid #fde047;
}

.is-style-key-point::before {
    content: "🔑";
    position: absolute;
    left: 0.875rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.25rem;
}

/* Important - Red exclamation */
/* bg: #fef2f2, text: #7f1d1d = 10:1 contrast ✓ */
.is-style-important {
    background: #fef2f2;
    color: #7f1d1d;
    padding: var(--space-half) var(--space-single) var(--space-half) 3.5rem;
    border-radius: var(--radius-m);
    margin: 1.5em 0;
    font-weight: 600;
    position: relative;
    border: 1px solid #fca5a5;
}

.is-style-important::before {
    content: "❗";
    position: absolute;
    left: 0.875rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.25rem;
}

/* Question - FAQ style */
/* bg: #faf5ff, text: #581c87 = 10:1 contrast ✓ */
.is-style-question {
    background: #faf5ff;
    color: #581c87;
    padding: var(--space-half) var(--space-single) var(--space-half) 3.5rem;
    border-radius: var(--radius-m);
    margin: 1.5em 0;
    font-weight: 500;
    position: relative;
    border: 1px solid #d8b4fe;
}

.is-style-question::before {
    content: "❓";
    position: absolute;
    left: 0.875rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.25rem;
}

/* Pro Tip - Expert advice */
/* bg: #f0fdfa, text: #134e4a = 9:1 contrast ✓ */
.is-style-pro-tip {
    background: #f0fdfa;
    color: #134e4a;
    padding: var(--space-half) var(--space-single) var(--space-half) 3.5rem;
    border-radius: var(--radius-m);
    margin: 1.5em 0;
    font-weight: 500;
    position: relative;
    border: 1px solid #5eead4;
}

.is-style-pro-tip::before {
    content: "🚀";
    position: absolute;
    left: 0.875rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.25rem;
}

/* ============================================
   ASIDE STYLES (RESPONSIVE)
   ============================================ */

@media (min-width: 1366px) {
    .is-style-aside,
    .is-style-aside-right {
        position: absolute;
        max-width: 200px;
        font-size: var(--fs-s);
        color: var(--color-text-sec);
        text-align: left;
        margin-top: -10rem;
        padding: var(--space-half);
        border-radius: var(--radius-s);
        background: var(--color-content-bg, rgba(255, 255, 255, 0.8));
    }

    .is-style-aside {
        left: 0;
    }

    .is-style-aside-right {
        right: 0;
    }
}