/**
 * Semtak Builder - Frontend Styles
 *
 * @package SemtakBuilder
 * @version 0.0.1
 *
 * Ultra-lightweight CSS (~3KB) for semantic HTML output
 * Based on 12-column CSS Grid system
 */

/* ==========================================================================
   CSS Custom Properties
   ========================================================================== */

:root {
    --stb-gap: 2rem;
    --stb-gap-sm: 1rem;
    --stb-margin: 1.5rem;
    --stb-border-radius: 4px;
    --stb-transition: 0.2s ease;
}

/* ==========================================================================
   Content Container
   ========================================================================== */

.stb-content {
    display: block;
    max-width: 100%;
}

/* ==========================================================================
   Block Base Styles
   ========================================================================== */

.stb-block {
    margin-bottom: var(--stb-mb, var(--stb-margin));
    margin-top: var(--stb-mt, 0);
}

.stb-block:last-child {
    margin-bottom: 0;
}

/* ==========================================================================
   Text Block
   ========================================================================== */

.stb-block--text {
    line-height: 1.7;
}

.stb-block--text p {
    margin: 0 0 1em;
}

.stb-block--text p:last-child {
    margin-bottom: 0;
}

/* ==========================================================================
   Link Block
   ========================================================================== */

.stb-block--link {
    display: inline-block;
}

.stb-block--link:hover {
    text-decoration: underline;
}

/* Button style link */
.stb-button {
    display: inline-block;
    padding: 0.75em 1.5em;
    background: var(--stb-button-bg, #2271b1);
    color: var(--stb-button-color, #fff);
    text-decoration: none;
    border-radius: var(--stb-border-radius);
    transition: background var(--stb-transition), transform var(--stb-transition);
}

.stb-button:hover {
    background: var(--stb-button-hover-bg, #135e96);
    text-decoration: none;
    transform: translateY(-1px);
}

.stb-button:active {
    transform: translateY(0);
}

/* ==========================================================================
   Image Block
   ========================================================================== */

.stb-block--image {
    margin: 0 0 var(--stb-margin);
}

.stb-block__image {
    display: block;
    max-width: 100%;
    height: auto;
}

.stb-block__caption {
    margin-top: 0.5em;
    font-size: 0.875em;
    color: var(--stb-caption-color, #666);
    text-align: center;
}

/* ==========================================================================
   HTML Block
   ========================================================================== */

.stb-block--html {
    overflow: hidden;
}

/* ==========================================================================
   Alignment
   ========================================================================== */

.stb-align--left {
    text-align: left;
}

.stb-align--center {
    text-align: center;
}

.stb-align--right {
    text-align: right;
}

/* Image alignment */
.stb-block--image.stb-align--left {
    margin-right: auto;
}

.stb-block--image.stb-align--center {
    margin-left: auto;
    margin-right: auto;
}

.stb-block--image.stb-align--right {
    margin-left: auto;
}

/* ==========================================================================
   Grid System (12-column)
   ========================================================================== */

.stb-row {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: var(--stb-gap);
}

.stb-col-1 { grid-column: span 1; }
.stb-col-2 { grid-column: span 2; }
.stb-col-3 { grid-column: span 3; }
.stb-col-4 { grid-column: span 4; }
.stb-col-5 { grid-column: span 5; }
.stb-col-6 { grid-column: span 6; }
.stb-col-7 { grid-column: span 7; }
.stb-col-8 { grid-column: span 8; }
.stb-col-9 { grid-column: span 9; }
.stb-col-10 { grid-column: span 10; }
.stb-col-11 { grid-column: span 11; }
.stb-col-12 { grid-column: span 12; }

/* Responsive columns */
@media (max-width: 768px) {
    .stb-row {
        gap: var(--stb-gap-sm);
    }

    .stb-col-1,
    .stb-col-2,
    .stb-col-3,
    .stb-col-4,
    .stb-col-5,
    .stb-col-6,
    .stb-col-7,
    .stb-col-8,
    .stb-col-9,
    .stb-col-10,
    .stb-col-11,
    .stb-col-12 {
        grid-column: span 12;
    }
}

/* ==========================================================================
   Separator
   ========================================================================== */

.stb-separator {
    border: 0;
    border-top: 1px solid var(--stb-separator-color, #ddd);
    margin: var(--stb-margin) 0;
}

/* ==========================================================================
   Spacer
   ========================================================================== */

.stb-spacer {
    display: block;
}

/* ==========================================================================
   Video Wrapper (responsive 16:9)
   ========================================================================== */

.stb-video-wrapper {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
}

.stb-video-wrapper iframe,
.stb-video-wrapper video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* ==========================================================================
   Accordion (native details/summary)
   ========================================================================== */

.stb-accordion {
    border: 1px solid var(--stb-accordion-border, #ddd);
    border-radius: var(--stb-border-radius);
}

.stb-accordion__item {
    border-bottom: 1px solid var(--stb-accordion-border, #ddd);
}

.stb-accordion__item:last-child {
    border-bottom: 0;
}

.stb-accordion__title {
    display: block;
    padding: 1em;
    cursor: pointer;
    font-weight: 600;
    background: var(--stb-accordion-header-bg, #f9f9f9);
    transition: background var(--stb-transition);
}

.stb-accordion__title:hover {
    background: var(--stb-accordion-header-hover-bg, #f0f0f0);
}

.stb-accordion__content {
    padding: 1em;
}

/* ==========================================================================
   Tables
   ========================================================================== */

.stb-block--html table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1em;
}

.stb-block--html th,
.stb-block--html td {
    padding: 0.75em;
    border: 1px solid var(--stb-table-border, #ddd);
    text-align: left;
}

.stb-block--html th {
    background: var(--stb-table-header-bg, #f9f9f9);
    font-weight: 600;
}

/* ==========================================================================
   Lists
   ========================================================================== */

.stb-block--html ul,
.stb-block--html ol {
    margin: 0 0 1em;
    padding-left: 1.5em;
}

.stb-block--html li {
    margin-bottom: 0.25em;
}

/* ==========================================================================
   Blockquote
   ========================================================================== */

.stb-block--html blockquote {
    margin: 1em 0;
    padding: 1em 1.5em;
    border-left: 4px solid var(--stb-blockquote-border, #2271b1);
    background: var(--stb-blockquote-bg, #f9f9f9);
    font-style: italic;
}

.stb-block--html blockquote cite {
    display: block;
    margin-top: 0.5em;
    font-size: 0.875em;
    font-style: normal;
    color: var(--stb-caption-color, #666);
}

/* ==========================================================================
   Code
   ========================================================================== */

.stb-block--html code {
    padding: 0.125em 0.375em;
    background: var(--stb-code-bg, #f5f5f5);
    border-radius: 3px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 0.875em;
}

.stb-block--html pre {
    margin: 1em 0;
    padding: 1em;
    background: var(--stb-code-bg, #f5f5f5);
    border-radius: var(--stb-border-radius);
    overflow-x: auto;
}

.stb-block--html pre code {
    padding: 0;
    background: none;
}

/* ==========================================================================
   Products Grid (WooCommerce)
   ========================================================================== */

.stb-products {
    display: grid;
    gap: var(--stb-gap);
    margin-bottom: var(--stb-margin);
}

.stb-products--cols-1 { grid-template-columns: 1fr; }
.stb-products--cols-2 { grid-template-columns: repeat(2, 1fr); }
.stb-products--cols-3 { grid-template-columns: repeat(3, 1fr); }
.stb-products--cols-4 { grid-template-columns: repeat(4, 1fr); }

.stb-product {
    background: var(--stb-product-bg, #fff);
    border: 1px solid var(--stb-product-border, #e0e0e0);
    border-radius: var(--stb-border-radius);
    overflow: hidden;
    transition: box-shadow var(--stb-transition), transform var(--stb-transition);
}

.stb-product:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    transform: translateY(-2px);
}

.stb-product__link {
    display: block;
    text-decoration: none;
    color: inherit;
}

.stb-product__link:hover {
    text-decoration: none;
}

.stb-product__image {
    position: relative;
    aspect-ratio: 1;
    background: var(--stb-product-image-bg, #f5f5f5);
    overflow: hidden;
}

.stb-product__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--stb-transition);
}

.stb-product:hover .stb-product__image img {
    transform: scale(1.05);
}

.stb-product__image--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
}

.stb-product__image--placeholder::after {
    content: "📷";
    font-size: 2rem;
    opacity: 0.3;
}

.stb-product__title {
    margin: 0;
    padding: 0.75rem 1rem 0.25rem;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.3;
}

.stb-product__price {
    padding: 0.25rem 1rem;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--stb-product-price-color, #2271b1);
}

.stb-product__price del {
    opacity: 0.6;
    font-weight: 400;
}

.stb-product__price ins {
    text-decoration: none;
    color: var(--stb-product-sale-color, #c00);
}

.stb-product__sku {
    padding: 0.5rem 1rem 0.75rem;
    font-size: 0.75rem;
    color: var(--stb-caption-color, #666);
}

/* Responsive products */
@media (max-width: 768px) {
    .stb-products--cols-3,
    .stb-products--cols-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .stb-products--cols-2,
    .stb-products--cols-3,
    .stb-products--cols-4 {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
    .stb-content {
        max-width: 100% !important;
    }

    .stb-block--image {
        break-inside: avoid;
    }

    .stb-video-wrapper {
        display: none;
    }
}
