/*
Theme Name: Hafidasfy V1
Theme URI: https://hafidasfy.com/
Description: Tema kustom berbasis Genesis Sample dengan desain Modern Slate & Typography Inter + Jakarta Sans.
Author: Hafid Asfiyanto
Version: 1.0.0
Template: genesis
License: GPL-2.0-or-later
*/

/* ==========================================================================
   DAFTAR ISI UTAMA
   ==========================================================================
   1.  VARIABLES & RESET
   2.  TYPOGRAPHY
   3.  COMMON CLASSES & WORDPRESS
   4.  SITE CONTAINER
   5.  SITE HEADER
   6.  SITE INNER
   7.  HOMEPAGE
   8.  ARCHIVE BLOG PORTOFOLIO SERTIFIKAT
   9.  SINGLE & PAGE
   10. SINGLE ONLY 
   11. PAGE ONLY
   12. SIDEBAR
   13. FOOTER
   ========================================================================== */


/* ==========================================================================
   BAGIAN 1: VARIABLES & RESET
   --------------------------------------------------------------------------
   1.1 Root Variables (Colors & Fonts)
   1.2 HTML5 Reset
   1.3 Box Sizing
   1.4 Float Clearing
   ========================================================================== */

/* 1.1 Root Variables (Colors & Fonts) */
:root {
    /* --- WARNA UTAMA --- */
    --color-primary: #2563EB;       /* biru utama untuk tombol dan link */
    --color-primary-dark: #1D4ED8;  /* biru gelap untuk hover */
    --color-accent: #EFF6FF;        /* biru sangat Muda untuk background badge */
    
    /* --- WARNA TEKS --- */
    --text-dark: #0F172A;           /* judul */
    --text-body: #334155;           /* paragraf */
    --text-muted: #64748B;          /* meta/Keterangan */
    
    /* --- BACKGROUND --- */
    --bg-light: #F8FAFC;            /* Ice Blue (Background Section) */
    --bg-white: #FFFFFF;
	--color-border: #E2E8F0;
    
    /* --- FONTS --- */
    --font-heading: 'Plus Jakarta Sans', sans-serif; /* Judul */
    --font-body: 'Inter', sans-serif;                /* Paragraf */
}

/* 1.2 HTML5 Reset */
html { 
    box-sizing: border-box; 
    scroll-behavior: smooth; 
    line-height: 1.15; 
    -webkit-text-size-adjust: 100%; 
    -moz-osx-font-smoothing: grayscale; 
    -webkit-font-smoothing: antialiased; 
}
*, ::after, ::before { box-sizing: inherit; }
body {font-family: var(--font-body);min-width: 320px;margin: 0; padding: 0; background: var(--bg-white); }

/* 1.3 Box Sizing */
html {box-sizing: border-box;}
@media (prefers-reduced-motion: no-preference) {html {scroll-behavior: smooth;}}
*,::after,::before{box-sizing:inherit}


/* 1.4 Float Clearing */
.author-box::before,.clearfix::before,.entry-content::before,.entry::before,.footer-widgets::before,.nav-primary::before,.nav-secondary::before,.pagination::before,.site-container::before,.site-footer::before,.site-header::before,.site-inner::before,.widget::before,.wrap::before{content:" ";display:table}
.author-box::after,.clearfix::after,.entry-content::after,.entry::after,.footer-widgets::after,.nav-primary::after,.nav-secondary::after,.pagination::after,.site-container::after,.site-footer::after,.site-header::after,.site-inner::after,.widget::after,.wrap::after{clear:both;content:" ";display:table}


/* ==========================================================================
   BAGIAN 2: TYPOGRAPHY
   --------------------------------------------------------------------------
   2.1 Body
   2.2 Headings
   2.3 Inline Elements
   2.4 Block Elements
   2.5 Media Objects
   2.6 Gallery Elements (WordPress Native Gallery)
   2.7 Forms
   2.8 Global Buttons Style
   2.9 Screen Reader & Accessibility
   ========================================================================== */

/* 2.1 Body */
body {
    font-family: var(--font-body);
    font-size: 16px;
    color: var(--text-body);
    line-height: 1.7;
    font-weight: 400;
    overflow-x: hidden;
}

/* 2.2 Headings */
h1, h2, h3, h4, h5, h6, .site-title, .entry-title, .widget-title {
    font-family: var(--font-heading);
    color: var(--text-dark);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.3;
    margin: 0 0 20px;
    text-wrap: balance;
}

h1 { font-size: 30px; }
h2 { font-size: 20px; }
h3 { font-size: 18px; }
h4, h5, h6 { font-size: 16px; }

/* 2.3 Inline Elements */
a { color: var(--color-primary); text-decoration: none; transition: 0.2s; }
a:hover { color: var(--color-primary-dark); }
b, strong { font-weight: 700; }
cite, em, i { font-style: italic; }
mark { background: var(--color-border); color: var(--text-body); }

/* 2.4 Block Elements */
p { margin: 0 0 15px; padding: 0; color: var(--text-body); }
ol, ul { margin: 0 0 20px; padding: 0; }
li { list-style-type: none; }
hr {
    border: 0;
    border-bottom: 1px solid var(--color-border);
    clear: both;
    margin: 1.65em auto;
}

blockquote {
    margin: 30px;
    font-style: italic;
    border-left: 4px solid var(--color-primary);
    padding-left: 20px;
}

/* 2.5 Media Objects */
.wp-caption,embed,iframe,img,object,video{max-width:100%}
img{height:auto;vertical-align:top}
figure{margin:0}


/* 2.6 Gallery Elements (WordPress Native Gallery) */
.gallery{overflow:hidden}
.gallery img{border:1px solid var(--color-border);height:auto;padding:4px}
.gallery img:focus,.gallery img:hover{border:1px solid #999;outline:0}
.gallery-columns-1 .gallery-item{width:100%}
.gallery-columns-2 .gallery-item{width:50%}
.gallery-columns-3 .gallery-item{width:33%}
.gallery-columns-4 .gallery-item{width:25%}
.gallery-columns-5 .gallery-item{width:20%}
.gallery-columns-6 .gallery-item{width:16.6666%}
.gallery-columns-7 .gallery-item{width:14.2857%}
.gallery-columns-8 .gallery-item{width:12.5%}
.gallery-columns-9 .gallery-item{width:11.1111%}
.gallery-columns-2 .gallery-item:nth-child(odd),.gallery-columns-3 .gallery-item:nth-child(3n+1),.gallery-columns-4 .gallery-item:nth-child(4n+1),.gallery-columns-5 .gallery-item:nth-child(5n+1),.gallery-columns-6 .gallery-item:nth-child(6n+1),.gallery-columns-7 .gallery-item:nth-child(7n+1),.gallery-columns-8 .gallery-item:nth-child(8n+1),.gallery-columns-9 .gallery-item:nth-child(9n+1){clear:left}
.gallery-item{float:left;margin:0 0 30px;text-align:center}


/* 2.7 Forms */
input, select, textarea {
    background-color: var(--bg-white);
    border: 1px solid var(--color-border);
    color: var(--text-dark);
    font-size: 18px;
    padding: 15px;
    width: 100%;
    border-radius: 8px !important;
    transition: all .2s ease-in-out;
}
input:focus, textarea:focus { border-color: var(--text-muted); outline: 0; }
::placeholder { color: var(--text-body); opacity: 1; }

/* 2.8 Global Buttons Style */
.button, button, input[type=button], input[type=reset], input[type=submit] {
    background-color: var(--text-dark);
    border: 0;
    border-radius: 50px;
    color: var(--bg-white);
    cursor: pointer;
    font-family: var(--font-heading);
    font-size: 16px;
    font-weight: 600;
    padding: 10px 30px 12px;
    text-align: center;
    transition: all .2s ease-in-out;
    display: inline-block;
}
.button:hover, button:hover, input[type=submit]:hover { background-color: var(--color-primary); color: var(--bg-white); }

/* 2.9 Screen Reader & Accessibility */
.screen-reader-text { border: 0; clip: rect(0,0,0,0); height: 1px; overflow: hidden; position: absolute!important; width: 1px; }



/* ==========================================================================
   BAGIAN 3: COMMON CLASSES & WORDPRESS
   --------------------------------------------------------------------------
   3.1 Avatar & Author Box
   3.2 WordPress Content Alignment
   3.3 Accessibility (Skip Links)
   3.4 Pagination
   3.5 Table
   3.6 Accordion Post
   ========================================================================== */


/* 3.1 Avatar & Author Box */
.avatar { border-radius: 50%; float: left; }
.alignleft .avatar, .author-box .avatar { margin-right: 20px; }
.alignright .avatar { margin-left: 20px; }
.comment .avatar { margin: 0 15px 20px 0; }

/* 3.2 WordPress Content Alignment */
a.aligncenter img { display: block; margin: 0 auto; }
a.alignnone { display: inline-block; }
.alignleft { float: left; text-align: left; }
.alignright { float: right; text-align: right; }
a.alignleft, a.alignnone, a.alignright { max-width: 100%; }
.aligncenter, .singular-image, img.centered { display: block; margin: 0 auto; }
.alignnone, img.alignnone { margin-bottom: 15px; }
.wp-caption.alignleft, a.alignleft, img.alignleft { margin: 0 20px 20px 0; }
.wp-caption.alignright, a.alignright, img.alignright { margin: 0 0 20px 20px; }

/* 3.3 Accessibility (Skip Links) */
.skip-link, .genesis-skip-link { display: none !important; visibility: hidden !important; height: 0 !important; width: 0 !important; }
.screen-reader-text { border: 0; clip: rect(0,0,0,0); height: 1px; overflow: hidden; position: absolute!important; width: 1px; }

/* 3.4 Pagination */
.pagination {
    clear: both;
    margin: 50px auto;
    padding:0;
    background: var(--bg-white);
    text-align: center;
}

.pagination ul {
	margin:0;
	padding:0;
}

.archive-pagination li {
    display: inline;
}

.archive-pagination li a {
    background: var(--color-primary);
    color: var(--bg-white);
    cursor: pointer;
    display: inline-block;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 4px;
    padding: 8px 12px;
    text-decoration: none;
    border-radius: 5px;
    transition: all 0.3s;
}

.archive-pagination li a:focus,
.archive-pagination li a:hover,
.archive-pagination li.active a {
    background-color: #222;
    color: var(--bg-white);
}

.archive-pagination .dashicons {
    font-size: 16px;
    width: 16px;
    height: 18px;
    line-height: 1;
    vertical-align: middle;
}

/* 3.5.1 Table detail sertifikat */

table.tabel-detail-sertifikat {
    border-collapse: collapse;
    border-spacing: 0;
    margin: 0 0 40px;
    width: 100%;
    table-layout: auto;
    font-size: 15px;
    color: var(--text-body);
    border: 1px solid var(--color-border);
    background-color: var(--bg-white);
}

.tabel-detail-sertifikat th, 
.tabel-detail-sertifikat td {
    padding: 15px 20px;
    border: 1px solid var(--color-border);
    vertical-align: middle;
    line-height: 1.6;
}

.tabel-detail-sertifikat th {
    background-color: var(--bg-light);
    color: var(--text-dark);
    font-family: var(--font-heading);
    font-weight: 700;
    text-align: left;
    text-transform: uppercase;
    font-size: 13px;
    letter-spacing: 0.05em;
    width: 30%;
}

.tabel-detail-sertifikat td {
    background-color: var(--bg-white);
}

.tabel-detail-sertifikat tr:hover td {
    background-color: var(--color-accent);
    transition: background-color 0.2s ease;
}

.tabel-detail-sertifikat td ol.pemateri-list {
	margin:0 !important;
}

.tabel-detail-sertifikat td ol.pemateri-list li {
	margin-bottom:15px !important;
    padding-left: 30px !important;
}

.tabel-detail-sertifikat td ol.pemateri-list li::before {
	font-weight: 400 !important;
    font-size: 16px !important
}

@media only screen and (max-width: 768px) {
    table.tabel-detail-sertifikat {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}

/* 3.5.2 Table content sertifikat */

table.tabel-content-sertifikat {
    border-collapse: collapse;
    border-spacing: 0;
    margin: 20px 0 40px;
    width: 100%;
    table-layout: auto;
    font-size: 15px;
    color: var(--text-body);
    border: 1px solid var(--color-border);
    background-color: var(--bg-white);
}

.tabel-content-sertifikat th {
    background-color: var(--bg-light);
    color: var(--text-dark);
    font-family: var(--font-heading);
    font-weight: 700;
    text-align: left;
    text-transform: uppercase;
    font-size: 13px;
    letter-spacing: 0.05em;
    padding: 15px 20px;
    border: 1px solid var(--color-border);
}

.tabel-content-sertifikat td {
    padding: 15px 20px;
    border: 1px solid var(--color-border);
    vertical-align: top;
    line-height: 1.6;
    background-color: var(--bg-white);
}

.tabel-content-sertifikat th:first-child,
.tabel-content-sertifikat td:first-child {
    width: 30%;
    white-space: nowrap;
}

.tabel-content-sertifikat tr:hover td {
    background-color: var(--color-accent);
    transition: background-color 0.2s ease;
}

@media only screen and (max-width: 768px) {
    table.tabel-content-sertifikat {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}

/* 3.6 Accordion Post */

/* Styling Container Details (Bawaan WordPress Block) */
body.page:not(.home) .entry-content details.wp-block-details,
body.single .entry-content details.wp-block-details {
    border: 1px solid #dadce0;
    background-color: var(--bg-white, #ffffff);
    margin-bottom: 24px;
    border-radius: 8px;
    overflow: hidden;
    transition: box-shadow 0.3s ease, border-color 0.3s ease;
}

/* Styling Bagian Header (Summary) */
body.page:not(.home) .entry-content details.wp-block-details summary,
body.single .entry-content details.wp-block-details summary {
    background-color: var(--bg-white, #ffffff);
    color: #3c4043;
    padding: 16px 24px;
    padding-right: 50px;
    font-weight: 500;
    font-size: 15px;
    cursor: pointer;
    position: relative;
    list-style: none; /* Menghilangkan marker default bawaan browser */
    border-bottom: 1px solid transparent; /* Transparan saat ditutup agar rapi */
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    margin: 0;
}

/* Memunculkan garis bawah pada summary hanya saat details terbuka */
body.page:not(.home) .entry-content details.wp-block-details[open] summary,
body.single .entry-content details.wp-block-details[open] summary {
    border-bottom: 1px solid #dadce0;
}

/* Efek Hover pada Header */
body.page:not(.home) .entry-content details.wp-block-details summary:hover,
body.single .entry-content details.wp-block-details summary:hover {
    background-color: #f0f7ff;
    color: #1a73e8;
    padding-left: 28px;
}

/* Menghilangkan icon panah bawaan webkit (Safari/Chrome) */
body.page:not(.home) .entry-content details.wp-block-details summary::-webkit-details-marker,
body.single .entry-content details.wp-block-details summary::-webkit-details-marker {
    display: none;
}

/* Membuat Icon Panah Kustom (Chevron) */
body.page:not(.home) .entry-content details.wp-block-details summary::after,
body.single .entry-content details.wp-block-details summary::after {
    content: '';
    position: absolute;
    right: 24px;
    top: 50%;
    width: 8px;
    height: 8px;
    border-right: 2px solid #70757a;
    border-bottom: 2px solid #70757a;
    transform: translateY(-60%) rotate(45deg);
    transition: transform 0.3s ease, border-color 0.3s ease, right 0.3s ease;
}

/* Efek Hover pada Icon Panah */
body.page:not(.home) .entry-content details.wp-block-details summary:hover::after,
body.single .entry-content details.wp-block-details summary:hover::after {
    border-color: #1a73e8;
    right: 20px;
}

/* Animasi Rotasi Icon Panah saat Details Terbuka */
body.page:not(.home) .entry-content details.wp-block-details[open] summary::after,
body.single .entry-content details.wp-block-details[open] summary::after {
    transform: translateY(-20%) rotate(225deg);
    border-color: #1a73e8;
}

/* Styling Konten di dalam Details (Paragraf dll) */
body.page:not(.home) .entry-content details.wp-block-details > :not(summary),
body.single .entry-content details.wp-block-details > :not(summary) {
    background-color: var(--bg-white, #ffffff);
    color: #5f6368;
    padding: 20px 24px;
    font-size: 14px;
    line-height: 1.6;
    margin: 0;
}

/* ==========================================================================
   BAGIAN 4: SITE CONTAINER
   --------------------------------------------------------------------------
   4.1 Site Container Animation
   ========================================================================== */

/* 4.1 Site Container Animation */
.site-container {
    animation: fadein 1s;
    word-wrap: break-word;
}
@keyframes fadein {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}




/* ==========================================================================
   BAGIAN 5: SITE HEADER
   --------------------------------------------------------------------------
   5.1 Sticky Header & Scroll Logic
   5.2 Logo & Site Title
   5.3 Desktop Navigation
   5.4 Mobile Navigation
   ========================================================================== */

/* 5.1 Sticky Header & Scroll Logic */
.site-header {
    background-color: var(--bg-white);
    border-bottom: 1px solid var(--color-border);
    position: fixed;
    width: 100%;
    max-width: 1600px;
    margin: 0px auto;
    top: 0;
    left: 0;
    right: 0;
    z-index: 9999;
    height: 70px;
    transition: background-color 0.4s cubic-bezier(0.4, 0, 0.2, 1),
                border-color 0.4s cubic-bezier(0.4, 0, 0.2, 1),
                box-shadow 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

body.home .site-header {
    background-color: var(--bg-light) !important;
    border-bottom-color: transparent !important;
    box-shadow: none !important;
}

body.home .site-header.is-scrolled {
    background-color: rgba(255, 255, 255, 0.95) !important;
    border-bottom-color: var(--color-border) !important;
    box-shadow: 0 4px 20px -5px rgba(0, 0, 0, 0.1);
    backdrop-filter: blur(8px);
}

.site-header .wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1600px;
    margin: 0 auto;
    height: 100%;
    padding: 0 60px;
    position: relative;
}

/* 5.2 Logo & Site Title */
.site-header .title-area,
.nav-primary { 
    float: none !important;
    width: auto !important;
    padding: 0 !important;
    margin: 0 !important;
}

.site-header .title-area {
    flex-shrink: 0;
    z-index: 101;
    display: flex;
    align-items: center;
}

.site-title {
    font-size: 20px;
    font-weight: 700;
    margin: 0;
    line-height: 1;
}

.site-title a {
    color: var(--text-body);
    text-decoration: none;
    display: block;
}

.site-description {
    display: none !important;
}


/* 5.3 Desktop Navigation */
@media only screen and (min-width: 769px) {
    button.menu-toggle {
        display: none !important;
    }

    .nav-primary {
        display: block !important;
        position: static;
        background: transparent;
        box-shadow: none;
        border: none;
        width: auto !important;
        margin-left: auto !important; 
    }
	
	.nav-primary .wrap {
		padding: 0;
	}

    .nav-primary .genesis-nav-menu {
        display: flex;
        align-items: center;
        gap: 25px; 
        margin: 0;
    }

    .nav-primary .menu-item {
        display: block;
        border: none;
        margin: 0;
        position: relative;
    }

    .nav-primary a {
        padding: 10px 0;
        font-size: 15px;
        color: var(--text-body);
        font-weight: 500;
        background-color: transparent !important;
        transition: color 0.2s;
    }

    .nav-primary a:hover {
        color: var(--color-primary);
    }

    .nav-primary .sub-menu {
        position: absolute;
        top: 100%;
        left: -15px;
        width: 200px;
        background: var(--bg-white);
        border-top: 2px solid var(--color-primary);
        box-shadow: 0 4px 10px rgba(0,0,0,0.1);
        opacity: 0;
        visibility: hidden;
        transition: all 0.2s ease-in-out;
        z-index: 100;
        display: block;
    }

    .nav-primary .menu-item:hover .sub-menu,
    .nav-primary .menu-item:focus-within .sub-menu {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }

    .nav-primary .sub-menu a {
        padding: 12px 15px;
        border-bottom: 1px solid #f5f5f5;
    	font-size: 14px;
    }
}


/* 5.4 Mobile Navigation */
@media only screen and (max-width: 768px) {
	.site-header .wrap {
		padding: 0 30px;
	}
	
	button.menu-toggle {
    	display: inline-flex !important; 
    	align-items: center; 
    	justify-content: center;
    	background: transparent !important;
    	border: none !important;
    	box-shadow: none !important;
    	color: var(--text-dark) !important;
    	font-size: 16px; 
   		font-weight: 600;
    	padding: 0;
    	cursor: pointer;
    	line-height: 1;
    	margin-left: auto; 
    	height: auto;
    	transition: color 0.2s ease;
	}
	
	button.menu-toggle:hover {
    	outline: none;
    	color: var(--color-primary) !important;
    	background: transparent !important;
	}

	button.menu-toggle:focus {
    	outline: none;
    	color: var(--text-body) !important;
    	background: transparent !important;
	}
	
	button.menu-toggle::before {
    	font-family: "Dashicons";
    	content: "\f333" !important;
    	font-size: 22px; 
    	margin-right: 8px; 
    	display: block;
    	line-height: 1 !important;
    	position: relative;
    	top: 0; 
	}
	
	button.menu-toggle span { 
    	display: block !important; 
    	line-height: 1 !important;
    	padding-top: 2px; 
	}
	
	.nav-primary {
    	display: none; 
    	position: absolute;
    	top: 70px;
    	left: 0;
    	width: 100% !important;
    	background: var(--bg-white);
    	border-bottom: 1px solid #eee;
    	box-shadow: 0 5px 10px rgba(0,0,0,0.05);
    	z-index: 999;
	}

	.nav-primary .wrap {
		padding: 0;
	}

	.nav-primary.toggled-on {
		display: block;
	}

	.nav-primary .menu-item {
		display: block;
		border-top: 1px solid #f9f9f9;
		text-align: left;
		margin: 0;
	}

	.nav-primary a {
		display: block;
		padding: 15px 20px;
		color: var(--text-body);
		font-weight: 500;
		text-decoration: none;
	}
}




/* ==========================================================================
   BAGIAN 6: SITE INNER
   --------------------------------------------------------------------------
   6.1 Site Inner
   ========================================================================== */

/* 6.1 Site Inner */
.site-inner {
    clear: both;
	width:100%;
    max-width: 1600px;
    position: relative;
    margin: 0 auto;
    padding: 70px 0px 50px;
}

body:not(.home) .site-inner { /* selain homepage */
	width:90%;
    max-width: 1100px;
}

@media (max-width: 1200px) {
	body.single .site-inner {
		width: 90%;
		max-width: 960px;
	}
}

@media (max-width: 1060px) {
	body.single .site-inner {
		width: 90%;
		max-width: 90%;
	}
}

/* ==========================================================================
   BAGIAN 7: HOMEPAGE
   --------------------------------------------------------------------------
   7.1 Content Area
   7.2 Profile Hero Section
   7.3 Featured Projects
   7.4 Journey Section
   7.5 Expertise Section
   7.6 Reason Section
   7.7 Testimonial Section
   7.8 Connect Section
   ========================================================================== */

/* 7.1 Content Area */
body.home .content {
    float: none;
    width: 100%;
    max-width: 1600px;
    margin: 0 auto;
    padding:0;
    background: var(--bg-white);
}


/* 7.2 Profile Hero Section */
body.home .profile-container {
    width: 100%;
    position: relative;
    overflow-x: hidden;
    background-color: var(--bg-light) !important; 
    min-width: 320px !important;
    --blob-color: #2563EB;        
    --btn-anim-speed: 1.2s; 
    --btn-ease: cubic-bezier(0.4, 0, 0.2, 1);
    --text-secondary: #475569;
}

body.home .profile-summary-section {
    position: relative;
    width: 100%;
    height: 100%;
    padding: 100px 60px 0px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

body.home .profile-grid-wrapper {
    display: grid;
    grid-template-columns: 420px 1fr 400px; 
    width: 100%;
    height: 580px;
    align-items: flex-end;
    padding-bottom: 0;
}

body.home .col-left,
body.home .col-right {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
    z-index: 10;
    padding: 20px 0 40px 0;
}

body.home .col-right {
    align-items: flex-end;
    text-align: right;
}

body.home .col-center {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    height: 100%;
    padding-bottom: 0;
}

body.home .content-top-left { text-align: left; }
body.home .content-bottom-left { text-align: left; }

body.home .content-top-right {
    text-align: right;
    padding-top: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

body.home .content-bottom-right {
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: flex-end;
}

body.home .profile-headline {
    font-family: var(--font-heading);
    font-size: 64px;
    font-weight: 800;
    line-height: 1.1;
    color: var(--text-dark);
    margin-bottom: 15px;
    word-break: keep-all;
    letter-spacing: -1px;
}

body.home .profile-role-wrapper {
    display: flex;
    align-items: center;
    gap: 15px;
}
body.home .profile-role-line {
    width: 40px;
    height: 3px;
    background-color: var(--text-dark);
}
body.home .profile-role-text {
    font-size: 16px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--text-secondary);
}

body.home .profile-bio-desc {
    font-size: 16px;
    line-height: 1.8;
    color: var(--text-secondary);
    margin-bottom: 0;
    max-width: 350px;
}

body.home .profile-bio-desc b { color: var(--text-dark) !important; font-weight: 700; }

body.home .profile-stat-simple {
    display: flex;
    align-items: center;
    gap: 12px;
}

body.home .profile-stat-number {
    font-family: var(--font-heading);
    font-size: 58px;
    font-weight: 800;
    color: var(--text-dark);
    line-height: 1;
}

body.home .profile-stat-label {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

body.home .profile-stat-label span {
    display: block;
    font-size: 15px;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    line-height: 1.2;
}

body.home .profile-btn-primary,
body.home .profile-btn-secondary {
    position: relative;
    isolation: isolate; 
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 16px 0;
    border-radius: 50px; 
    text-decoration: none;
    font-weight: 700;
    cursor: pointer;
    background: transparent; 
    border: none;
    width: 220px;
    z-index: 1;
    transition: transform 0.2s ease, color 0.8s ease, border-color 0.8s ease, box-shadow 0.2s ease;
}

body.home .btn-text { position: relative; z-index: 2; }

body.home .profile-btn-primary {
    color: var(--bg-white) !important;
    box-shadow: 0 4px 15px rgba(37, 99, 235, 0.3);
    border: 2px solid var(--color-primary);
}
body.home .profile-btn-primary::after {
    content: ''; position: absolute; inset: 0; background-color: var(--color-primary); z-index: -2; 
}
body.home .profile-btn-primary::before {
    content: ''; position: absolute; top: var(--y); left: var(--x); width: 100%; padding-bottom: 100%;
    border-radius: 50%; background-color: var(--color-primary-dark); 
    transform: translate(-50%, -50%) scale(0); z-index: -1; 
    transition: transform var(--btn-anim-speed) var(--btn-ease); pointer-events: none;
}
body.home .profile-btn-primary:hover { transform: translateY(-3px); }
body.home .profile-btn-primary:hover::before { transform: translate(-50%, -50%) scale(2.8); }

body.home .profile-btn-secondary {
    color: var(--color-primary) !important;
    border: 2px solid #CBD5E1; 
}
body.home .profile-btn-secondary::after {
    content: ''; position: absolute; inset: 0; background-color: var(--bg-white); z-index: -2;
}
body.home .profile-btn-secondary::before {
    content: ''; position: absolute; top: var(--y); left: var(--x); width: 100%; padding-bottom: 100%;
    border-radius: 50%; background-color: var(--color-primary); 
    transform: translate(-50%, -50%) scale(0); z-index: -1; 
    transition: transform var(--btn-anim-speed) var(--btn-ease); pointer-events: none;
}
body.home .profile-btn-secondary:hover {
    color: var(--bg-white) !important; border-color: var(--color-primary); transform: translateY(-3px);
}
body.home .profile-btn-secondary:hover::before { transform: translate(-50%, -50%) scale(2.8); }

body.home .profile-blob-bg {
    position: absolute;
    width: 580px; 
    height: 580px;
    background-color: var(--blob-color);
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    border-radius: 44% 56% 30% 70% / 50% 30% 70% 50%;
    z-index: 1;
    left: 50%;
    transform: translateX(-50%);
    animation: blobMorph 8s infinite alternate ease-in-out;
    bottom: 60px;
    opacity: 0.9;
}

body.home .profile-main-photo {
    width: auto; height: auto;
    max-height: 560px;
    max-width: 100%;
    object-fit: contain; z-index: 2; 
    filter: drop-shadow(0 25px 50px rgba(0,0,0,0.15));
    margin-bottom: 0; display: block;
}

@keyframes blobMorph {
    0% { 
		border-radius: 44% 56% 30% 70% / 50% 30% 70% 50%; 
	}
    100% { 
		border-radius: 60% 40% 70% 30% / 30% 50% 50% 70%; 
	}
}

@media (min-width: 1201px) and (max-width: 1550px) {
    body.home .profile-grid-wrapper { 
		grid-template-columns: 320px 1fr 300px; 
	}
}

@media (min-width: 1201px) and (max-width: 1350px) {
    body.home .profile-blob-bg { 
		width: 450px !important; 
		height: 450px !important; 
		bottom: 40px; 
	}
	
    body.home .profile-main-photo {
		max-height: 430px !important;
	}
}

@media (max-width: 1200px) {
    body.home .profile-btn-primary::before,
    body.home .profile-btn-secondary::before {
        display: none !important; 
    }

    body.home .profile-btn-primary:hover,
    body.home .profile-btn-secondary:hover {
        transform: none !important;
        box-shadow: none !important;
    }
	
    body.home .profile-btn-secondary:hover {
        color: var(--color-primary) !important;
        background-color: var(--bg-white) !important;
        border-color: #CBD5E1 !important;
    }

    body.home .profile-btn-primary:active {
        transform: scale(0.92) !important;
        transition: all 0.05s !important; 
        background-color: var(--color-primary-dark) !important;
    }

    body.home .profile-btn-secondary:active {
        transform: scale(0.92) !important;
        transition: all 0.05s !important;
        background-color: var(--color-accent) !important; 
        color: var(--color-primary) !important; 
        border-color: var(--color-primary) !important;
    }

    body.home .profile-summary-section {
		min-height: auto;
		padding: 60px 20px 80px 20px;
		display: block; height: auto;
	}
	
    body.home .profile-grid-wrapper {
		display: flex;
		flex-direction: column;
		height: auto; max-width: 700px;
		margin: 0 auto;
		gap: 0;
	}
	
    body.home .col-left,
	body.home .col-right,
	body.home .col-center {
		width: 100%;
		height: auto;
		padding: 0; align-items: center;
		text-align: center;
		justify-content: flex-start;
	}

    body.home .col-left {
		order: 1;
		margin-bottom: 80px;
	} 
	
    body.home .col-center {
		order: 2;
		margin-bottom: 60px;
		margin-top: 20px;
	}
	
    body.home .col-right  { 
		order: 3;
	}

    body.home .content-top-left, 
	body.home .content-bottom-left, 
	body.home .content-top-right, 
	body.home .content-bottom-right { 
		text-align: center; 
		align-items: center; 
		width: 100%; 
	}
	
    body.home .col-right { 
		text-align: center; 
		align-items: center; 
	}
    
    body.home .profile-headline { 
		font-size: 56px; 
		margin-bottom: 15px; 
	}
	
    body.home .profile-role-wrapper { 
		justify-content: center; 
		margin-bottom: 20px; 
	}
	
    body.home .content-bottom-left { 
		display: flex; 
		justify-content: center; 
		margin-top: 0; 
		position: static; 
	}

    body.home .col-center { 
		height: 560px; 
		position: relative; 
	}
	
    body.home .profile-blob-bg { 
        width: 540px !important; 
		height: 540px !important; 
		position: absolute; 
		bottom: 60px; 
        left: 50%; 
		transform: translateX(-50%); 
		margin: 0; 
    }
	
    body.home .profile-main-photo { 
		max-height: 540px !important; 
		width: auto; margin: 0 auto; 
		position: absolute; 
		bottom: 0; 
		left: 50%; 
		transform: translateX(-50%); 
		z-index: 2; 
	}
	
    body.home .profile-bio-desc { 
		max-width: 80%; 
		margin-bottom: 30px;
		margin-left: auto; 
		margin-right: auto; 
	}
	
    body.home .content-bottom-right { 
		gap: 15px; 
		width: 100%; 
		padding-bottom: 20px; 
	}
}

@media (max-width: 768px) {
    body.home .col-left { 
		margin-bottom: 80px !important; 
	}
	
    body.home .col-center { 
		height: 480px; 
		margin-bottom: 50px;
		margin-top: 0;
	}
    
    body.home .profile-blob-bg { 
		width: 440px !important;
		height: 440px !important; 
		bottom: 90px !important;
	}
    
    body.home .profile-main-photo { 
		max-height: 460px !important;
	}
	
    body.home .profile-headline { 
		font-size: 52px;
		letter-spacing: -1px; 
	}
	
    body.home .profile-stat-number { 
		font-size: 56px;
	}
	
    body.home .profile-role-text {
		font-size: 16px; 
	}
	
    body.home .profile-bio-desc { 
		max-width: 90%; font-size: 16px; 
	}
}

@media (max-width: 480px) {
    body.home .col-left { 
		margin-bottom: 60px !important; 
	}
	
    body.home .profile-headline { 
		font-size: 44px;
	} 
	
    body.home .col-center { 
		height: 320px; 
		margin-bottom: 40px;
	}
    
    body.home .profile-blob-bg { 
        width: 280px !important; 
		height: 280px !important;
		bottom: 60px !important; 
    }
    
    body.home .profile-main-photo { 
		max-height: 300px !important;
	}
	
    body.home .profile-btn-primary, 
	body.home .profile-btn-secondary { 
		width: 100%;
	}
}


/* 7.3 Featured Projects */
body.home .featured-projects-section {
    background-color: var(--bg-white); 
    border-top: none; 
    padding-top: 100px;
    padding-bottom: 100px;
    font-family: var(--font-body);
}

body.home .featured-projects-container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 40px;
    box-sizing: border-box;
}

body.home .featured-header {
    text-align: center;
    margin-bottom: 70px;
}

body.home .featured-header h2 {
    font-family: var(--font-heading);
    font-size: 36px;
    font-weight: 800;
    color: var(--text-dark); 
    margin: 0 0 20px 0;
    letter-spacing: -0.5px;
    position: relative;
    display: inline-block;
    border-bottom: none;
}

body.home .featured-header h2::after {
    content: "";
    display: block;
    width: 60px;
    height: 5px;
    background-color: var(--color-primary); 
    margin: 15px auto 0;
    border-radius: 10px;
}

body.home .featured-header p {
    font-size: 16px;
    color: var(--text-muted);
    margin: 20px auto 0;
    max-width: 650px;
    line-height: 1.6;
}

body.home .featured-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    margin-bottom: 60px;
}

body.home .project-card {
    background-color: var(--bg-white);
    border-radius: 16px;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--color-border); 
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
    height: 100%;
    position: relative; 
}

body.home .project-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 25px -5px rgba(37, 99, 235, 0.1), 0 10px 10px -5px rgba(37, 99, 235, 0.04);
    border-color: var(--color-primary); 
}

body.home .project-content {
    padding: 35px 30px 35px 30px; 
    text-align: left;
    flex-grow: 1; 
    display: flex;
    flex-direction: column; 
}

body.home .project-icon-box {
    width: 48px;
    height: 48px;
    background-color: var(--color-primary); 
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    color: var(--bg-white);
    flex-shrink: 0; 
}

body.home .project-icon-box svg {
    width: 24px;
    height: 24px;
    fill: currentColor;
}

body.home .project-content h3 {
    margin: 0 0 12px 0;
    font-family: var(--font-heading);
    font-size: 20px;
    font-weight: 700;
    color: var(--text-dark);
    line-height: 1.4;
}

body.home .project-content p {
    margin: 0;
    font-size: 15px;
    color: var(--text-muted); 
    line-height: 1.6;
    margin-bottom: 30px;
}

body.home .project-badge {
    position: static; 
    bottom: auto; 
    right: auto;
    margin-top: auto;
    align-self: flex-end;
    z-index: 5;
    background-color: var(--bg-light);
    color: #475569;
    border: 1px solid var(--color-border);
    padding: 6px 14px;
    border-radius: 50px;
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

body.home .badge-highlight {
    background-color: var(--color-accent); 
    color: var(--color-primary); 
    border: 1px solid #BFDBFE; 
}

body.home .featured-footer {
    text-align: center;
    margin-top: 35px;
    margin-bottom: 20px;
}

body.home .btn-view-all {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: transparent; 
    border: none;
    padding: 10px 20px;
    text-decoration: none;
    font-weight: 700;
    font-size: 16px;
    color: var(--color-primary) !important; 
    transition: all 0.3s ease;
}

body.home .btn-view-all .arrow {
    display: inline-block;
    margin-left: 10px;
    transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

body.home .btn-view-all:hover {
    color: var(--color-primary-dark) !important; 
    opacity: 1;
}

body.home .btn-view-all:hover .arrow {
    transform: translateX(6px);
}

@media (max-width: 1200px) {
    body.home .featured-projects-section {
        padding: 60px 0;
    }

    body.home .featured-projects-container {
        padding: 0 24px;
		max-width: 640px;
    }
    
    body.home .featured-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }
    
    body.home .project-content {
        padding: 30px;
    }
    
    body.home .featured-header h2 {
        font-size: 30px;
    }
}

/* 7.4 Journey Section */
body.home .journey-section {
    background-color: var(--bg-light); 
    padding: 100px 20px 140px;
    position: relative;
    overflow: hidden;
    font-family: var(--font-body);
}

body.home .journey-header {
    text-align: center;
    margin: 0 auto 60px;
}

body.home .journey-header h2 {
	font-family: var(--font-heading);
    font-size: 36px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0 0 20px 0;
    letter-spacing: -0.5px;
    position: relative;
    display: inline-block;
    border-bottom: none;
}

body.home .journey-header h2::after {
    content: "";
    display: block;
    width: 60px;
    height: 5px;
    background-color: var(--color-primary); 
    margin: 15px auto 0;
    border-radius: 10px;
}

body.home .journey-nav-wrapper { 
    display: flex; 
    justify-content: center; 
    gap: 15px; 
    margin-bottom: 80px; 
    flex-wrap: wrap; 
}

body.home .journey-nav-btn {
    padding: 12px 30px; 
    background: var(--bg-white); 
    color: var(--text-muted); 
    border: 1px solid var(--color-border); 
    border-radius: 50px;
    font-size: 15px; 
    font-weight: 600; 
    cursor: pointer; 
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0,0,0,0.02);
    text-align: center;
}

body.home .journey-nav-btn:hover { 
    border-color: var(--color-primary); 
    color: var(--color-primary); 
    transform: translateY(-2px); 
}

body.home .journey-nav-btn.active {
    background: var(--color-primary); 
    color: var(--bg-white); 
    border-color: var(--color-primary);
    box-shadow: 0 8px 20px rgba(37, 99, 235, 0.25); 
    transform: translateY(-2px);
    font-weight: 700;
}

body.home .journey-content-wrapper { 
	max-width: 1100px; 
	margin: 0 auto;
}

body.home .journey-tab-panel {
	display: none; 
	animation: fadeInMove 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

body.home .journey-tab-panel.active { 
	display: block;
}

@keyframes fadeInMove { 
	from { 
		opacity: 0;
		transform: translateY(20px); 
	} 
	to {
		opacity: 1; 
		transform: translateY(0); 
	} 
}

body.home .journey-timeline-row { 
    display: flex; 
    justify-content: center;
    align-items: stretch; 
    position: relative; 
    padding-bottom: 0; 
    margin-bottom: 80px;
}

body.home .journey-col-left { 
    width: 45%; 
	text-align: right; 
	padding-right: 40px;
	padding-top: 0; 
}

body.home .journey-company-group {
	display: flex;
	flex-direction: column;
	align-items: flex-end; 
}

body.home .journey-company-name { 
    font-family: var(--font-heading);
    font-size: 22px; 
    font-weight: 800; 
    color: var(--text-dark); 
    margin: 0 0 5px 0; 
    line-height: 1.2; 
}

body.home .journey-date-row { 
	font-size: 15px; 
	color: #475569;
	font-weight: 600;
}

body.home .journey-duration-text { 
	font-size: 14px; 
	color: #94a3b8;
	font-weight: 400; 
	margin-top: 2px;
	display:block;
}

body.home .journey-col-center { 
    width: 60px; position: relative; 
	flex-shrink: 0; 
    display: flex; 
	justify-content: center; 
}

body.home .journey-line {
    position: absolute; 
    top: 20px; 
    bottom: -100px; 
    width: 2px;
    border-left: 2px dashed #CBD5E1; 
    left: 50%; transform: translateX(-50%); 
    z-index: 0;
}

body.home .journey-dot {
    width: 24px; 
	height: 24px; 
	border-radius: 50%;
	z-index: 2; 
	margin-top: 5px; 
	position: relative;
    background-color: var(--bg-white);
    border: 2px solid var(--color-primary); 
    box-shadow: 0 0 0 4px var(--bg-light); 
    display: flex; 
	align-items: center; 
	justify-content: center;
}

body.home .journey-dot::after { 
    content: '';
	width: 10px;
	height: 10px;
	border-radius: 50%; 
    background-color: var(--color-primary); 
}

body.home .dot-blue::after {
	background-color: var(--color-primary); 
}

body.home .journey-col-right { 
    width: 45%; 
	padding-left: 40px; 
	padding-top: 0;
}

body.home .journey-role-block {
    margin-bottom: 40px; 
    position: relative;
}

body.home .journey-role-block:last-child {
    margin-bottom: 0;
}

body.home .journey-role-title { 
    font-family: var(--font-heading);
    font-size: 20px; font-weight: 700; color: var(--text-dark); 
    margin: 0 0 5px 0; 
    line-height: 1.4; 
}

body.home .journey-role-title + .journey-desc {
    margin-top: 15px; 
}

body.home .journey-role-specific-date {
    font-size: 14px;
    color: var(--text-muted);
    font-weight: 600;
    margin-bottom: 15px; 
    display: block;
}

body.home .journey-desc { 
    font-size: 15px; color: var(--text-muted); line-height: 1.7; 
    margin-bottom: 25px; 
}

body.home .journey-link { 
    display: inline-flex; 
	align-items: center; 
	font-size: 14px; 
	font-weight: 700; 
    color: var(--color-primary); 
	text-decoration: none; 
    padding-bottom: 2px;
    transition: all 0.2s; 
}

body.home .journey-link:hover { 
	color: var(--color-primary-dark); 
	transform:translateX(4px);
}

body.home .journey-link span { 
	margin-left: 5px; 
	transition: margin 0.2s;
}

body.home .journey-start-node {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: -20px;
    position: relative;
    z-index: 2;
}

body.home .journey-start-badge {
    background-color: var(--bg-white);
    color: var(--color-primary); 
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 10px 24px;
    border-radius: 50px;
    border: 1px solid #CBD5E1; 
    box-shadow: 0 4px 6px rgba(0,0,0,0.03);
}

@media screen and (max-width: 768px) {
    body.home .journey-section { 
		padding: 60px 24px 80px;
	}
    
    body.home .journey-nav-wrapper {
        display: flex;
        flex-direction: column;
        gap: 12px;
        margin-bottom: 40px;
        align-items: stretch; 
    }
	
    body.home .journey-nav-btn {
        width: 100%; 
        text-align: center;
        margin: 0;
        padding: 14px 20px; 
    }
    
    body.home .journey-col-center { 
		display: none; 
	} 
    
    body.home .journey-timeline-row { 
        flex-direction: column; 
        padding-bottom: 40px; 
        margin-left: 15px; 
        border-left: 2px dashed #CBD5E1; 
        padding-left: 30px;
		padding-right: 5%;
        margin-bottom: 0;
        align-items: flex-start; 
        position: relative;
    }
    
    body.home .journey-timeline-row::before {
        content: '';
        position: absolute;
		left: -7px;
		top: 0;
        width: 12px; height: 12px;
		border-radius: 50%;
        background: var(--color-primary); 
		border: 2px solid var(--bg-white);
        box-shadow: 0 0 0 2px var(--color-primary);
    }

    body.home .journey-timeline-row:last-child {
        border-left: 2px dashed #CBD5E1;
    }

    body.home .journey-company-name {
        font-size: 20px; 
        margin-bottom: 5px;
        color: var(--text-dark); 
    }
	
    body.home .journey-role-title {
        font-size: 18px; 
        margin-bottom: 10px;
        color: var(--text-dark);
    }

    body.home .journey-col-left { 
		width: 100%; 
		text-align: left; 
		padding-right: 0; 
		margin-bottom: 20px;
	}
	
    body.home .journey-company-group { 
		align-items: flex-start; 
	}
	
    body.home .journey-duration-text {
		display: inline-block;
		margin-left: 5px; 
		margin-top: 0; 
	}
	
    body.home .journey-col-right { 
		width: 100%;
		padding-left: 0; 
	}
    
    body.home .journey-start-badge {
        display: none;
    }

    body.home .journey-start-node { 
        display: block;
        margin-top: -5px; 
        margin-left: 15px;
        position: relative;
        height: 20px;
        width: 20px;
    } 

    body.home .journey-start-node::before {
        content: '';
        display: block;
        width: 12px; 
		height: 12px; 
		border-radius: 50%;
        background: var(--color-primary);
		border: 2px solid var(--bg-white);
        box-shadow: 0 0 0 2px var(--color-primary);
        position: absolute;
        left: 1px; 
        transform: translateX(-50%);        
        top: 0;
        z-index: 2;
    }
}

/* 7.5 Expertise Section */
body.home .expertise-section {
    padding: 100px 20px;
    background-color: var(--bg-white); 
}

body.home .expertise-container {
    max-width: 1100px;
    margin: 0 auto;
}

body.home .expertise-header {
    text-align: center;
    margin-bottom: 60px;
}

body.home .expertise-header h2 {	
	font-family: var(--font-heading);
    font-size: 36px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0 0 20px 0;
    letter-spacing: -0.5px;
    position: relative;
    display: inline-block;
    border-bottom: none;
}

body.home .expertise-header h2::after {
    content: "";
    display: block;
    width: 60px;
    height: 5px;
    background-color: var(--color-primary); 
    margin: 15px auto 0;
    border-radius: 10px;
}

body.home .expertise-header p {
    color: var(--text-muted);
    font-size: 16px;
    margin: 0;
    line-height: 1.6;
    max-width: 600px;
    margin: 10px auto 0;
}

body.home .expertise-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr); 
    gap: 30px; 
}

body.home .expertise-card {
    display: flex;
    align-items: center; 
    background: var(--bg-white);
    border: 1px solid var(--color-border); 
    border-radius: 24px; 
    padding: 30px; 
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    position: relative; 
    overflow: hidden;
    cursor: default; 
}

body.home .expertise-card:hover {
    border-color: #BFDBFE; 
    box-shadow: 0 15px 35px -5px rgba(37, 99, 235, 0.15); 
    transform: translateY(-5px);
}

body.home .expertise-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-right: 20px;
    color: var(--bg-white); 
    font-size: 24px;
    transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

body.home .expertise-card:hover .expertise-icon {
    transform: scale(1.1) rotate(6deg);
}

body.home .expertise-icon .dashicons {
    font-size: 28px; 
    width: auto;
    height: auto;
    line-height: 1;
}

body.home .expertise-icon.blue {
    background-color: var(--color-primary); 
}

body.home .expertise-icon.yellow {
    background-color: #F59E0B; 
}

body.home .expertise-content {
    flex: 1; 
}

body.home .expertise-badge {
    position: absolute; 
    top: 25px;          
    right: 25px;            
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 4px 10px;
    border-radius: 6px;
    background-color: #ECFDF5; 
    color: #059669; 
    border: 1px solid #A7F3D0;
    z-index: 2;
}

body.home .expertise-content h3 {
    margin: 0 0 15px 0; 
    font-size: 18px;
    font-weight: 700;
    color: var(--text-dark);
    line-height: 1.3;
    padding-right: 10px; 
}

body.home .expertise-content p {
    margin: 0;
    font-size: 15px;
    line-height: 1.6;
    color: var(--text-muted);
}

body.home .expertise-footer {
    margin-top: 45px;
    padding-top: 40px;
    text-align: center;
}

body.home .expertise-footer h3 {
    font-size: 13px;
    font-weight: 700;
    color: #94A3B8;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 25px;
}

body.home .expertise-footer-grid {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px;
}

body.home .expertise-pill {
    background: var(--bg-light);
    border: 1px solid var(--color-border);
    border-radius: 50px;
    padding: 10px 24px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 600;
    color: #475569;
    transition: all 0.3s ease;
	cursor: default;
}

body.home .expertise-pill .dashicons {
    font-size: 18px;
    width: auto; height: auto;
    color: #94A3B8; 
    transition: color 0.3s;
    line-height: 1;
}

body.home .expertise-pill:hover {
    background: var(--bg-white);
    border-color: var(--color-primary); 
    color: var(--color-primary); 
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.1);
}

body.home .expertise-pill:hover .dashicons {
    color: var(--color-primary);
}

@media (max-width: 1140px) {
    body.home .expertise-header h2 { 
		font-size: 28px;
	}
	
    body.home .expertise-header p { 
		font-size: 15px;
	}

    body.home .expertise-grid {
        grid-template-columns: 1fr;
        gap: 15px;
        max-width: 640px;
        margin: 0px auto;
    }
    
    body.home .expertise-card {
        padding: 20px;
        border-radius: 16px;
        flex-direction: row; 
        align-items: center;
        text-align: left;
    }

    body.home .expertise-badge {
        position: static; 
        display: inline-block;
        margin-bottom: 10px; 
        top: auto; 
        right: auto;
    }
    
    body.home .expertise-icon {
        width: 48px; height: 48px;
        font-size: 20px;
        margin-right: 15px;
        border-radius: 12px;
        margin-bottom: 0; 
    }
    
    body.home .expertise-icon .dashicons {
		font-size: 22px;
	}
    
    body.home .expertise-content h3 { 
		font-size: 17px; 
		margin-bottom: 8px; 
	}
	
    body.home .expertise-content p { 
		font-size: 14px; 
	}

    body.home .expertise-footer-grid {
		gap: 8px;
	}
	
    body.home .expertise-pill { 
		padding: 8px 16px;
		font-size: 13px; 
	}
}

/* 7.6 Certification Section */
body.home .cert-section {
    padding: 100px 40px;
    background: var(--bg-light); 
    margin: 0;
}

body.home .cert-container {
    width: 100%;
    max-width: 950px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
}

body.home .cert-section-title {
    font-family: var(--font-heading);
    color: var(--text-dark);
    font-size: 36px;
    font-weight: 800;
    margin: 0 0 20px 0;
    letter-spacing: -0.5px;
    position: relative;
    display: inline-block;
    border-bottom: none;
    text-align: center;
}

body.home .cert-section-title::after {
    content: "";
    display: block;
    width: 60px;
    height: 5px;
    background-color: var(--color-primary);
    margin: 15px auto 0;
    border-radius: 10px;
}

body.home .cert-section-desc {
    font-size: 16px;
    color: var(--text-muted);
    max-width: 600px;
    line-height: 1.6em;
    margin: 10px auto 60px;
    text-align: center;
    display: block;
}

body.home .cert-list {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 0; 
}

body.home .cert-item {
    display: flex;
    flex-direction: row;
    align-items: flex-start; 
    padding: 40px 0;
    border-bottom: 1px solid #E2E8F0;
    background: transparent;
    position: relative;
}

body.home .cert-item:last-child {
    border-bottom: none;
}

body.home .cert-visual {
    width: 260px;
    flex-shrink: 0;
    margin-right: 40px;
}

body.home .cert-img-wrapper {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(0,0,0,0.08);
    border: 1px solid #F1F5F9;
    position: relative;
}

body.home .cert-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
    transition: transform 0.5s ease;
}

body.home .cert-item:hover .cert-img {
    transform: scale(1.05);
}

body.home .cert-img-wrapper::before {
    position: absolute;
    top: 0;
    left: -75%;
    z-index: 2;
    display: block;
    content: '';
    width: 50%;
    height: 100%;
    background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,0.4) 100%);
    transform: skewX(-25deg);
}

body.home .cert-item:hover .cert-img-wrapper::before {
    animation: shine 0.75s;
}

@keyframes shine {
    100% {
        left: 125%;
    }
}

body.home .cert-content {
    flex-grow: 1;
    padding-right: 20px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

body.home .cert-header {
    display: flex;
    flex-direction: column; 
    align-items: flex-start;
    gap: 8px; 
    margin-bottom: 15px;
}

body.home .cert-header h3 {
    font-size: 22px;
    font-weight: 800;
    color: var(--text-dark);
    margin: 0;
    line-height: 1.3em;
}

body.home .cert-badge {
    font-size: 10px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    display: inline-block;
}

body.home .cert-badge.active {
    background: #ECFDF5;
    color: #059669;
    border: 1px solid #A7F3D0;
}

body.home .cert-badge.pending {
    background: var(--bg-white);
    color: #E11D48;
    border: 1px solid #FECDD3;
}

body.home .cert-meta {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 20px;
}

body.home .cert-meta-row {
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-body);
    font-size: 14px;
    color: var(--text-muted);
    line-height: 1.4;
}

body.home .cert-meta-row strong {
    color: var(--text-body);
    font-weight: 600;
}

body.home .cert-meta-row .dashicons {
    font-size: 18px;
    width: 18px;
    height: 18px;
    color: var(--color-primary);
    opacity: 1;
}

body.home .cert-desc {
    font-family: var(--font-body);
    font-size: 15px;
    line-height: 1.7em;
    color: #475569;
    margin: 0 0 10px 0;
}

body.home .cert-actions {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-width: 150px; 
    align-items: flex-end;
    padding-top: 5px;
}

body.home .cert-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 16px; 
    border-radius: 8px; 
    font-family: var(--font-body);
    font-size: 13px; 
    font-weight: 600;
    text-decoration: none;
    transition: all 0.2s ease;
    line-height: 1;
    white-space: nowrap;
    cursor: pointer;
    width: auto;
    min-width: 140px; 
}

body.home .cert-btn.primary {
    background: var(--color-primary);
    color: var(--bg-white);
    border: 1px solid var(--color-primary);
    box-shadow: 0 4px 6px -1px rgba(37, 99, 235, 0.3);
}

body.home .cert-btn.primary:hover {
    background: var(--color-primary);
    color: var(--bg-white);
    border-color: var(--color-primary);
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(37, 99, 235, 0.4);
}

body.home .cert-btn.secondary {
    background: transparent;
    color: var(--text-muted);
    border: 1px solid transparent;
    font-size: 12px;
}

body.home .cert-btn.secondary:hover {
    color: var(--color-primary);
    text-decoration: none !important;
    background: transparent;
    opacity: 0.8; 
    transform: none;
}

body.home .cert-btn.disabled {
    background: #F8FAFC;
    color: #94A3B8;
    border: 1px solid #E2E8F0;
    cursor: default;
    box-shadow: none;
}

body.home .cert-btn .dashicons {
    margin-left: 6px;
    font-size: 14px;
    width: 14px;
    height: 14px;
}

body.home .cert-footer {
    text-align: center;
    margin-top: 50px;
    margin-bottom: 20px;
}

body.home .btn-cert-view-all {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    border: none;
    padding: 10px 20px;
    text-decoration: none;
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 16px;
    color: var(--color-primary) !important;
    transition: all 0.3s ease;
}

body.home .btn-cert-view-all .arrow {
    display: inline-block;
    margin-left: 10px;
    transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

body.home .btn-cert-view-all:hover {
    background-color: transparent;
    color: var(--color-primary-dark) !important;
}

body.home .btn-cert-view-all:hover .arrow {
    transform: translateX(6px);
}

@media (max-width: 900px) {
    body.home .cert-section {
        padding: 100px 20px;
    }
    
    body.home .cert-container {
        max-width: 640px;
    }

    body.home .cert-item {
        flex-direction: column;
        align-items: flex-start;
        padding: 40px 0;
    }

    body.home .cert-visual {
        width: 100%;
        margin-right: 0;
        margin-bottom: 25px;
    }

    body.home .cert-img-wrapper {
        aspect-ratio: 16/9;
    }

    body.home .cert-content {
        width: 100%;
        padding-right: 0;
        margin-bottom: 25px;
    }

    body.home .cert-actions {
        width: 100%;
        flex-direction: row; 
        align-items: center;
        justify-content: flex-start;
        gap: 15px;
    }

    body.home .cert-btn {
        min-width: auto;
        padding: 10px 20px;
    }
}

/* 7.6 Reason Section */
body.home .reason-section {
    padding: 80px 5%;
    background-color: var(--bg-white);
}

body.home .reason-header {
    text-align: center;
    max-width: 700px;
    margin: 0 auto 60px;
    padding: 0 20px;
}

body.home .reason-title {
	font-family:var(--font-heading);
    color: var(--text-dark);
    font-size: 36px;
    font-weight: 800;
    margin: 0 0 20px 0;
    letter-spacing: -0.5px;
    position: relative;
    display: inline-block;
    border-bottom: none;
}


body.home .reason-title::after {
    content: '';
    display: block;
    width: 60px;
    height: 5px;
    background-color: var(--color-primary);
    margin: 15px auto 0;
    border-radius: 10px;
}

body.home .reason-subtitle {
    font-size: 16px;
    color: var(--text-muted);
    max-width: 600px;
    line-height: 1.6em;
    margin: 10px auto 60px;
    text-align: center;
    display: block;
}

body.home .reason-wrapper {
    max-width: 1000px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    border: 1px solid var(--color-border); 
    border-radius: 24px; 
    overflow: hidden;
    background-color: var(--bg-white);
}

body.home .reason-item {
    display: flex; 
    align-items: flex-start;
    padding: 35px;
    gap: 25px;
    border-right: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    transition: background-color 0.3s ease;
}

body.home .reason-item:nth-child(2n) {
    border-right: none;
}

body.home .reason-item:nth-last-child(-n+2) {
    border-bottom: none;
}


body.home .reason-item:hover {
    background-color:var(--bg-light); 
}

body.home .reason-icon {
    flex-shrink: 0;
    width: 50px;
    height: 50px;
    background-color: var(--color-accent);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

body.home .reason-item:hover .reason-icon {
    background-color: var(--color-primary);
}

body.home .reason-icon .dashicons,
body.home .reason-icon i {
    font-size: 24px;
    color: var(--color-primary);
    width: auto;
    height: auto;
    transition: color 0.3s ease;
}

body.home .reason-item:hover .reason-icon .dashicons,
body.home .reason-item:hover .reason-icon i {
    color: var(--bg-white);
}

body.home .reason-content {
    flex-grow: 1;
}

body.home .reason-item h3 {
	font-family:var(--font-heading);
    font-size: 20px;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0 0 15px 0;
    line-height: 1.3;
}

body.home .reason-item p {
    font-size: 14px;
    color: var(--text-muted);
    line-height: 1.6;
    margin: 0;
}

@media (max-width: 768px) {
    body.home .reason-wrapper {
        grid-template-columns: 1fr;
        border-radius: 16px;
    }

    body.home .reason-item {
        border-right: none;
        border-bottom: 1px solid var(--color-border);
        padding: 30px 25px;
    }
    
    body.home .reason-item:last-child {
        border-bottom: none;
    }
}

/* 7.7 Testimonial Section */
body.home .testi-section {
    padding: 100px 5%;
    background-color: var(--bg-light);
    background-image: none;
    overflow: hidden;
}

body.home .testi-container {
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
}

body.home .testi-header {
    text-align: center;
    max-width: 700px;
    margin: 0 auto 60px;
    padding: 0 20px;
}

body.home .testi-title {
	font-family: var(--font-heading);
    color: var(--text-dark);
    font-size: 36px;
    font-weight: 800;
    margin: 0 0 20px 0;
    letter-spacing: -0.5px;
    position: relative;
    display: inline-block;
}

body.home .testi-title::after {
    content: '';
    display: block;
    width: 60px;
    height: 5px;
    background-color: var(--color-primary);
    margin: 15px auto 0;
    border-radius: 10px;
}

body.home .testi-desc {
    font-size: 16px;
    color: var(--text-muted);
    max-width: 600px;
    line-height: 1.6em;
    margin: 10px auto 60px;
    text-align: center;
    display: block;
}

body.home .testi-slider-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 20px;
}

body.home .testi-track {
    display: flex;
    gap: 30px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding: 40px 10px;
    width: 100%;
    scrollbar-width: none;
    -ms-overflow-style: none;
    scroll-behavior: smooth;
}

body.home .testi-track::-webkit-scrollbar { 
	display: none;
}

body.home .testi-card {
    min-width: 350px;
    max-width: 350px;
    background: var(--bg-white);
    border-radius: 24px;
    padding: 40px;
    display: flex;
    flex-direction: column;
    position: relative;
    scroll-snap-align: center;
    border: 1px solid var(--color-border);
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
    transition: all 0.3s ease;
    height: auto;
    min-height: 420px;
}

body.home .testi-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
    border-color: var(--color-primary);
}

body.home .testi-card-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 15px;
    margin-bottom: 25px;
    padding-bottom: 25px;
    border-bottom: 1px solid #F1F5F9;
}

body.home .testi-avatar {
    width: 80px;
    height: 80px;
    flex-shrink: 0;
    margin: 0 auto;
}

body.home .letter-avatar {
    width: 80px !important; 
    height: 80px !important;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 4px solid var(--bg-white);
    box-shadow: 0 4px 10px rgba(0,0,0,0.08);
    line-height: 1; 
}

body.home .letter-avatar.orange {
    background: linear-gradient(135deg, #F59E0B, #EA580C);
    color: var(--bg-white);
    font-size: 32px; 
    font-weight: 800;
}

body.home .letter-avatar.blue {
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));
    color: var(--bg-white);
    font-size: 28px;
    font-weight: 700;
}

body.home .testi-avatar img {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid var(--bg-white);
    box-shadow: 0 4px 10px rgba(0,0,0,0.08);
}

body.home .testi-profile {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
}

body.home .testi-name {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text-dark);
    margin: 0;
}

body.home .testi-role {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-primary);
    margin: 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

body.home .testi-company {
    font-size: 0.875rem;
    color: var(--text-muted);
    margin: 0;
}

body.home .testi-body {
    margin-bottom: auto;
    text-align: center;
}

body.home .testi-body p {
    font-size: 1rem;
    line-height: 1.6;
    color: var(--text-body);
    font-style: italic;
    margin: 0;
}

body.home .testi-footer {
    margin-top: 30px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-muted);
    background: var(--bg-light);
    border: 1px solid var(--color-border);
    padding: 8px 16px;
    border-radius: 50px;
    align-self: center;
}

body.home .testi-footer .dashicons { 
    font-size: 16px; 
    color: #94A3B8; 
}

body.home .testi-card.blur-card {
    overflow: hidden;
    user-select: none;
    background: var(--bg-white);
}

body.home .testi-card.blur-card .testi-card-header,
body.home .testi-card.blur-card .testi-body,
body.home .testi-card.blur-card .testi-footer {
    filter: blur(6px);
    opacity: 0.4;
    pointer-events: none;
}

body.home .testi-card.blur-card::after {
    content: "Coming Soon";
	text-align: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 5;
    background: var(--bg-light);
    border: 1px solid var(--color-border);
    padding: 10px 24px;
    border-radius: 50px;
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    box-shadow: 0 10px 25px rgba(0,0,0,0.05);
}

body.home .testi-nav-btn {
    background: var(--bg-white);
    width: 50px;
    height: 50px;
    padding: 0; 
    border-radius: 50%;
    border: 1px solid var(--color-border);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    outline: none;
}

body.home .testi-nav-btn .dashicons { 
    font-size: 20px; 
    color: var(--text-dark); 
    width: auto;
    height: auto;
    line-height: 1; 
    transition: color 0.3s ease; 
}

body.home .prev-btn {
	left: -25px;
}

body.home .next-btn {
	right: -25px;
}

body.home .testi-nav-btn:hover {
    background: var(--color-primary);
    border-color: var(--color-primary);
    transform: translateY(-50%) scale(1.1);
    box-shadow: 0 10px 20px rgba(37, 99, 235, 0.3);
}

body.home .testi-nav-btn:hover .dashicons {
	color: var(--bg-white); 
}

body.home .testi-nav-btn:active { 
	background: var(--color-primary-dark);
	transform: translateY(-50%) scale(0.95);
}

@media (max-width: 900px) {
    body.home .testi-nav-btn { 
		display: none; 
	}
    
    body.home .testi-section { 
		padding: 80px 0;
	}
    
    body.home .testi-track { 
        padding-left: 20px; 
        padding-right: 20px; 
        gap: 20px; 
    }
    
    body.home .testi-card { 
        min-width: 300px; 
        max-width: 300px; 
        padding: 30px; 
        min-height: 400px; 
    }
}

/* 7.8 Connect Section */
body.home .connect-section {
    padding: 100px 20px 40px; 
    background: var(--bg-white); 
}

body.home .connect-container {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
}

body.home .connect-header {
    margin-bottom: 40px;
    padding: 0 10px;
}

body.home .connect-title {
	font-family: var(--font-heading);
    color: var(--text-dark);
    font-size: 36px;
    font-weight: 800;
    margin: 0 0 20px 0;
    letter-spacing: -0.5px;
    position: relative;
    display: inline-block;
	border-bottom: none;
}

body.home .connect-title::after {
    content: '';
    display: block;
    width: 60px;
    height: 5px;
    background-color: var(--color-primary); 
    margin: 15px auto 0;
    border-radius: 10px;
}

body.home .connect-desc {
	font-size: 16px;
    color: var(--text-muted);
    max-width: 600px;
    line-height: 1.6em;
    margin: 10px auto 60px;
    text-align: center;
    display: block;
}

body.home .connect-cta-wrapper {
    margin-bottom: 40px;
    display: flex;
    flex-direction: column;
    align-items: center; 
}

body.home .btn-email-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    background-color: var(--color-primary);
    color: var(--bg-white);
    font-size: 16px;
    font-weight: 700;
    padding: 16px 36px;
    border-radius: 50px;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    box-shadow: 0 10px 20px -5px rgba(37, 99, 235, 0.4);
}

body.home .btn-email-primary:hover {
    background-color: var(--color-primary-dark);
    transform: translateY(-3px);
    box-shadow: 0 15px 30px -5px rgba(37, 99, 235, 0.5);
}

body.home .btn-email-primary svg {
    width: 20px; height: 20px;
    fill: currentColor;
    margin-top: -2px;
}

body.home .connect-divider {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    margin-bottom: 30px;
    color: #94A3B8;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}

body.home .connect-divider::before,
body.home .connect-divider::after {
    content: "";
    display: block;
    width: 60px;
    height: 1px;
    background-color: var(--color-border);
}

body.home .social-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
    flex-wrap: wrap;
}

body.home .social-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;  
    background-color:var(--color-accent); 
    color: var(--color-primary);            
    border: 1px solid transparent;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

body.home .social-btn svg {
    width: 24px;
    height: 24px;
    fill: currentColor;
    transition: transform 0.3s ease;
}

body.home .social-btn:hover {
    background-color: var(--color-primary);
    color: var(--bg-white);
    transform: translateY(-5px);
    box-shadow: 0 10px 20px -5px rgba(37, 99, 235, 0.3);
}

body.home .social-btn:hover svg {
    transform: scale(1.1);
}

@media (max-width: 600px) {
    body.home .connect-section { 
		padding: 80px 20px; 
	}
	
    body.home .connect-title { 
		font-size: 28px; 
	}   
	
    body.home .btn-email-primary {
        width: 100%; 
    }

    body.home .social-btn {
        width: 48px;
        height: 48px;
    }
	
    body.home .social-btn svg {
        width: 20px; height: 20px;
    }
}

/* ==========================================================================
   BAGIAN 8: ARCHIVE BLOG PORTOFOLIO SERTIFIKAT
   --------------------------------------------------------------------------
   8.0 Global Archive
   8.1 Blog Archive Content Layout
   8.2 Portfolio & Sertifikat Archive Breadcrumbs & Page Titles
   8.3 Portfolio & Sertifikat Archive Filter
   8.4 Portfolio & Sertifikat Archive Content Layout
   8.5 Portfolio Archive Content Layout
   8.6 Sertifikat Archive Content Layout
   ========================================================================== */

/* 8.0 Global Archive */
body.archive-no-results .entry {
    text-align: center;
}

/* 8.1 Blog Archive Content */
body.blog .custom-blog-title-heading {
    font-size: 16px;
    font-weight: 600;
    text-align: center;
    border-bottom: 1px solid var(--color-border);
    padding: 15px 10px;
    margin: 0 0 30px;
}

body.blog .content {
    float: none;
    max-width: 1200px;
    margin: 0 auto;
    padding: 50px 20px;
}

body.blog .articles {
    display: grid;
    grid-gap: 40px;
    grid-template-columns: repeat(3, 1fr);
    width: 100%;
}

body.blog .entry {
    margin-bottom: 0;
    padding: 0;
    border-radius: 8px;
}

body.blog .entry-content {
    padding: 0;
}

body.blog a.entry-image-link {
    display: block;
    overflow: hidden;
    border-radius: 8px;
    margin-bottom: 15px;
    position: relative;
}

body.blog a.entry-image-link img {
    display: block;
    width: 100%;
    height: 250px;
    object-fit: cover;
    border-radius: 8px;
    transition: transform 0.3s ease-in-out;
}

body.blog a.entry-image-link:hover img {
    transform: scale(1.1);
    opacity: 0.9;
}

body.blog .entry-title {
    margin-bottom: 10px;
}

body.blog .entry-title a {
    font-size: 18px;
    text-decoration: none;
    color: var(--text-dark);
    font-weight: 600;
    line-height: 1.4;
    display: block;
    transition: color 0.2s ease;
}

body.blog .entry-title a:hover,
body.blog .entry-title a:focus {
    color: var(--color-primary);
}

body.blog .entry-meta {
    font-size: 14px;
    font-weight: 400;
    color: var(--text-muted);
    line-height: 1.5;
    margin-top: 10px;
}

body.blog .entry-meta a {
    color: var(--text-muted);
    text-decoration: none;
    transition: color 0.2s;
}

body.blog .entry-meta a:hover {
    color: #c3251d;
}

@media only screen and (max-width: 768px) {
    body.blog .articles {
        grid-template-columns: 1fr;
        grid-gap: 30px;
    }
    
    body.blog .content {
        padding: 30px 20px;
    }
}

/* 8.2 Portofolio & Sertifikat Archive Breadcrumbs & Page Titles */
body.archive .breadcrumb,
.archive-description.cpt-archive-description,
.archive-description.taxonomy-archive-description {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    text-align: center;
}

body.archive .breadcrumb {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: #94a3b8;
    margin-top: 60px !important;
    margin-bottom: 30px !important;
}

.archive-description .archive-title {
    font-size: 48px;
    font-weight: 800;
    color: var(--text-dark);
    letter-spacing: -1.5px;
    line-height: 1.1;  
    margin: 0 auto;
    max-width: 900px;
    position: relative;
    display: block;
}

.archive-description .archive-title::after {
    content: "";
    display: block;
    width: 80px;
    height: 5px;
    background-color: #FFD058;
    border-radius: 10px;
    margin-top: 25px;
    margin-bottom: 35px;
    margin-left: auto;
    margin-right: auto;
}

.archive-description p {
    font-size: 16px;
    line-height: 1.8;
    color: #475569;    
    max-width: 700px;    
    margin: 0 auto 80px auto;
}

@media (max-width: 768px) {
    body.archive .breadcrumb {
        margin-top: 40px !important;
        margin-bottom: 20px !important;
    }
	
    .archive-description .archive-title {
        font-size: 32px;
        padding: 0 20px;
    }
	
    .archive-description .archive-title::after {
        margin-top: 20px;
        margin-bottom: 25px;
    }
	
    .archive-description p {
        padding: 0 20px;
        margin-bottom: 50px;
    }
}

/* 8.3 Portofolio & Sertifikat Archive Filter */
/* ==========================================================================
   UNIVERSAL FILTER SYSTEM (HYBRID: CHIPS & DROPDOWN)
   ========================================================================== */

/* --- 1. BASE: TAMPILAN DESKTOP (CHIPS) --- */

/* Container Utama (Hanya muncul di Desktop) */
.filter-scroll-container.desktop-view-only {
    display: flex;
    align-items: center;
    gap: 12px;
    
    /* Style Mas Hafid */
    background-color: var(--bg-light);
    border: 1px solid var(--color-border);
    border-radius: 60px;
    padding: 10px 12px;
    width: fit-content;
    max-width: 100%;
    margin: 0 auto 75px auto; /* Margin 75px sesuai request */
    position: relative;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
}

/* Sembunyikan elemen Mobile secara default */
.mobile-view-only {
    display: none !important;
}

/* Track Area (Scrollable) */
.filter-scroll-container .universal-filter-track {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 12px;    
    flex-grow: 1;
    width: 100%;
    scrollbar-width: none;
    -ms-overflow-style: none;
    scroll-behavior: smooth;
    
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.filter-scroll-container .universal-filter-track::-webkit-scrollbar {
    display: none;
}

/* Tombol Pills */
.filter-scroll-container .filter-btn {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;    
    
    padding: 10px 24px;
    border-radius: 50px;    
    font-size: 15px;
    font-weight: 600;
    color: var(--text-muted);    
    
    background-color: transparent;
    border: 1px solid transparent;   
    text-decoration: none;
    transition: all 0.2s ease;
    cursor: pointer;
    white-space: nowrap;
    line-height: 1;
}

.filter-scroll-container .filter-btn:hover {
    color: var(--color-primary);
    background-color: rgba(37, 99, 235, 0.1);
}

.filter-scroll-container .filter-btn.active {
    background-color: var(--color-primary);
    color: #ffffff;
    border-color: var(--color-primary);
    transform: translateY(-1px);
}

/* Badge Angka */
.filter-scroll-container .filter-count {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    height: 22px;
    min-width: 24px;
    padding: 0 5px;
    border-radius: 10px;    
    background-color: rgba(0, 0, 0, 0.08);
    color: var(--text-muted);    
    font-size: 11px;
    font-weight: 700;
    margin-left: 8px;
    line-height: 1 !important;
}

.filter-scroll-container .filter-btn.active .filter-count {
    background-color: #ffffff;
    color: var(--color-primary);
}

/* Tombol Panah (Desktop) */
.filter-scroll-container .scroll-nav-btn {
    flex: 0 0 40px;
    width: 40px;
    height: 40px;
    min-width: 40px;
    min-height: 40px;
    border-radius: 50px;   
    
    background: #ffffff;
    border: 1px solid var(--color-border);
    color: var(--text-muted);    
    
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
    z-index: 2;
    outline: none !important;
}

.filter-scroll-container .scroll-nav-btn:hover {
    background: var(--color-primary);
    color: #ffffff;
    border-color: var(--color-primary);
}

.filter-scroll-container .scroll-nav-btn:active {
    transform: scale(0.95);
    background: #ffffff;
    color: var(--text-muted);
    border-color: var(--color-border);
    outline: none;
}

.filter-scroll-container .scroll-nav-btn span {
    font-size: 20px;
    line-height: 1;
    display: block;
    margin-top: 2px;
}


/* --- 2. MOBILE RESPONSIVE (CUSTOM DROPDOWN UI) --- */
@media (max-width: 768px) {
    .desktop-view-only { display: none !important; }
    .mobile-view-only { display: block !important; }
    .filter-mobile-custom-dropdown {
        position: relative;
        width: 100%;
        margin: 0 auto 50px auto;
        padding:0;
        z-index: 50;
    }

    .mobile-dropdown-trigger,
	.mobile-dropdown-trigger:focus{
        width: 100%;
        display: flex;
        justify-content: space-between;
        align-items: center;     
        background-color: var(--bg-light);
        border: 1px solid var(--color-border);
        border-radius: 12px;
        padding: 14px 20px;        
        font-family: inherit;
        font-size: 15px;
        font-weight: 600;
        color: var(--text-color);        
        cursor: pointer;
        transition: all 0.2s ease;
    }

    .mobile-dropdown-trigger.is-open,
	.mobile-dropdown-trigger.is-open:focus {
        color: var(--text-color); 
        background-color: #ffffff;
        border-color: var(--color-primary);
        box-shadow: 0 4px 12px rgba(37, 99, 235, 0.15);
    }
    
    .mobile-dropdown-trigger .trigger-icon {
        color: var(--color-primary);
        transition: transform 0.3s ease;
    }
    .mobile-dropdown-trigger.is-open .trigger-icon {
        transform: rotate(180deg);
    }

    .mobile-dropdown-menu {
        display: none;
        position: absolute;
        top: 100%;
        left: 0px;
        right: 0px;
        margin-top: 15px;      
        background-color: #ffffff;
        border: 1px solid var(--color-border);
        border-radius: 12px;
        box-shadow: 0 10px 25px rgba(0,0,0,0.1);
        overflow: hidden;
        z-index: 100;
        animation: fadeInDrop 0.2s ease-out;
    }
    
    @keyframes fadeInDrop {
        from { opacity: 0; transform: translateY(-10px); }
        to { opacity: 1; transform: translateY(0); }
    }

    .mobile-dropdown-menu.is-open {
        display: block;
    }

    .mobile-dropdown-menu ul {
        list-style: none;
        margin: 0;
        padding: 0;
    }

    .mobile-dropdown-menu li {
        border-bottom: 1px solid var(--color-border);
    }
    .mobile-dropdown-menu li:last-child {
        border-bottom: none;
    }

    .mobile-dropdown-menu a {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 14px 20px;        
        color: var(--text-muted);
        text-decoration: none;
        font-size: 15px;
        font-weight: 500;
        transition: background 0.2s;
    }

    .mobile-dropdown-menu a:hover {
        background-color: var(--bg-light);
        color: var(--color-primary);
    }
    
    .mobile-dropdown-menu a.current {
        background-color: rgba(37, 99, 235, 0.08);
        color: var(--color-primary);
        font-weight: 700;
    }

    .mobile-dropdown-menu .count {
        font-size: 12px;
        background: rgba(0,0,0,0.05);
        padding: 2px 8px;
        border-radius: 10px;
        color: var(--text-muted);
    }
    .mobile-dropdown-menu a.current .count {
        background: #ffffff;
        color: var(--color-primary);
    }
}

/* 8.4 Portofolio & Sertifikat Archive Content Grid */
.content-archive .articles, 
.archive .articles {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 30px !important;
}

.post-type-archive-sertifikat .entry-content,
.tax-kategori_sertifikat .entry-content,
.tax-topik_sertifikat .entry-content,
.post-type-archive-portofolio .entry-content,
.tax-kategori_portofolio .entry-content,
.tax-tags_portofolio .entry-content,
.archive .entry {
    padding: 0 !important;
    margin: 0 !important;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.portofolio-card-wrapper,
.sertifikat-card-wrapper {
    background: var(--bg-white);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
    height: 100%;
    width: 100%;
    position: relative;
}

.portofolio-card-wrapper:hover,
.sertifikat-card-wrapper:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 24px rgba(0,0,0,0.08);
    border-color: #cbd5e1;
}

.porto-image-container,
.cert-image-container {
    position: relative;
    width: 100%;
	aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--bg-light);
    flex-shrink: 0;
}

.porto-image-container img,
.cert-image-container img {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
}

.portofolio-card-wrapper:hover .porto-image-container img,
.sertifikat-card-wrapper:hover .cert-image-container img {
    transform: scale(1.05);
}

.porto-card-content,
.cert-card-content {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    padding: 0;
}

.porto-title-area,
.cert-title-area {
    padding: 25px 20px;
    flex-grow: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.porto-title-area .entry-title,
.cert-title-area .entry-title {
    font-size: 16px !important;
    font-weight: 700;
    line-height: 1.4;
    margin: 0;
	border:none;
}

.porto-title-area .entry-title a,
.cert-title-area .entry-title a {
    text-decoration: none;
    color: var(--text-dark);
}

.porto-title-area .entry-title a:hover,
.cert-title-area .entry-title a:hover,
.porto-title-area .entry-title a:focus,
.cert-title-area .entry-title a:focus {
    text-decoration: none;
    color: var(--text-dark);
}

@media only screen and (max-width: 1023px) {
    .content-archive .articles, 
    .archive .articles {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 20px !important;
    }
}

@media only screen and (max-width: 767px) {
    .content-archive .articles, 
    .archive .articles {
        grid-template-columns: 1fr !important;
        gap: 25px !important;
    }
    
    .porto-title-area,
    .cert-footer-title { 
        padding: 25px 15px !important; 
        min-height: 80px !important;
    }

    .cert-meta-info {
        gap: 10px !important;
        padding: 15px 15px 0 15px !important;
    }
}

/* 8.5 Portfolio Archive Content Layout */
body.archive .porto-footer-cats {
    margin-top: auto;
    padding: 15px 20px;
    border-top: 1px solid #eee;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
	gap: 6px;
}

body.archive .porto-cat-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 4px 10px;
    border-radius: 4px;
    background: #fef3c7; /* Kuning background */
    color: #92400e;      /* Coklat teks */
    display: inline-block;
}



/* 8.6 Sertifikat Archive Content Grid */
body.archive .cert-footer-cats {
    margin-top: auto;
    padding: 15px 10px;
    border-top: 1px solid #F1F5F9;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0;
}

body.archive a.cert-cat-label {
    background: none !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;   
    font-family: var(--font-body);
    font-size: 10px !important;
    font-weight: 600 !important;
    color: #64748B !important;
    text-transform: capitalize;
    letter-spacing: 0.8px;
    text-decoration: none !important;
    line-height: 1.4;
    cursor: pointer;
    transition: color 0.2s ease;
    display: inline-block;
}

body.archive a.cert-cat-label:hover {
    color: var(--color-primary) !important;
}

body.archive .cert-cat-label + .cert-cat-label::before {
    content: "•";
    margin: 0 8px;
    color: #CBD5E1;
    font-size: 14px;
    position: relative;
    top: 1px;
}

body.archive .cert-footer-cats.is-wrapped {
    flex-direction: column;
    gap: 8px;
}

body.archive .cert-footer-cats.is-wrapped a::before {
    display: none !important; /* hilangkan titik divider */
}

body.archive .cert-footer-cats.is-wrapped a {
    margin: 0 !important; /* reset margin */
}

body.archive .cert-meta-info {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 20px 20px 0px;
}

body.archive .meta-text-validity, 
body.archive .meta-text-date, 
body.archive .meta-text-time {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-family: var(--font-body);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 8px 10px;
    border-radius: 50px;
    line-height: 1;
}

body.archive .status-active,
body.archive .valid-lifetime {
    background-color: #ECFDF5;
    color: #059669;
    border: 1px solid #A7F3D0;
}

body.archive .status-expired {
    background-color: #FEF2F2;
    color: #E11D48;
    border: 1px solid #FECDD3;
}

body.archive .meta-text-date, 
body.archive .meta-text-time {
    background-color: #EFF6FF;
    color: var(--color-primary);
    border: 1px solid #BFDBFE;
}

body.archive .cert-card-content {
    text-align: center;
}

body.archive .cert-title-area {
    justify-content: center;
    text-align: center;
}

body.archive .cert-header-type {
    padding: 15px 20px 10px 20px;
    text-align: left;
}

body.archive .cert-type-label {
    display: inline-block;
    text-transform: uppercase;
    font-size: 10px;
    letter-spacing: 0.5px;
    font-weight: 700;
    color: var(--text-muted);
    background: #f1f5f9;
    padding: 4px 8px;
    border-radius: 4px;
}

body.archive .cert-img-link {
    display: block;
    width: 100%;
}

body.archive .cert-img-link img {
    display: block;
    width: 100%;
    height: 200px;
    object-fit: cover;
    object-position: top center;
    margin-bottom: 0 !important;
}


/* ==========================================================================
   BAGIAN 9: SINGLE & PAGE
   --------------------------------------------------------------------------
   9.1 Single & Page Breadcrumb
   9.2 Single & Page Content
   9.3 Single & Page Footer
   9.4 Single & Page Content Additional: Box Disclaimer Portofolio
   9.5 Single & Page Content Additional: Accordion Styling
   9.6 Single & Page Content Additional: List Style
   9.7 Single & Page Content Additional: Demo Box
   ========================================================================== */

/* 9.1 Single & Page Breadcrumb */
body.single .breadcrumb,
body.page .breadcrumb {
    font-size: 11px;
    font-weight: 400;
	color: var(--text-body);
    margin: 0;
    padding: 15px 20px;
	border-bottom: 1px solid var(--color-border);
}

body.single .breadcrumb a,
body.page .breadcrumb a,
body.single .breadcrumb a:hover,
body.page .breadcrumb a:hover {
	color: var(--text-body);
}

/* 9.2 Single & Page Content */
body.single .content,
body.page:not(.home) .content {
    float: left;
    width: 100%;
    max-width: 740px;
    margin: 50px 0px 0px;
    border: 1px solid var(--color-border);
    border-radius: 10px;
}

body.single .entry,
body.page:not(.home) .entry {
    padding: 50px;
}

body.single .content .entry-title,
body.page:not(.home) .content .entry-title {
	font-family: var(--font-heading);
    font-size: 32px;
    font-weight: 800;
    color: var(--text-dark);
    text-align: left;
    line-height: 1.25; 
    letter-spacing: -0.8px;
    margin-top: 10px;
    margin-bottom: 25px;
}

body.single .entry-content h2,
body.page:not(.home) .entry-content h2 {
    font-size: 28px;
    font-weight: 800;
    color: #111;
    margin-bottom: 1em;
    padding-bottom: 15px;
    border-bottom: 3px solid #eee;
    line-height: 1.2;
}

body.single .entry-content h3,
body.page:not(.home) .entry-content h3 {
    font-size: 18px;
    font-weight: 700;
    color: #333;
    margin-bottom: 0.8em;
}

body.single .entry-content p,
body.page:not(.home) .entry-content p {
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.7;
    color: var(--text-body);
    margin-bottom: 24px;
    font-weight: 400;
}

body.single .entry-content .wp-block-image,
body.page:not(.home) .entry-content .wp-block-image {
    margin-bottom: 25px;
}

body.single .entry-content .wp-block-image img,
body.page:not(.home) .entry-content .wp-block-image img {
	display: block;
    height: auto;
    max-width: 100%;
    border-radius: 12px;
    border: 1px solid var(--color-border);
    margin: 0px auto 30px;
}

@media (max-width: 1200px) {
	body.single .content, body.page:not(.home) .content {
		max-width: 600px;
	}
}

@media (max-width: 1060px) {
	body.single .content, body.page:not(.home) .content {
		float:none;
		max-width: 100%;
	}
}

@media (max-width: 420px) {
	body.single .content .entry-title,
	body.page:not(.home) .content .entry-title {
		font-size: 26px;
	}
}

/* 9.3 Single & Page Footer */
body.page:not(.home) .content .entry-footer,
body.single .content .entry-footer {
    font-size: 14px;
    color: #999;
}

.entry-footer a {
    display: inline-block;
    background-color: #E6F0F8;
    color: #2980b9;
    padding: 5px 15px;
    border-radius: 50px;
    text-decoration: none;
    font-weight: 600;
    margin-left: 8px;
    transition: all 0.3s ease;
}

.entry-footer a:hover {
    background-color: var(--color-primary);
    color: var(--bg-white);
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(41, 128, 185, 0.2);
}

.entry-footer .entry-categories-link::before {
    content: "\f318";
    font-family: "dashicons";
    margin-right: 5px;
    vertical-align: middle;
}

/* 9.4 Single & Page Content Additional: Box Disclaimer Portofolio */
body.single .disclaimer-box,
body.page:not(.home) .disclaimer-box {
    background-color: var(--bg-white);
    border: 2px dashed #e53935;
    border-radius: 15px;
    padding: 20px 25px;
    margin: 25px 0;
    display: block;
    position: relative;
    overflow: hidden;
}

body.single p.disclaimer-box,
body.page:not(.home) p.disclaimer-box {
    color: #c62828 !important;
    font-size: 14px !important;
    line-height: 1.75 !important;
    font-weight: 500 !important;
    text-align: center !important;
}

body.single .disclaimer-box,
body.page:not(.home) .disclaimer-box {
    box-shadow: 0 4px 10px rgba(229, 57, 53, 0.05);
}

/* 9.5 Single & Page Content Additional: Accordion Styling */
body.page:not(.home) .entry-content details.code-accordion,
body.single .entry-content details.code-accordion {
    border: 1px solid #dadce0;
    background-color: var(--bg-white);
    margin-bottom: 24px;
    border-radius: 8px;
    overflow: hidden;
    transition: box-shadow 0.3s ease, border-color 0.3s ease;
}

body.page:not(.home) .entry-content summary.accordion-header,
body.single .entry-content summary.accordion-header {
    background-color: var(--bg-white);
    color: #3c4043;
    padding: 16px 24px;
    padding-right: 50px;
    font-weight: 500;
    font-size: 15px;
    cursor: pointer;
    position: relative;
    list-style: none;
    border-bottom: 1px solid transparent;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

body.page:not(.home) .entry-content details[open] summary.accordion-header,
body.single .entry-content details[open] summary.accordion-header {
    border-bottom: 1px solid #dadce0;
}

body.page:not(.home) .entry-content summary.accordion-header:hover,
body.single .entry-content summary.accordion-header:hover {
    background-color: #f0f7ff;
    color: #1a73e8;
    border-bottom-color: #c2dbfe;
    padding-left: 28px;
}

body.page:not(.home) .entry-content summary.accordion-header::-webkit-details-marker,
body.single .entry-content summary.accordion-header::-webkit-details-marker {
    display: none;
}

body.page:not(.home) .entry-content summary.accordion-header::after,
body.single .entry-content summary.accordion-header::after {
    content: '';
    position: absolute;
    right: 24px;
    top: 50%;
    width: 8px;
    height: 8px;
    border-right: 2px solid #70757a;
    border-bottom: 2px solid #70757a;
    transform: translateY(-60%) rotate(45deg);
    transition: transform 0.3s ease, border-color 0.3s ease, right 0.3s ease;
}

body.page:not(.home) .entry-content summary.accordion-header:hover::after,
body.single .entry-content summary.accordion-header:hover::after {
    border-color: #1a73e8;
    right: 20px;
}

body.page:not(.home) .entry-content details[open] summary.accordion-header::after,
body.single .entry-content details[open] summary.accordion-header::after {
    transform: translateY(-20%) rotate(225deg);
    border-color: #1a73e8;
}

body.page:not(.home) .entry-content .accordion-body,
body.single .entry-content .accordion-body {
    background-color: var(--bg-white);
    color: #3c4043;
    padding: 20px 24px;
    border-right: none;    
    height: auto;
    max-height: 300px;
    overflow-y: auto;
    overflow-x: auto;   
    white-space: pre; 
    font-size: 13px;
    line-height: 1.6;
    font-family: 'Roboto Mono', Consolas, monospace;   
    scrollbar-width: thin;
    scrollbar-color: var(--bg-white);
}

body.page:not(.home) .entry-content .accordion-desc,
body.single .entry-content .accordion-desc {
    white-space: normal;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
    color: #5f6368;
    font-size: 14px;
    margin-top: 0 !important;
    margin-bottom: 20px !important;
    padding-bottom: 15px;
    padding-right: 5px; 
    border-bottom: 1px dashed #dadce0;
}

body.page:not(.home) .entry-content .accordion-body::-webkit-scrollbar,
body.single .entry-content .accordion-body::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

body.page:not(.home) .entry-content .accordion-body::-webkit-scrollbar-track,
body.single .entry-content .accordion-body::-webkit-scrollbar-track {
    background: var(--bg-white); 
}

body.page:not(.home) .entry-content .accordion-body::-webkit-scrollbar-thumb,
body.single .entry-content .accordion-body::-webkit-scrollbar-thumb {
    background: #dadce0; 
    border-radius: 6px;
    border: 3px solid var(--bg-white); 
}

body.page:not(.home) .entry-content .accordion-body::-webkit-scrollbar-thumb:hover,
body.single .entry-content .accordion-body::-webkit-scrollbar-thumb:hover {
    background: #bdc1c6;
}

/* 9.6 Single & Page Content Additional: List Style */
body.page:not(.home) .entry-content ol,
body.single .entry-content ol {
    list-style: none;
    counter-reset: impact-counter;
    padding-left: 0;
    margin-top: 30px;
    margin-bottom: 30px;
}

body.page:not(.home) .entry-content ol li,
body.single .entry-content ol li {
    counter-increment: impact-counter;
    position: relative;
    padding-left: 35px;
    margin-bottom: 18px;
    line-height: 1.7;
}

body.page:not(.home) .entry-content ol li::before,
body.single .entry-content ol li::before {
    content: counter(impact-counter) ".";
    position: absolute;
    left: 0;
    top: 0;
    font-family: var(--font-heading);
    font-weight: 800;
    font-size: 18px;
    color: var(--text-body);
    background: none;
    border: none;
    box-shadow: none;
    width: 25px;
    line-height: 1.7;
}

body.page:not(.home) .entry-content ul,
body.single .entry-content ul {
    list-style: none;
    padding-left: 0;
    margin-top: 30px;
    margin-bottom: 30px;
}

body.page:not(.home) .entry-content ul li,
body.single .entry-content ul li {
    position: relative;
    padding-left: 35px;
    margin-bottom: 18px;
    line-height: 1.7;
}

body.page:not(.home) .entry-content ul li::before,
body.single .entry-content ul li::before {
    content: "\2713";
    position: absolute;
    left: 0;
    top: 0;
    font-weight: 900;
    font-size: 18px;
    color: var(--text-body);
    width: auto;
    height: auto;
    background: none;
    border: none;
    box-shadow: none;
    line-height: 1.7;
}

/* 9.7 Single & Page Content Additional: Demo Box */
.haf-demo-box {
    background-color: #fffbeb;
    border: 2px dashed rgb(245, 158, 11);
    padding: 30px 40px 30px;
    border-radius: 8px;
    margin-bottom: 25px;
    font-size: 14px;
    color: #b45309;
    text-align: center;
}

.haf-demo-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.haf-demo-title {
    margin-top: 0;
    margin-bottom: 20px;
    color: #b45309;
    font-size: 18px;
    font-weight: 700;
}

.haf-btn-demo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: #f59e0b;
    color: #ffffff !important;
    font-weight: 600;
    font-size: 16px;
    text-decoration: none;
    padding: 12px 28px;
    border-radius: 6px;
    transition: all 0.3s ease;
    border: none;
    cursor: pointer;
}

.haf-btn-demo:hover {
    transform: translateY(-2px);
    color: #ffffff !important;
}

.haf-btn-demo:active {
    transform: translateY(0);
    box-shadow: 0 4px 6px -1px rgba(245, 158, 11, 0.3);
}

.haf-btn-icon {
    margin-right: 8px;
    font-size: 20px;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
}


/* ==========================================================================
   BAGIAN 10: SINGLE ONLY
   --------------------------------------------------------------------------
   10.1 Single Blog Header Metadata
   10.2 Single Blog Footer Comments
   10.2 Single Portofolio Footer Metadata
   10.3 Single Sertifikat Header Metadata
   ========================================================================== */

/* 10.1 Single Blog Header Metadata */
body.single .content .entry-meta {
    font-size: 16px;
    font-weight: 500;
    color: #57607680;
    line-height: 1.4em;
    margin-bottom: 20px;
}

body.single .content .entry-meta .entry-categories,
body.single .content .entry-meta .entry-tags {
    display: inline-block;
}

body.single .content .entry-meta .entry-categories a,
body.single .content .entry-meta .entry-tags a,
body.single .content .entry-meta .entry-author a,
body.single .content .entry-meta .entry-time {
    background: var(--bg-white);
    padding: 5px 16px;
    border-radius: 4px;
    color: #57607680;
    border: 1px solid var(--color-border);
    text-decoration: none;
    display: inline-block;
    margin-right: 5px;
    margin-bottom: 5px;
    transition: all 0.2s ease;
}

body.single .content .entry-meta a:hover {
    border-color: #576076;
    color: #1f1f1f;
}

.post-type-archive-sertifikat .entry-meta,
.post-type-archive-sertifikat .entry-time,
.single-sertifikat .entry-meta, 
.single-sertifikat .entry-time,
.single-portofolio .entry-meta, 
.single-portofolio .entry-time,
.post-type-archive-portofolio .entry-meta,
.post-type-archive-portofolio .entry-time {
    display: none !important;
}

@media only screen and (max-width: 768px) {
    .archive .articles {
        grid-template-columns: 1fr;
    }
}


/* 10.1 Single Blog Footer Comments */
.comment-respond,
.entry-comments,
.entry-pings {
    margin-bottom: 40px;
    background-color: var(--bg-white);
    border-radius: 8px;
    padding: 20px;
    border: 1px solid var(--color-border);
    box-shadow: none;
}

.comment-list li {
    padding: 20px 0 20px 30px;
    font-size: 1rem;
}

.comment-list li article {
    border: 1px solid var(--color-border);
    padding: 25px;
    border-radius: 8px;
}

.comment-list .depth-1 {
    padding-left: 0;
}

.comment-header {
    margin: -25px -25px 20px;
    padding: 20px 15px 20px;
    font-weight: bold;
    font-size: 1.1rem;
    color: var(--text-dark);
    border-bottom: 1px solid var(--color-border);
    background: #f8f8f8;
}

.comment-author-name a {
    color: var(--text-body);
}
.comment-time a {
    font-size: 14px;
    color: #616670;
}

.comment-content {
    clear: both;
    color: #555;
}

.comment-content ul > li {
    list-style-type: disc;
    margin-left: 20px;
}

.comment-respond .logged-in-as,
.comment-respond .comment-notes {
    font-size: 16px;
}

.comment-respond input[type="email"],
.comment-respond input[type="text"],
.comment-respond input[type="url"] {
    width: 100%;
    padding: 12px;
    margin: 10px 0;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-size: 1rem;
    transition: border-color 0.3s ease;
}

.comment-respond input[type="email"]:focus,
.comment-respond input[type="text"]:focus,
.comment-respond input[type="url"]:focus {
    border-color: var(--color-primary);
}

.comment-respond label {
    display: block;
    margin-bottom: 8px;
    font-size: 1rem;
    color: var(--text-body);
}

.comment-header p {
    margin-bottom: 0;
    color: #777;
}

.entry-pings .reply {
    display: none;
}

.comment-form-cookies-consent label {
    display: inline-block;
    padding-left: 10px;
    font-size: 0.9rem;
    color: #777;
}

.comment-respond button[type="submit"] {
    background-color: var(--color-primary);
    color: var(--bg-white);
    border: none;
    border-radius: 4px;
    padding: 12px 24px;
    cursor: pointer;
    font-size: 1rem;
    margin-top: 10px;
    width: 100%;
    transition: background-color 0.3s ease;
}

.comment-respond button[type="submit"]:hover {
    background-color: var(--color-primary-dark);
}

.comment-edit-link {
    display: none;
}


/* 10.2 Single Portofolio Footer Metadata */
.portofolio-single-meta.footer-view {
    margin-top: 70px;
    padding-top: 25px;
    border-top: 1px solid #eaeaea;
    display: flex;
    flex-direction: column;
    gap: 15px;
    align-items: flex-start;
    font-family: var(--font-body);
}

.portofolio-meta-row {
    display: flex;
    align-items: center;
    gap: 15px;
    width: 100%;
}

.portofolio-meta-row .meta-label {
    font-size: 11px;
    font-weight: 700;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 1px;
    min-width: 70px;
    flex-shrink: 0;
}

.portofolio-meta-row .meta-items {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.portofolio-meta-row a {
    display: inline-block;
    text-decoration: none !important;
    padding: 6px 14px;
    border-radius: 50px;
    font-size: 13px;
    font-weight: 500;
    transition: all 0.2s ease-in-out;
    line-height: 1.2;
}

.meta-cats a {
    background-color: #f0f7ff; 
    color: var(--color-primary); 
    border: 1px solid transparent;
}
.meta-cats a:hover {
    background-color: var(--color-primary); 
    color: var(--bg-white);
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(0, 115, 229, 0.2);
}

.meta-tags a {
    background-color: #f8f9fa;
    color: #555;
    border: 1px solid #e9ecef;
}
.meta-tags a:hover {
    background-color: var(--text-body);
    color: var(--bg-white);
    border-color: var(--text-body);
    transform: translateY(-2px);
}

@media only screen and (max-width: 600px) {
    .portofolio-meta-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
	
    .portofolio-meta-row .meta-label {
        min-width: auto;
        margin-bottom: 2px;
    }
}

/* 10.3 Single Sertifikat Header Metadata */
body.single .sertifikat-meta-container.single-view {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;
    width: 100%;
    margin-top: 10px;
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--color-border); 
}

body.single .cert-cat-label,
body.single .meta-text-validity,
body.single .meta-text-date,
body.single .meta-text-time {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--font-heading);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 8px 16px;
    border-radius: 50px;
    line-height: 1;
    text-decoration: none !important;
}

body.single .cert-cat-label,
body.single .meta-text-validity,
body.single .meta-text-date,
body.single .meta-text-time,
body.single .cert-cat-label:hover,
body.single .meta-text-validity:hover,
body.single .meta-text-date:hover,
body.single .meta-text-time:hover {
    background-color: var(--bg-light);
    color: var(--text-muted);
    border: 1px solid var(--color-border);
    transition: all 0.2s ease;
}


.post-type-archive-sertifikat .entry-meta,
.post-type-archive-sertifikat .entry-time,
.single-sertifikat .entry-meta, 
.single-sertifikat .entry-time {
    display: none !important;
}


/* ==========================================================================
   BAGIAN 11: PAGE ONLY
   --------------------------------------------------------------------------
   11.1 -
   ========================================================================== */




/* ==========================================================================
   BAGIAN 12: SIDEBAR
   --------------------------------------------------------------------------
   12.1 Sidebar Container Styles
   12.2 Sidebar Widget: User Profile
   12.3 Sidebar Widget: Mari Terhubung
   12.4 Sidebar Widget: Unduh Resume
   ========================================================================== */

/* 12.1 Sidebar Container Styles */
.sidebar {
    float: right;
    margin: 50px 0px 0px;
}

.sidebar .widget {
    background: var(--bg-white);
    width: 320px;
    margin: 0px 0px 40px;
    padding: 10px;
    border-radius: 10px;
    border: 1px solid var(--color-border);
}

.sidebar .widget .widget-title,
.sidebar .widget .wp-block-heading {
    font-size: 16px;
    font-weight: 600;
    text-align: center;
    border-bottom: 1px solid var(--color-border);
    padding: 5px 10px 15px;
    margin: 0px -10px 10px;
}

@media (max-width: 1060px) {
    .sidebar {
        clear: both;
        float: none;
        margin: 50px auto 0px;
        width: 100%;
        max-width: 320px;
        display: block;
    }

    .sidebar .widget {
        width: 100%;
    }
}

/* 12.2 Sidebar Widget: User Profile */
.sidebar-primary #user-profile-2.widget {
    padding: 35px 35px 40px;
    text-align: center !important;
}

.sidebar-primary #user-profile-2 .widget-wrap p {
    display: flex !important;           
    flex-direction: column !important; 
    align-items: center !important;     
    text-align: center !important;     
    font-size: 14px;
    line-height: 1.5;
    margin: 0;
    gap: 20px;
}

.sidebar-primary #user-profile-2 img.avatar {
    width: 100px;
    height: 100px;
    border-radius: 50%; 
    object-fit: cover;
    border: 4px solid #E6F0F8; 
    padding: 2px;
    background: var(--bg-white);
    float: none !important;
    margin: 0 !important; 
    display: block;
}

.sidebar-primary #user-profile-2 a.pagelink {
    display: inline-block;
    padding: 10px 24px;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: 0.5px;
    color: var(--color-primary);
    border: 2px solid var(--color-primary);
    border-radius: 50px;
    transition: all 0.3s ease;
    background: transparent;
}

.sidebar-primary #user-profile-2 a.pagelink:hover {
    background-color: var(--color-primary);
    color: var(--bg-white);
}

/* 12.3 Sidebar Widget: Mari Terhubung */
.sidebar-primary .my-social-icons {
    display: flex;
    justify-content: center;
    gap: 15px;
    margin-top: 20px;
    margin-bottom: 30px;
}

.sidebar-primary .social-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 45px;  
    height: 45px;
    border-radius: 50%; 
    background-color: var(--bg-white);
    border: 2px solid #E6F0F8;
    color: var(--color-primary);
    text-decoration: none;
    transition: all 0.3s ease;
}

.sidebar-primary .social-btn svg {
    width: 20px;     
    height: 20px;    
    fill: currentColor;
    transition: fill 0.3s ease;
}

.sidebar-primary .social-btn:hover {
    background-color: var(--color-primary); 
    border-color: var(--color-primary);
    color: var(--bg-white);
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(41, 128, 185, 0.3);
}

/* 12.4 Sidebar Widget: Unduh Resume */
.sidebar-primary .widget-cta-box {
    background: #E6F0F8;
    padding: 25px;
    border-radius: 12px;
    text-align: center;
    border: 1px solid #dcebf5;
}

.sidebar-primary .widget-cta-box p {
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 20px;
    color: #444;
    font-weight: 500;
}

.sidebar-primary .btn-download-cv {
    display: inline-flex; 
    align-items: center;
    justify-content: center;
    gap: 8px;
    background-color: var(--color-primary); 
    color: var(--bg-white) !important;  
    padding: 12px 20px;
    border-radius: 50px;     
    text-decoration: none;
    font-weight: bold;
    font-size: 14px;
    transition: all 0.3s ease;
    width: 100%;                
    box-sizing: border-box;  
    border: none;
}

.sidebar-primary .btn-download-cv:hover {
    background-color: var(--color-primary-dark); 
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(41, 128, 185, 0.4);
}

.sidebar-primary .btn-download-cv .dashicons {
    font-size: 18px;
    width: 18px;
    height: 18px;
    color: var(--bg-white);
}




/* ==========================================================================
   BAGIAN 13: FOOTER
   --------------------------------------------------------------------------
   13.1 Footer Container Styles
   13.2 Footer Widget: Navigation Menu
   ========================================================================== */

/* 13.1 Footer Container Styles */
.site-footer {
    border-top: 1px solid var(--color-border);
    font-size: 15px;
    line-height: 1.5;
    padding: 30px;
    text-align: center;
}

.site-footer p {
    margin-bottom: 0;
}

/* 13.2 Footer Widget: Navigation Menu */
.footer-widgets {
    border-top: 1px solid var(--color-border);
    background-color: var(--bg-white);
    clear: both;
    padding: 60px 0;
}

.footer-widgets .wrap {
    margin-left: auto;
    margin-right: auto;
}

.footer-widget-area {
    margin-bottom: 40px;
    padding-left: 30px;
    padding-right: 30px;
}

.footer-widget-area:last-child,
.footer-widgets .widget:last-child {
    margin-bottom: 0;
}

.nav-secondary {
    margin-top: 10px;
}

.nav-secondary .genesis-nav-menu {
    line-height: 1.5;
}

.nav-secondary .menu-item {
    display: inline-block;
}

.nav-secondary a {
    margin-left: 10px;
    margin-right: 10px;
    padding: 0;
}
