/*
 * Archive Portfolio – Template Styles
 * Loaded only on portfolio archive (is_post_type_archive('portfolio'))
 * @package KadenceChild
 */
/* ── Kadence entry-content override ── */
.post-type-archive-portfolio .entry-content,
.post-type-archive-portfolio article,
.post-type-archive-portfolio .entry {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
}
.post-type-archive-portfolio .content-area,
.post-type-archive-portfolio .site-main {
    padding: 0 !important;
    margin: 0 !important;
}
.post-type-archive-portfolio .entry-header {
    display: none !important;
}



/* ================================================
   CSS Variables — adjust to match your brand
   ================================================ */
:root {
	--portfolio-red:     #c0392b;
	--portfolio-red-dark:#a93226;
	--portfolio-yellow:  #f0a500;
	--portfolio-white:   #ffffff;
	--portfolio-bg:      #f5f5f5;
	--portfolio-text:    #222222;
	--portfolio-muted:   #666666;
	--portfolio-radius:  4px;
	--portfolio-gap:     24px;
	--portfolio-transition: 0.3s ease;
}

/* ================================================
   Layout
   ================================================ */
#portfolio-archive-main {
	background: var(--portfolio-bg);
}

.portfolio-container {
	max-width: 1200px;
	margin:    0 auto;
	padding:   0 20px;
}

/* ================================================
   Hero Banner
   ================================================ */
/* ── Portfolio Hero — matches services single hero ── */
.portfolio-hero {
    background:    linear-gradient(54deg, var(--global-palette1, #ed1c24) 0%, #020202 99%);
    border-radius: 10px;
    margin:        10px 24px 0;
    min-height:    320px;
    display:       flex;
    align-items:   center;
}

.portfolio-hero .container {
    width: 100%;
}

.portfolio-hero__content {
    padding:    48px 40px;
    max-width:  640px;
}

.portfolio-hero__label {
    display:        inline-block;
    background:     rgba(255,255,255,0.18);
    color:          #fff;
    font-size:      11px;
    font-weight:    700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding:        5px 16px;
    border-radius:  20px;
    margin-bottom:  16px;
}

.portfolio-hero__title {
    color:       #fff;
    font-size:   clamp(28px, 4vw, 42px);
    font-weight: 800;
    margin:      0 0 16px;
    line-height: 1.15;
    letter-spacing: -0.3px;
}

.portfolio-hero__desc {
    color:       rgba(255,255,255,0.75);
    font-size:   16px;
    line-height: 1.65;
    margin:      0;
    max-width:   520px;
}

/* Tablet Breakpoint */
@media (max-width: 768px) {
    .portfolio-hero {
        margin:     max(20px, clamp(20px, 5vw, 40px)) 24px 0;
        min-height: clamp(280px, 50vh, 400px);
    }
    .portfolio-hero__content {
        padding: clamp(24px, 4vw, 36px);
    }
    .portfolio-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ================================================
   Search Section
   ================================================ */
.portfolio-search-section {
	background: var(--portfolio-white);
	padding:    clamp(24px, 4vw, 32px) 20px;
}

/* Override shortcode search styles to match design */
.portfolio-search-section form,
.portfolio-search-section .search-form {
	display:         flex;
	justify-content: center;
	align-items:     center;
	gap:             0;
	max-width:       500px;
	margin:          0 auto;
}

.portfolio-search-section input[type="text"],
.portfolio-search-section input[type="search"] {
	flex:          1;
	height:        44px;
	padding:       0 16px;
	border:        1px solid #ccc;
	border-right:  none;
	border-radius: var(--portfolio-radius) 0 0 var(--portfolio-radius);
	font-size:     14px;
	outline:       none;
	transition:    border-color var(--portfolio-transition);
}

.portfolio-search-section input[type="text"]:focus,
.portfolio-search-section input[type="search"]:focus {
	border-color: var(--portfolio-red);
}

.portfolio-search-section input[type="submit"],
.portfolio-search-section button[type="submit"],
.portfolio-search-section .search-submit {
	height:        44px;
	padding:       0 24px;
	background:    var(--portfolio-red);
	color:         var(--portfolio-white);
	border:        none;
	border-radius: 0 var(--portfolio-radius) var(--portfolio-radius) 0;
	font-size:     14px;
	font-weight:   600;
	cursor:        pointer;
	transition:    background var(--portfolio-transition);
	white-space:   nowrap;
}

.portfolio-search-section input[type="submit"]:hover,
.portfolio-search-section button[type="submit"]:hover,
.portfolio-search-section .search-submit:hover {
	background: var(--portfolio-red-dark);
}

/* ================================================
   Grid
   ================================================ */
.portfolio-grid-section {
	padding: clamp(40px, 5vw, 60px) 20px;
}

.portfolio-grid {
	display:               grid;
	grid-template-columns: repeat(3, 1fr);
	gap:                   var(--portfolio-gap);
}

/* Large Phone / Small Tablet */
@media (max-width: 640px) {
	.portfolio-grid-section {
		padding: clamp(28px, 4vw, 40px) 16px;
	}
	.portfolio-grid {
		grid-template-columns: 1fr;
		gap: clamp(12px, 2vw, 16px);
	}
}

/* Small Phone */
@media (max-width: 480px) {
	.portfolio-grid-section {
		padding: 24px 12px;
	}
}

/* ================================================
   Portfolio Card
   ================================================ */
.portfolio-card {
	background:    var(--portfolio-white);
	border-radius: var(--portfolio-radius);
	overflow:      hidden;
	transition:    transform var(--portfolio-transition), box-shadow var(--portfolio-transition);
}

.portfolio-card:hover {
	transform:  translateY(-4px);
	box-shadow: 0 12px 32px rgba(0,0,0,0.12);
}

.portfolio-card__link {
	display:         block;
	text-decoration: none;
	color:           inherit;
}

/* Image */
.portfolio-card__image-wrap {
	position:      relative;
	overflow:      hidden;
	aspect-ratio:  4 / 3;
	background:    #ddd;
}

.portfolio-card__image {
	width:      100%;
	height:     100%;
	object-fit: cover;
	display:    block;
	transition: transform 0.5s ease;
}

.portfolio-card:hover .portfolio-card__image {
	transform: scale(1.04);
}

.portfolio-card__overlay {
	position:   absolute;
	inset:      0;
	background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,0.18) 100%);
	transition: opacity var(--portfolio-transition);
}

.portfolio-card:hover .portfolio-card__overlay {
	opacity: 0.6;
}

.portfolio-card__no-image {
	width:           100%;
	height:          100%;
	display:         flex;
	align-items:     center;
	justify-content: center;
	background:      #e0e0e0;
	color:           var(--portfolio-muted);
	font-size:       14px;
	padding:         16px;
	text-align:      center;
}

/* Content */
.portfolio-card__content {
	padding: 14px 16px 18px;
}

.portfolio-card__title {
	font-size:   17px;
	font-weight: 600;
	color:       var(--portfolio-text);
	margin:      0 0 8px;
	line-height: 1.3;
	transition:  color var(--portfolio-transition);
}

.portfolio-card:hover .portfolio-card__title {
	color: var(--portfolio-red);
}

.portfolio-card__underline {
	display:    block;
	width:      40px;
	height:     3px;
	background: var(--portfolio-yellow);
	border-radius: 2px;
	transition: width var(--portfolio-transition);
}

.portfolio-card:hover .portfolio-card__underline {
	width: 70px;
}

/* ================================================
   Pagination
   ================================================ */
.portfolio-pagination {
	margin-top:      48px;
	display:         flex;
	justify-content: center;
	flex-wrap:       wrap;
	gap:             8px;
}

.portfolio-pagination .page-numbers {
	display:         inline-flex;
	align-items:     center;
	justify-content: center;
	min-width:       40px;
	height:          40px;
	padding:         0 14px;
	border:          1px solid #ddd;
	border-radius:   var(--portfolio-radius);
	font-size:       14px;
	color:           var(--portfolio-text);
	text-decoration: none;
	background:      var(--portfolio-white);
	transition:      all var(--portfolio-transition);
}

.portfolio-pagination .page-numbers:hover,
.portfolio-pagination .page-numbers.current {
	background:   var(--portfolio-red);
	border-color: var(--portfolio-red);
	color:        var(--portfolio-white);
}

/* ================================================
   Empty State
   ================================================ */
.portfolio-empty {
	text-align: center;
	padding:    60px 20px;
	color:      var(--portfolio-muted);
	font-size:  16px;
}