/**
 * CMWeb Magazine v4 - Complete Styles
 */

/* ============================================
   BASE
   ============================================ */
.cmweb-no-img {
    background: #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 150px;
    color: #999;
    font-size: 14px;
}

.cmweb-sep { margin: 0 8px; opacity: 0.6; }

/* Category */
.cmweb-cat {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    text-decoration: none;
    transition: opacity 0.3s;
}
.cmweb-cat:hover { opacity: 0.8; }
.cmweb-cat-text { color: var(--cat-color, #e67e22); }
.cmweb-cat-badge {
    padding: 5px 12px;
    background: var(--cat-bg, #e67e22);
    color: var(--cat-color, #fff);
    border-radius: 3px;
}

/* Date & Author */
.cmweb-date { font-size: 13px; color: inherit; }
.cmweb-author { font-size: 13px; }
.cmweb-author a { color: inherit; text-decoration: none; font-weight: 500; }
.cmweb-author img { border-radius: 50%; margin-right: 6px; vertical-align: middle; }

/* Read More */
.cmweb-readmore {
    display: inline-block;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s;
}
.cmweb-rm-link { color: var(--rm-color, #e67e22); }
.cmweb-rm-underline {
    color: var(--rm-color, #e67e22);
    border-bottom: 2px solid currentColor;
    padding-bottom: 2px;
}
.cmweb-rm-button {
    background: var(--rm-color, #e67e22);
    color: #fff !important;
    padding: 12px 24px;
    border-radius: 3px;
}
.cmweb-rm-button:hover { opacity: 0.9; }

/* Section Title */
.cmweb-sec-title {
    margin-bottom: 20px;
}
.cmweb-sec-title span {
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.cmweb-st-simple span {
    color: var(--title-color, #333);
}
.cmweb-st-badge span {
    display: inline-block;
    padding: 10px 20px;
    background: var(--title-bg, #e67e22);
    color: var(--title-color, #fff);
}
.cmweb-st-border span {
    display: inline-block;
    padding-bottom: 10px;
    border-bottom: 3px solid var(--title-bg, #e67e22);
    color: var(--title-color, #333);
}
.cmweb-st-vertical {
    flex-shrink: 0;
    margin-bottom: 0;
    margin-right: 20px;
}
.cmweb-st-vertical span {
    writing-mode: vertical-lr;
    transform: rotate(180deg);
    display: block;
    padding: 20px 15px;
    background: var(--title-bg, #f5f5f5);
    color: var(--title-color, #333);
    white-space: nowrap;
    height: 100%;
}

/* ============================================
   CAROUSEL
   ============================================ */
.cmweb-carousel {
    position: relative;
}
.cmweb-carousel.cmweb-has-vtitle {
    display: flex;
    align-items: stretch;
}
.cmweb-carousel.cmweb-has-vtitle .cmweb-car-main {
    flex: 1;
    min-width: 0;
}

.cmweb-car-viewport {
    overflow: hidden;
}
.cmweb-car-track {
    display: flex;
    gap: var(--gap, 20px);
    transition: transform 0.5s ease;
}
.cmweb-car-slide {
    flex: 0 0 calc((100% - (var(--cols, 4) - 1) * var(--gap, 20px)) / var(--cols, 4));
    min-width: 0;
}

/* Card */
.cmweb-card {
    height: 100%;
}
.cmweb-card-img {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius, 5px);
    margin-bottom: 15px;
}
.cmweb-card-below .cmweb-card-img {
    height: var(--img-h, 200px);
}
.cmweb-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s;
}
.cmweb-card:hover .cmweb-card-img img {
    transform: scale(1.05);
}

.cmweb-card-body {
    padding: 0;
}
.cmweb-card-cat {
    margin-bottom: 10px;
}
.cmweb-card-title {
    margin: 0 0 12px 0;
    font-size: var(--title-size, 16px);
    font-weight: 600;
    line-height: 1.4;
}
.cmweb-card-title a {
    color: #333;
    text-decoration: none;
    transition: color 0.3s;
}
.cmweb-card-title a:hover {
    color: var(--cat-color, #e67e22);
}
.cmweb-card-rm {
    margin-top: 15px;
}

/* Carousel Nav */
.cmweb-car-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin-top: 25px;
}
.cmweb-num {
    background: none;
    border: none;
    font-size: 16px;
    font-weight: 500;
    color: var(--nav-color, #333);
    cursor: pointer;
    padding: 5px;
    position: relative;
}
.cmweb-num.active,
.cmweb-num:hover {
    color: var(--nav-active, #e67e22);
}
.cmweb-num.active::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    height: 2px;
    background: var(--nav-active, #e67e22);
}
.cmweb-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: none;
    background: #ddd;
    cursor: pointer;
}
.cmweb-dot.active,
.cmweb-dot:hover {
    background: var(--nav-active, #e67e22);
}
.cmweb-arr {
    width: 40px;
    height: 40px;
    border: 1px solid var(--nav-color, #333);
    background: transparent;
    color: var(--nav-color, #333);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}
.cmweb-arr:hover {
    background: var(--nav-color, #333);
    color: #fff;
}

@media (max-width: 1024px) {
    .cmweb-car-slide { flex: 0 0 calc((100% - 2 * var(--gap, 20px)) / 3); }
}
@media (max-width: 768px) {
    .cmweb-car-slide { flex: 0 0 calc((100% - var(--gap, 20px)) / 2); }
    .cmweb-carousel.cmweb-has-vtitle { flex-direction: column; }
    .cmweb-st-vertical { margin-right: 0; margin-bottom: 20px; }
    .cmweb-st-vertical span { writing-mode: horizontal-tb; transform: none; height: auto; }
}
@media (max-width: 549px) {
    .cmweb-car-slide { flex: 0 0 100%; }
}

/* ============================================
   FEATURED GRID
   ============================================ */
.cmweb-grid {
    display: flex;
    gap: var(--gap, 10px);
}
.cmweb-grid-main {
    flex: 1.2;
    min-width: 0;
}
.cmweb-grid-side {
    flex: 1;
    display: grid;
    gap: var(--gap, 10px);
    min-width: 0;
}
.cmweb-side-2 { grid-template-columns: 1fr; }
.cmweb-side-3 { grid-template-columns: 1fr 1fr; }
.cmweb-side-3 .cmweb-grid-item:first-child { grid-column: span 2; }
.cmweb-side-4 { grid-template-columns: 1fr 1fr; }

.cmweb-grid-item {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius, 5px);
}
.cmweb-item-link {
    display: block;
    height: 100%;
    text-decoration: none;
    color: inherit;
}
.cmweb-item-img {
    position: relative;
    height: 100%;
    overflow: hidden;
}
.cmweb-item-main .cmweb-item-img {
    min-height: var(--main-h, 500px);
}
.cmweb-grid-side .cmweb-item-img {
    min-height: var(--side-h, 245px);
}
.cmweb-item-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s;
}
.cmweb-grid-item:hover .cmweb-item-img img {
    transform: scale(1.05);
}

/* Overlay */
.cmweb-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
}
.cmweb-ov-gradient {
    background: linear-gradient(to top, var(--overlay, rgba(0,0,0,0.6)) 0%, transparent 70%);
}
.cmweb-ov-solid {
    background: var(--overlay, rgba(0,0,0,0.5));
}

/* Letter */
.cmweb-letter {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 180px;
    font-weight: 700;
    font-family: Georgia, serif;
    color: var(--letter-color, rgba(255,255,255,0.1));
    line-height: 1;
    opacity: 0;
    transition: opacity 0.4s;
    pointer-events: none;
}
.cmweb-has-letter:hover .cmweb-letter {
    opacity: 1;
}

/* Content */
.cmweb-item-content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 25px;
    z-index: 2;
}
.cmweb-item-content .cmweb-cat {
    margin-bottom: 12px;
}
.cmweb-item-title {
    margin: 0 0 10px 0;
    font-weight: 600;
    line-height: 1.3;
    color: var(--title-color, #fff);
}
.cmweb-item-main .cmweb-item-title {
    font-size: var(--title-main, 26px);
}
.cmweb-grid-side .cmweb-item-title {
    font-size: var(--title-side, 15px);
}
.cmweb-item-excerpt {
    margin: 0 0 15px 0;
    font-size: 15px;
    line-height: 1.6;
    color: rgba(255,255,255,0.9);
}
.cmweb-item-meta {
    font-size: 13px;
    color: var(--meta-color, rgba(255,255,255,0.85));
}
.cmweb-item-meta a {
    color: inherit;
}

@media (max-width: 849px) {
    .cmweb-grid { flex-direction: column; }
    .cmweb-item-main .cmweb-item-img { min-height: 350px; }
    .cmweb-side-3 .cmweb-grid-item:first-child { grid-column: auto; }
    .cmweb-grid-side { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 549px) {
    .cmweb-grid-side { grid-template-columns: 1fr; }
    .cmweb-item-main .cmweb-item-title { font-size: 22px; }
}

/* ============================================
   EDITORIAL BLOCK
   ============================================ */
.cmweb-editorial {
    margin-bottom: 30px;
}
.cmweb-ed-header {
    margin-bottom: 25px;
}
.cmweb-ed-wrap {
    display: flex;
    gap: var(--gap, 30px);
}
.cmweb-ed-right .cmweb-ed-wrap {
    flex-direction: row-reverse;
}
.cmweb-ed-featured {
    flex: 1.2;
    min-width: 0;
}
.cmweb-ed-list {
    flex: 1;
    min-width: 0;
}

/* Featured */
.cmweb-featured-img {
    position: relative;
    margin-bottom: 20px;
    border-radius: 5px;
    overflow: hidden;
}
.cmweb-featured-img img {
    width: 100%;
    height: auto;
    display: block;
}
.cmweb-cat-overlay {
    position: absolute;
    bottom: 15px;
    left: 15px;
}
.cmweb-featured-body {
    padding: 0;
}
.cmweb-featured-title {
    margin: 0 0 12px 0;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.3;
}
.cmweb-featured-title a {
    color: #333;
    text-decoration: none;
}
.cmweb-featured-title a:hover {
    color: var(--rm-color, #e67e22);
}
.cmweb-featured-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 15px;
    font-size: 14px;
    color: #666;
}
.cmweb-featured-excerpt {
    margin: 0 0 20px 0;
    font-size: 15px;
    line-height: 1.7;
    color: #555;
}
.cmweb-featured-rm {
    margin-top: 20px;
}

/* List */
.cmweb-list-item {
    display: flex;
    gap: 15px;
    padding: 15px 0;
    border-bottom: 1px solid #eee;
}
.cmweb-list-item:last-child {
    border-bottom: none;
}
.cmweb-list-img {
    flex-shrink: 0;
    width: var(--thumb, 100px);
    height: var(--thumb, 100px);
    border-radius: 5px;
    overflow: hidden;
}
.cmweb-list-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.cmweb-list-body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.cmweb-list-title {
    margin: 0 0 8px 0;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.4;
}
.cmweb-list-title a {
    color: #333;
    text-decoration: none;
}
.cmweb-list-title a:hover {
    color: #e67e22;
}
.cmweb-list-meta {
    font-size: 13px;
    color: #999;
}

@media (max-width: 849px) {
    .cmweb-ed-wrap { flex-direction: column; }
    .cmweb-ed-right .cmweb-ed-wrap { flex-direction: column; }
}

/* ============================================
   SIDEBAR POSTS
   ============================================ */
.cmweb-sidebar {}
.cmweb-sb-item {
    display: flex;
    align-items: flex-start;
    gap: 15px;
    padding: 15px 0;
}
.cmweb-sb-item.cmweb-has-border {
    border-bottom: 1px solid #eee;
}
.cmweb-sb-item:last-child {
    border-bottom: none;
}
.cmweb-sb-num {
    font-size: 32px;
    font-weight: 800;
    color: var(--num-color, #333);
    line-height: 1;
    min-width: 45px;
    font-family: Georgia, serif;
}
.cmweb-sb-thumb {
    flex-shrink: 0;
    width: var(--thumb, 80px);
    height: var(--thumb, 80px);
    border-radius: 5px;
    overflow: hidden;
}
.cmweb-sb-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.cmweb-sb-body {
    flex: 1;
    min-width: 0;
}
.cmweb-sb-cat {
    margin-bottom: 5px;
}
.cmweb-sb-title {
    margin: 0 0 5px 0;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.4;
}
.cmweb-sb-title a {
    color: #333;
    text-decoration: none;
}
.cmweb-sb-title a:hover {
    color: #e67e22;
}
.cmweb-sb-date {
    font-size: 13px;
    color: #999;
}

/* ============================================
   NEWS TICKER
   ============================================ */
.cmweb-ticker {
    display: flex;
    align-items: stretch;
    background: var(--bg, #f5f5f5);
    overflow: hidden;
    border-radius: 4px;
}
.cmweb-ticker-label {
    display: flex;
    align-items: center;
    padding: 12px 20px;
    background: var(--label-bg, #e74c3c);
    color: var(--label-color, #fff);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    white-space: nowrap;
}
.cmweb-ticker-wrap {
    flex: 1;
    overflow: hidden;
}
.cmweb-ticker-track {
    display: flex;
    align-items: center;
    animation: tickerScroll var(--speed, 30s) linear infinite;
    white-space: nowrap;
    padding: 12px 20px;
}
.cmweb-ticker-wrap:hover .cmweb-ticker-track {
    animation-play-state: paused;
}
@keyframes tickerScroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.cmweb-ticker-item {
    color: var(--color, #333);
    text-decoration: none;
    font-size: 14px;
    padding-right: 50px;
}
.cmweb-ticker-item:hover {
    color: #e67e22;
}
