/* =========================================================
   IIS THEME — MAIN STYLESHEET
   Investigative Intelligence Solutions Inc.
   "Guyana's Only High-Tech Private Investigation Firm"
   ========================================================= */

/* ---------------------------------------------------------
   TABLE OF CONTENTS
   1.  CSS Custom Properties
   2.  Typography
   3.  Utility Classes
   4.  Layout & Grid
   5.  Buttons
   6.  Header & Navigation
   7.  Mobile Navigation
   8.  Hero Section
   9.  Services Grid
   10. Why IIS / Stats Section
   11. CTA Banner
   12. Testimonials
   13. Team Section
   14. About Page
   15. Services Page
   16. Contact Page
   17. Single Post
   18. 404 Page
   19. Blog / Archive
   20. Sidebar
   21. Footer
   22. WooCommerce Hide Cart
   23. Animations & Keyframes
   24. Responsive — Tablet (≤768px)
   25. Responsive — Mobile (≤480px)
   --------------------------------------------------------- */

/* =========================================================
   1. CSS CUSTOM PROPERTIES
   ========================================================= */

:root {
	/* Brand Colors */
	--gold:        #c9a84c;
	--gold-dark:   #a8872e;
	--gold-light:  #e2c06d;
	--gold-glow:   rgba(201, 168, 76, 0.35);
	--gold-subtle: rgba(201, 168, 76, 0.08);

	--black:       #0a0a0a;
	--dark:        #1a1a1a;
	--mid:         #2a2a2a;
	--mid-light:   #333333;
	--off-white:   #f5f5f5;
	--white:       #ffffff;
	--gray:        #888888;
	--gray-light:  #bbbbbb;
	--border:      rgba(201, 168, 76, 0.2);
	--border-mid:  rgba(255,255,255,0.08);

	/* Typography */
	--font-body:    'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
	--font-heading: 'Rajdhani', sans-serif;

	/* Spacing */
	--section-pad: 90px;
	--container:   1200px;

	/* Transitions */
	--trans:       0.3s ease;
	--trans-slow:  0.6s ease;

	/* Shadows */
	--shadow:      0 4px 20px rgba(0,0,0,0.5);
	--shadow-gold: 0 0 30px rgba(201, 168, 76, 0.3);
}

/* =========================================================
   2. TYPOGRAPHY
   ========================================================= */

body {
	font-family:             var(--font-body);
	font-size:               16px;
	line-height:             1.7;
	color:                   var(--off-white);
	background-color:        var(--black);
	-webkit-font-smoothing:  antialiased;
}

h1, h2, h3, h4, h5, h6 {
	font-family:    var(--font-heading);
	font-weight:    700;
	line-height:    1.2;
	color:          var(--off-white);
	letter-spacing: 0.5px;
}

h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.5rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.8rem); }
h4 { font-size: 1.25rem; }
h5 { font-size: 1.1rem; }
h6 { font-size: 1rem; }

p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }

a {
	color:           var(--gold);
	text-decoration: none;
	transition:      color var(--trans);
}
a:hover { color: var(--gold-light); }

strong, b { font-weight: 600; }

ul, ol {
	padding-left: 1.5rem;
	margin-bottom: 1rem;
}

img {
	max-width: 100%;
	height:    auto;
	display:   block;
}

code, pre {
	font-family:      'Courier New', monospace;
	background-color: var(--mid);
	border:           1px solid var(--border);
	border-radius:    4px;
}

code    { padding: 2px 6px; font-size: 0.875rem; }
pre     { padding: 1.5rem; overflow-x: auto; }
pre code { background: none; border: none; padding: 0; }

hr {
	border:     none;
	border-top: 1px solid var(--border);
	margin:     2rem 0;
}

blockquote {
	border-left:  3px solid var(--gold);
	padding:      1rem 1.5rem;
	margin:       1.5rem 0;
	color:        var(--gray-light);
	font-style:   italic;
	background:   var(--gold-subtle);
}

/* =========================================================
   3. UTILITY CLASSES
   ========================================================= */

.container {
	max-width:    var(--container);
	margin-left:  auto;
	margin-right: auto;
	padding-left: 24px;
	padding-right:24px;
}

.container--narrow { max-width: 860px; }
.container--wide   { max-width: 1400px; }

.section {
	padding-top:    var(--section-pad);
	padding-bottom: var(--section-pad);
}

.section--dark  { background-color: var(--black); }
.section--dark2 { background-color: var(--dark); }
.section--mid   { background-color: var(--mid); }

/* Section headings */
.section-header {
	text-align:    center;
	margin-bottom: 60px;
}

.section-header .eyebrow {
	display:        block;
	font-family:    var(--font-heading);
	font-size:      0.75rem;
	font-weight:    600;
	letter-spacing: 3px;
	text-transform: uppercase;
	color:          var(--gold);
	margin-bottom:  12px;
}

.section-header h2 { margin-bottom: 16px; }

.section-header p {
	color:     var(--gray-light);
	max-width: 580px;
	margin:    0 auto;
	font-size: 1.05rem;
}

/* Gold accent line */
.gold-line {
	display:          block;
	width:            50px;
	height:           2px;
	background:       var(--gold);
	margin:           16px auto;
}

/* Text colors */
.text-gold   { color: var(--gold) !important; }
.text-white  { color: var(--white) !important; }
.text-gray   { color: var(--gray) !important; }
.text-center { text-align: center; }
.text-left   { text-align: left; }

/* Background helpers */
.bg-black  { background-color: var(--black); }
.bg-dark   { background-color: var(--dark); }
.bg-gold   { background-color: var(--gold); }

/* Visibility */
.sr-only {
	position: absolute;
	width:    1px;
	height:   1px;
	overflow: hidden;
	clip:     rect(0, 0, 0, 0);
}

/* Scroll animations */
.fade-up {
	opacity:    0;
	transform:  translateY(30px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}
.fade-up.visible {
	opacity:   1;
	transform: translateY(0);
}

.fade-in {
	opacity:    0;
	transition: opacity 0.6s ease;
}
.fade-in.visible { opacity: 1; }

/* =========================================================
   4. LAYOUT & GRID
   ========================================================= */

.grid {
	display:               grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap:                   30px;
}

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

.flex         { display: flex; }
.flex-center  { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-wrap    { flex-wrap: wrap; }
.gap-sm       { gap: 12px; }
.gap-md       { gap: 24px; }
.gap-lg       { gap: 40px; }

/* =========================================================
   5. BUTTONS
   ========================================================= */

.btn {
	display:         inline-flex;
	align-items:     center;
	gap:             8px;
	padding:         13px 28px;
	font-family:     var(--font-heading);
	font-size:       1rem;
	font-weight:     600;
	letter-spacing:  1px;
	text-transform:  uppercase;
	border:          2px solid transparent;
	border-radius:   3px;
	cursor:          pointer;
	transition:      all var(--trans);
	text-decoration: none;
	white-space:     nowrap;
}

.btn--gold {
	background-color: var(--gold);
	border-color:     var(--gold);
	color:            var(--black);
}
.btn--gold:hover {
	background-color: var(--gold-light);
	border-color:     var(--gold-light);
	color:            var(--black);
	box-shadow:       var(--shadow-gold);
	transform:        translateY(-2px);
}

.btn--outline {
	background-color: transparent;
	border-color:     var(--gold);
	color:            var(--gold);
}
.btn--outline:hover {
	background-color: var(--gold);
	color:            var(--black);
	box-shadow:       var(--shadow-gold);
	transform:        translateY(-2px);
}

.btn--white {
	background-color: transparent;
	border-color:     var(--white);
	color:            var(--white);
}
.btn--white:hover {
	background-color: var(--white);
	color:            var(--black);
}

.btn--sm { padding: 9px 20px; font-size: 0.85rem; }
.btn--lg { padding: 17px 38px; font-size: 1.1rem; }

/* =========================================================
   6. HEADER & NAVIGATION
   ========================================================= */

#site-header {
	position:         fixed;
	top:              0;
	left:             0;
	right:            0;
	z-index:          1000;
	transition:       background-color var(--trans), box-shadow var(--trans), padding var(--trans);
	padding:          20px 0;
	background-color: transparent;
}

#site-header.scrolled {
	background-color: rgba(10, 10, 10, 0.97);
	box-shadow:       0 2px 30px rgba(0,0,0,0.6);
	padding:          12px 0;
	backdrop-filter:  blur(8px);
}

.header-inner {
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	gap:             24px;
}

/* Logo */
.site-logo {
	flex-shrink: 0;
}

.site-logo a {
	display:     flex;
	align-items: center;
	gap:         12px;
	text-decoration: none;
}

.site-logo img {
	height:    50px;
	width:     auto;
	max-width: 180px;
}

.logo-text {
	display:     flex;
	flex-direction: column;
}

.logo-name {
	font-family:    var(--font-heading);
	font-size:      1.4rem;
	font-weight:    700;
	letter-spacing: 2px;
	color:          var(--white);
	line-height:    1;
}

.logo-name span { color: var(--gold); }

.logo-tagline {
	font-size:      0.6rem;
	letter-spacing: 2px;
	text-transform: uppercase;
	color:          var(--gray);
	margin-top:     3px;
}

/* Primary Nav */
.primary-nav {
	display:     flex;
	align-items: center;
	gap:         8px;
}

.primary-nav ul {
	display:    flex;
	align-items:center;
	gap:        4px;
	list-style: none;
	margin:     0;
	padding:    0;
}

.primary-nav ul li a {
	display:        block;
	padding:        8px 14px;
	font-family:    var(--font-heading);
	font-size:      0.95rem;
	font-weight:    500;
	letter-spacing: 1px;
	text-transform: uppercase;
	color:          var(--gray-light);
	transition:     color var(--trans);
	position:       relative;
}

.primary-nav ul li a::after {
	content:          '';
	position:         absolute;
	bottom:           4px;
	left:             14px;
	right:            14px;
	height:           1px;
	background:       var(--gold);
	transform:        scaleX(0);
	transform-origin: left;
	transition:       transform var(--trans);
}

.primary-nav ul li a:hover,
.primary-nav ul li.current-menu-item a,
.primary-nav ul li.current-page-ancestor a {
	color: var(--gold);
}

.primary-nav ul li a:hover::after,
.primary-nav ul li.current-menu-item a::after {
	transform: scaleX(1);
}

/* Header phone number */
.header-phone {
	font-family:    var(--font-heading);
	font-size:      0.85rem;
	font-weight:    600;
	color:          var(--gold);
	letter-spacing: 1px;
	white-space:    nowrap;
}

.header-phone a { color: inherit; }
.header-phone a:hover { color: var(--gold-light); }

/* Header CTA button */
.header-cta {
	margin-left: 8px;
}

/* =========================================================
   7. MOBILE NAVIGATION
   ========================================================= */

.hamburger {
	display:         none;
	flex-direction:  column;
	justify-content: space-between;
	width:           26px;
	height:          18px;
	background:      none;
	border:          none;
	cursor:          pointer;
	padding:         0;
	flex-shrink:     0;
}

.hamburger span {
	display:          block;
	width:            100%;
	height:           2px;
	background-color: var(--gold);
	transition:       all var(--trans);
	border-radius:    1px;
}

.hamburger.active span:nth-child(1) {
	transform: rotate(45deg) translate(5px, 5px);
}
.hamburger.active span:nth-child(2) {
	opacity:   0;
	transform: scaleX(0);
}
.hamburger.active span:nth-child(3) {
	transform: rotate(-45deg) translate(5px, -5px);
}

/* Mobile nav drawer */
.mobile-nav {
	position:         fixed;
	top:              0;
	right:            0;
	width:            min(320px, 90vw);
	height:           100vh;
	background-color: var(--dark);
	border-left:      1px solid var(--border);
	z-index:          999;
	transform:        translateX(100%);
	transition:       transform var(--trans-slow);
	overflow-y:       auto;
	padding:          100px 30px 40px;
}

.mobile-nav.open {
	transform: translateX(0);
}

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

.mobile-nav ul li {
	border-bottom: 1px solid var(--border-mid);
}

.mobile-nav ul li a {
	display:        block;
	padding:        16px 0;
	font-family:    var(--font-heading);
	font-size:      1.1rem;
	font-weight:    600;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color:          var(--gray-light);
	transition:     color var(--trans);
}

.mobile-nav ul li a:hover { color: var(--gold); }

.mobile-nav .mobile-cta {
	margin-top: 30px;
}

.mobile-nav .mobile-cta .btn {
	width:           100%;
	justify-content: center;
}

/* Overlay */
.nav-overlay {
	display:          none;
	position:         fixed;
	inset:            0;
	background:       rgba(0,0,0,0.7);
	z-index:          998;
	backdrop-filter:  blur(2px);
}

.nav-overlay.active { display: block; }

/* =========================================================
   8. HERO SECTION
   ========================================================= */

.hero {
	position:        relative;
	min-height:      100vh;
	display:         flex;
	align-items:     center;
	overflow:        hidden;
	background-color:var(--black);
}

/* Dark gradient background (default) */
.hero--dark-gradient {
	background: radial-gradient(ellipse at 70% 50%, rgba(201,168,76,0.06) 0%, transparent 60%),
	            linear-gradient(135deg, #0a0a0a 0%, #121212 50%, #0d0d0d 100%);
}

/* Circuit grid background */
.hero--circuit-grid {
	background-color: var(--black);
	background-image:
		linear-gradient(rgba(201,168,76,0.04) 1px, transparent 1px),
		linear-gradient(90deg, rgba(201,168,76,0.04) 1px, transparent 1px);
	background-size: 60px 60px;
}

.hero--circuit-grid::before {
	content:    '';
	position:   absolute;
	inset:      0;
	background: radial-gradient(ellipse at center, rgba(201,168,76,0.08) 0%, rgba(10,10,10,0.9) 70%);
}

/* Solid dark */
.hero--solid-dark {
	background-color: #111111;
}

/* Animated grid overlay */
.hero__grid-overlay {
	position:         absolute;
	inset:            0;
	background-image:
		linear-gradient(rgba(201,168,76,0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(201,168,76,0.035) 1px, transparent 1px);
	background-size:  80px 80px;
	animation:        gridShift 20s linear infinite;
}

@keyframes gridShift {
	0%   { background-position: 0 0; }
	100% { background-position: 80px 80px; }
}

/* Glowing orb */
.hero__orb {
	position:         absolute;
	top:              50%;
	right:            10%;
	transform:        translateY(-50%);
	width:            600px;
	height:           600px;
	border-radius:    50%;
	background:       radial-gradient(circle, rgba(201,168,76,0.08) 0%, transparent 70%);
	animation:        orbPulse 6s ease-in-out infinite;
	pointer-events:   none;
}

@keyframes orbPulse {
	0%, 100% { transform: translateY(-50%) scale(1);    opacity: 0.5; }
	50%       { transform: translateY(-50%) scale(1.15); opacity: 1;   }
}

/* Scan line effect */
.hero::after {
	content:           '';
	position:          absolute;
	top:               0;
	left:              0;
	right:             0;
	height:            2px;
	background:        linear-gradient(90deg, transparent, var(--gold), transparent);
	animation:         scanLine 4s ease-in-out infinite;
	opacity:           0.4;
	pointer-events:    none;
}

@keyframes scanLine {
	0%   { top: 0;    opacity: 0; }
	10%  { opacity: 0.4; }
	90%  { opacity: 0.4; }
	100% { top: 100%; opacity: 0; }
}

.hero__content {
	position:   relative;
	z-index:    2;
	padding:    120px 0 80px;
}

.hero__badge {
	display:          inline-flex;
	align-items:      center;
	gap:              8px;
	background:       var(--gold-subtle);
	border:           1px solid var(--border);
	border-radius:    2px;
	padding:          6px 16px;
	font-family:      var(--font-heading);
	font-size:        0.7rem;
	font-weight:      600;
	letter-spacing:   3px;
	text-transform:   uppercase;
	color:            var(--gold);
	margin-bottom:    24px;
}

.hero__badge::before {
	content:          '';
	display:          block;
	width:            6px;
	height:           6px;
	border-radius:    50%;
	background:       var(--gold);
	animation:        blink 1.5s ease-in-out infinite;
}

@keyframes blink {
	0%, 100% { opacity: 1; }
	50%       { opacity: 0; }
}

.hero__headline {
	font-size:      clamp(2.2rem, 5.5vw, 4rem);
	font-weight:    700;
	line-height:    1.1;
	color:          var(--white);
	margin-bottom:  20px;
	max-width:      750px;
}

.hero__headline .highlight { color: var(--gold); }

.hero__subheadline {
	font-family:    var(--font-heading);
	font-size:      clamp(1rem, 2.5vw, 1.5rem);
	font-weight:    400;
	letter-spacing: 3px;
	text-transform: uppercase;
	color:          var(--gray-light);
	margin-bottom:  40px;
}

.hero__cta-group {
	display:     flex;
	flex-wrap:   wrap;
	gap:         16px;
	margin-bottom: 48px;
}

.hero__contact {
	display:     flex;
	align-items: center;
	gap:         12px;
	padding:     16px 20px;
	background:  rgba(255,255,255,0.04);
	border:      1px solid var(--border);
	border-radius:3px;
}

.hero__contact-icon {
	width:           40px;
	height:          40px;
	border-radius:   50%;
	background:      var(--gold-subtle);
	border:          1px solid var(--border);
	display:         flex;
	align-items:     center;
	justify-content: center;
	color:           var(--gold);
	font-size:       1rem;
	flex-shrink:     0;
}

.hero__contact-label {
	font-size:   0.7rem;
	color:       var(--gray);
	letter-spacing:2px;
	text-transform:uppercase;
}

.hero__contact-number {
	font-family:    var(--font-heading);
	font-size:      1.2rem;
	font-weight:    700;
	color:          var(--white);
	letter-spacing: 1px;
}

.hero__contact-number a {
	color:       inherit;
	transition:  color var(--trans);
}
.hero__contact-number a:hover { color: var(--gold); }

/* Scroll indicator */
.hero__scroll {
	position:    absolute;
	bottom:      40px;
	left:        50%;
	transform:   translateX(-50%);
	display:     flex;
	flex-direction:column;
	align-items: center;
	gap:         8px;
	color:       var(--gray);
	font-size:   0.7rem;
	letter-spacing:2px;
	text-transform:uppercase;
	animation:   bounce 2s ease-in-out infinite;
}

.hero__scroll i { color: var(--gold); }

@keyframes bounce {
	0%, 100% { transform: translateX(-50%) translateY(0); }
	50%       { transform: translateX(-50%) translateY(8px); }
}

/* =========================================================
   9. SERVICES GRID
   ========================================================= */

.services-preview { background-color: var(--dark); }

.service-card {
	background:    var(--mid);
	border:        1px solid var(--border);
	border-radius: 4px;
	padding:       36px 28px;
	text-align:    center;
	transition:    all var(--trans);
	position:      relative;
	overflow:      hidden;
}

.service-card::before {
	content:     '';
	position:    absolute;
	top:         0;
	left:        0;
	right:       0;
	height:      2px;
	background:  var(--gold);
	transform:   scaleX(0);
	transition:  transform var(--trans);
}

.service-card:hover {
	border-color: var(--gold);
	box-shadow:   var(--shadow-gold);
	transform:    translateY(-5px);
}

.service-card:hover::before {
	transform: scaleX(1);
}

.service-card__icon {
	width:           70px;
	height:          70px;
	border-radius:   50%;
	border:          2px solid var(--border);
	background:      var(--gold-subtle);
	display:         flex;
	align-items:     center;
	justify-content: center;
	margin:          0 auto 20px;
	font-size:       1.8rem;
	color:           var(--gold);
	transition:      all var(--trans);
}

.service-card:hover .service-card__icon {
	background:   var(--gold-subtle);
	border-color: var(--gold);
	box-shadow:   0 0 20px var(--gold-glow);
}

.service-card__title {
	font-family:    var(--font-heading);
	font-size:      1.15rem;
	font-weight:    700;
	letter-spacing: 1px;
	color:          var(--off-white);
	margin-bottom:  10px;
}

.service-card__desc {
	font-size:   0.9rem;
	color:       var(--gray);
	line-height: 1.6;
	margin:      0;
}

.services-footer {
	text-align:  center;
	margin-top:  50px;
}

/* =========================================================
   10. WHY IIS / STATS SECTION
   ========================================================= */

.stats-section {
	background-color: var(--black);
	position:         relative;
	overflow:         hidden;
}

.stats-section::before {
	content:           '';
	position:          absolute;
	top:               0;
	left:              0;
	right:             0;
	height:            1px;
	background:        linear-gradient(90deg, transparent, var(--gold), transparent);
}

.stats-section::after {
	content:           '';
	position:          absolute;
	bottom:            0;
	left:              0;
	right:             0;
	height:            1px;
	background:        linear-gradient(90deg, transparent, var(--gold), transparent);
}

.stats-grid {
	display:               grid;
	grid-template-columns: repeat(4, 1fr);
	gap:                   0;
}

.stat-block {
	padding:      50px 30px;
	text-align:   center;
	border-right: 1px solid var(--border);
	position:     relative;
	transition:   background-color var(--trans);
}

.stat-block:last-child { border-right: none; }

.stat-block:hover {
	background-color: var(--gold-subtle);
}

.stat-block__number {
	font-family:    var(--font-heading);
	font-size:      clamp(2rem, 4vw, 3rem);
	font-weight:    700;
	color:          var(--gold);
	line-height:    1;
	margin-bottom:  10px;
	display:        block;
}

.stat-block__label {
	font-family:    var(--font-heading);
	font-size:      0.85rem;
	font-weight:    600;
	letter-spacing: 2px;
	text-transform: uppercase;
	color:          var(--gray-light);
}

.stat-block__sub {
	font-size:   0.8rem;
	color:       var(--gray);
	margin-top:  6px;
}

/* =========================================================
   11. CTA BANNER
   ========================================================= */

.cta-banner {
	background:      var(--gold);
	padding:         70px 0;
	position:        relative;
	overflow:        hidden;
}

.cta-banner::before {
	content:     '';
	position:    absolute;
	inset:       0;
	background-image:
		linear-gradient(rgba(0,0,0,0.06) 1px, transparent 1px),
		linear-gradient(90deg, rgba(0,0,0,0.06) 1px, transparent 1px);
	background-size: 40px 40px;
}

.cta-banner .container {
	position:    relative;
	z-index:     1;
	text-align:  center;
}

.cta-banner h2 {
	font-size:     clamp(1.8rem, 4vw, 2.8rem);
	color:         var(--black);
	margin-bottom: 12px;
}

.cta-banner p {
	color:         rgba(10,10,10,0.75);
	font-size:     1.05rem;
	margin-bottom: 36px;
	max-width:     500px;
	margin-left:   auto;
	margin-right:  auto;
}

.cta-banner .btn--gold {
	background-color: var(--black);
	border-color:     var(--black);
	color:            var(--gold);
}
.cta-banner .btn--gold:hover {
	background-color: var(--dark);
	border-color:     var(--dark);
}

.cta-banner .btn--outline {
	border-color: var(--black);
	color:        var(--black);
}
.cta-banner .btn--outline:hover {
	background-color: var(--black);
	color:            var(--gold);
}

.cta-banner__buttons {
	display:          flex;
	justify-content:  center;
	flex-wrap:        wrap;
	gap:              16px;
}

/* =========================================================
   12. TESTIMONIALS
   ========================================================= */

.testimonials-section { background-color: var(--dark); }

.testimonial-slider {
	display:               grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap:                   28px;
}

.testimonial-card {
	background:    var(--mid);
	border:        1px solid var(--border);
	border-radius: 4px;
	padding:       36px;
	position:      relative;
}

.testimonial-card::before {
	content:     '"';
	position:    absolute;
	top:         16px;
	right:       24px;
	font-family: Georgia, serif;
	font-size:   5rem;
	color:       var(--gold);
	opacity:     0.2;
	line-height: 1;
}

.testimonial-card__stars {
	color:         var(--gold);
	font-size:     1rem;
	margin-bottom: 16px;
	letter-spacing:3px;
}

.testimonial-card__text {
	font-size:     0.95rem;
	color:         var(--gray-light);
	line-height:   1.8;
	margin-bottom: 24px;
	font-style:    italic;
}

.testimonial-card__client {
	display:     flex;
	align-items: center;
	gap:         14px;
}

.testimonial-card__avatar {
	width:           46px;
	height:          46px;
	border-radius:   50%;
	background:      var(--gold-subtle);
	border:          2px solid var(--border);
	display:         flex;
	align-items:     center;
	justify-content: center;
	font-family:     var(--font-heading);
	font-weight:     700;
	color:           var(--gold);
	font-size:       1rem;
	flex-shrink:     0;
}

.testimonial-card__name {
	font-family:    var(--font-heading);
	font-weight:    700;
	color:          var(--off-white);
	font-size:      1rem;
}

.testimonial-card__company {
	font-size: 0.8rem;
	color:     var(--gray);
}

/* =========================================================
   13. TEAM SECTION
   ========================================================= */

.team-section { background-color: var(--black); }

.team-grid {
	display:               grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap:                   28px;
}

.team-card {
	background:    var(--dark);
	border:        1px solid var(--border);
	border-radius: 4px;
	overflow:      hidden;
	transition:    all var(--trans);
}

.team-card:hover {
	border-color: var(--gold);
	box-shadow:   var(--shadow-gold);
	transform:    translateY(-4px);
}

.team-card__photo {
	width:           100%;
	padding-top:     100%;
	position:        relative;
	background-color:var(--mid);
	overflow:        hidden;
}

.team-card__photo img {
	position:   absolute;
	inset:      0;
	width:      100%;
	height:     100%;
	object-fit: cover;
}

.team-card__photo-placeholder {
	position:        absolute;
	inset:           0;
	display:         flex;
	align-items:     center;
	justify-content: center;
	font-size:       3rem;
	color:           var(--gold);
	opacity:         0.4;
}

.team-card__body {
	padding: 24px;
}

.team-card__name {
	font-family:    var(--font-heading);
	font-size:      1.1rem;
	font-weight:    700;
	color:          var(--off-white);
	margin-bottom:  4px;
}

.team-card__title {
	font-size:     0.8rem;
	color:         var(--gold);
	letter-spacing:2px;
	text-transform:uppercase;
	margin-bottom: 12px;
}

.team-card__bio {
	font-size:   0.875rem;
	color:       var(--gray);
	line-height: 1.6;
}

/* =========================================================
   14. ABOUT PAGE
   ========================================================= */

.about-hero {
	padding:         160px 0 80px;
	background:      linear-gradient(180deg, rgba(201,168,76,0.05) 0%, transparent 100%),
	                 var(--black);
	position:        relative;
	overflow:        hidden;
}

.about-hero::before {
	content:     '';
	position:    absolute;
	inset:       0;
	background-image:
		linear-gradient(rgba(201,168,76,0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(201,168,76,0.03) 1px, transparent 1px);
	background-size: 60px 60px;
}

.about-intro {
	display:     grid;
	grid-template-columns: 1fr 1fr;
	gap:         60px;
	align-items: center;
}

.about-intro__image {
	border:        2px solid var(--border);
	border-radius: 4px;
	overflow:      hidden;
	position:      relative;
}

.about-intro__image::before {
	content:     '';
	position:    absolute;
	top:         -1px;
	left:        -1px;
	right:       -1px;
	height:      3px;
	background:  var(--gold);
}

.about-values {
	display:               grid;
	grid-template-columns: repeat(3, 1fr);
	gap:                   24px;
	margin-top:            60px;
}

.value-card {
	text-align:    center;
	padding:       36px 24px;
	background:    var(--dark);
	border:        1px solid var(--border);
	border-radius: 4px;
}

.value-card__icon {
	font-size:     2.5rem;
	color:         var(--gold);
	margin-bottom: 16px;
}

.value-card__title {
	font-family:    var(--font-heading);
	font-size:      1.1rem;
	font-weight:    700;
	color:          var(--off-white);
	margin-bottom:  10px;
}

.value-card__text {
	font-size:  0.9rem;
	color:      var(--gray);
	line-height:1.7;
}

/* =========================================================
   15. SERVICES PAGE
   ========================================================= */

.services-page-hero {
	padding:     160px 0 70px;
	background:  var(--dark);
	text-align:  center;
	position:    relative;
	overflow:    hidden;
}

.services-page-hero::before {
	content:     '';
	position:    absolute;
	inset:       0;
	background-image:
		linear-gradient(rgba(201,168,76,0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(201,168,76,0.03) 1px, transparent 1px);
	background-size: 60px 60px;
}

/* Filter bar */
.services-filter {
	display:         flex;
	flex-wrap:       wrap;
	gap:             10px;
	justify-content: center;
	margin-bottom:   50px;
}

.filter-btn {
	padding:        9px 22px;
	font-family:    var(--font-heading);
	font-size:      0.8rem;
	font-weight:    600;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	background:     var(--mid);
	border:         1px solid var(--border);
	color:          var(--gray-light);
	border-radius:  3px;
	cursor:         pointer;
	transition:     all var(--trans);
}

.filter-btn:hover,
.filter-btn.active {
	background:   var(--gold);
	border-color: var(--gold);
	color:        var(--black);
}

/* Full service card */
.service-full-card {
	background:    var(--dark);
	border:        1px solid var(--border);
	border-radius: 4px;
	padding:       32px;
	transition:    all var(--trans);
	display:       flex;
	flex-direction:column;
}

.service-full-card:hover {
	border-color: var(--gold);
	box-shadow:   var(--shadow-gold);
	transform:    translateY(-4px);
}

.service-full-card__header {
	display:      flex;
	align-items:  center;
	gap:          16px;
	margin-bottom:20px;
}

.service-full-card__icon {
	width:           60px;
	height:          60px;
	border-radius:   50%;
	background:      var(--gold-subtle);
	border:          2px solid var(--border);
	display:         flex;
	align-items:     center;
	justify-content: center;
	font-size:       1.5rem;
	color:           var(--gold);
	flex-shrink:     0;
}

.service-full-card__title {
	font-family:  var(--font-heading);
	font-size:    1.1rem;
	font-weight:  700;
	color:        var(--off-white);
	margin-bottom:4px;
}

.service-full-card__category {
	font-size:    0.75rem;
	color:        var(--gold);
	letter-spacing:2px;
	text-transform:uppercase;
}

.service-full-card__desc {
	font-size:   0.9rem;
	color:       var(--gray);
	flex:        1;
	line-height: 1.7;
	margin-bottom:20px;
}

.service-full-card__footer {
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	border-top:      1px solid var(--border);
	padding-top:     16px;
}

.service-full-card__price {
	font-family:    var(--font-heading);
	font-size:      0.9rem;
	font-weight:    600;
	color:          var(--gray-light);
}

/* =========================================================
   16. CONTACT PAGE
   ========================================================= */

.contact-hero {
	padding:    160px 0 70px;
	text-align: center;
	background: var(--dark);
	position:   relative;
	overflow:   hidden;
}

.contact-hero::before {
	content:     '';
	position:    absolute;
	inset:       0;
	background-image:
		linear-gradient(rgba(201,168,76,0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(201,168,76,0.03) 1px, transparent 1px);
	background-size: 60px 60px;
}

.contact-layout {
	display:               grid;
	grid-template-columns: 1fr 1.5fr;
	gap:                   60px;
	align-items:           start;
}

.contact-info-block {
	background:    var(--dark);
	border:        1px solid var(--border);
	border-radius: 4px;
	padding:       40px;
}

.contact-info-block h3 {
	color:         var(--gold);
	margin-bottom: 30px;
	font-size:     1.3rem;
}

.contact-detail {
	display:       flex;
	align-items:   flex-start;
	gap:           16px;
	margin-bottom: 28px;
}

.contact-detail:last-child { margin-bottom: 0; }

.contact-detail__icon {
	width:           44px;
	height:          44px;
	border-radius:   50%;
	background:      var(--gold-subtle);
	border:          1px solid var(--border);
	display:         flex;
	align-items:     center;
	justify-content: center;
	color:           var(--gold);
	font-size:       1rem;
	flex-shrink:     0;
}

.contact-detail__label {
	font-size:    0.7rem;
	letter-spacing:2px;
	text-transform:uppercase;
	color:        var(--gray);
	margin-bottom:4px;
}

.contact-detail__value {
	font-family: var(--font-heading);
	font-size:   1rem;
	font-weight: 600;
	color:       var(--off-white);
}

.contact-detail__value a { color: inherit; }
.contact-detail__value a:hover { color: var(--gold); }

/* Contact form */
.contact-form {
	background:    var(--dark);
	border:        1px solid var(--border);
	border-radius: 4px;
	padding:       40px;
}

.contact-form h3 {
	margin-bottom: 28px;
	font-size:     1.3rem;
}

.form-row {
	display: grid;
	gap:     20px;
	margin-bottom: 20px;
}

.form-row--2 {
	grid-template-columns: 1fr 1fr;
}

.form-group {
	display:       flex;
	flex-direction:column;
	gap:           8px;
	margin-bottom: 20px;
}

.form-group:last-of-type { margin-bottom: 0; }

.form-group label {
	font-family:    var(--font-heading);
	font-size:      0.8rem;
	font-weight:    600;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color:          var(--gray-light);
}

.form-group input,
.form-group select,
.form-group textarea {
	padding:          12px 16px;
	background:       var(--mid);
	border:           1px solid var(--border-mid);
	border-radius:    3px;
	color:            var(--off-white);
	font-family:      var(--font-body);
	font-size:        0.95rem;
	transition:       border-color var(--trans);
	width:            100%;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
	outline:       none;
	border-color:  var(--gold);
}

.form-group input::placeholder,
.form-group textarea::placeholder {
	color: var(--gray);
}

.form-group select option {
	background: var(--dark);
	color:      var(--off-white);
}

.form-group textarea {
	min-height: 140px;
	resize:     vertical;
}

.form-submit { margin-top: 24px; }

.form-message {
	margin-top:    16px;
	padding:       12px 16px;
	border-radius: 3px;
	font-size:     0.9rem;
	display:       none;
}

.form-message.success {
	display:     block;
	background:  rgba(40, 167, 69, 0.15);
	border:      1px solid rgba(40, 167, 69, 0.3);
	color:       #5fd080;
}

.form-message.error {
	display:     block;
	background:  rgba(220, 53, 69, 0.15);
	border:      1px solid rgba(220, 53, 69, 0.3);
	color:       #e87474;
}

/* Emergency contact strip */
.emergency-strip {
	background:      var(--gold);
	padding:         20px 0;
	text-align:      center;
}

.emergency-strip p {
	color:         var(--black);
	font-family:   var(--font-heading);
	font-size:     1rem;
	font-weight:   700;
	letter-spacing:1px;
	margin:        0;
}

.emergency-strip a {
	color:          var(--black);
	text-decoration:underline;
}

/* =========================================================
   17. SINGLE POST
   ========================================================= */

.single-post-hero {
	padding:    160px 0 60px;
	background: var(--dark);
}

.post-meta {
	display:     flex;
	flex-wrap:   wrap;
	gap:         16px;
	align-items: center;
	color:       var(--gray);
	font-size:   0.85rem;
	margin-bottom:16px;
}

.post-meta span { display: flex; align-items: center; gap: 6px; }
.post-meta .cat-link { color: var(--gold); }

.entry-content {
	max-width:  800px;
	margin:     0 auto;
	padding:    60px 0;
}

.entry-content p       { margin-bottom: 1.4rem; }
.entry-content h2      { margin: 2rem 0 1rem; }
.entry-content h3      { margin: 1.8rem 0 0.8rem; }
.entry-content ul,
.entry-content ol      { margin-bottom: 1.4rem; }
.entry-content li      { margin-bottom: 0.5rem; }
.entry-content img     { border-radius: 4px; margin: 1.5rem 0; }

/* Post navigation */
.post-nav {
	display:         flex;
	justify-content: space-between;
	gap:             24px;
	padding:         40px 0;
	border-top:      1px solid var(--border);
}

.post-nav a {
	color:       var(--gray-light);
	font-size:   0.9rem;
	transition:  color var(--trans);
}
.post-nav a:hover { color: var(--gold); }

/* =========================================================
   18. 404 PAGE
   ========================================================= */

.page-404 {
	min-height:      80vh;
	display:         flex;
	align-items:     center;
	justify-content: center;
	text-align:      center;
	padding:         120px 0;
}

.page-404__code {
	font-family:    var(--font-heading);
	font-size:      clamp(5rem, 15vw, 10rem);
	font-weight:    700;
	color:          var(--gold);
	opacity:        0.2;
	line-height:    1;
	margin-bottom:  20px;
}

.page-404 h1 { margin-bottom: 16px; }
.page-404 p  { color: var(--gray); max-width: 400px; margin: 0 auto 32px; }

/* =========================================================
   19. BLOG / ARCHIVE
   ========================================================= */

.archive-hero {
	padding:    140px 0 60px;
	text-align: center;
	background: var(--dark);
}

.posts-grid {
	display:               grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap:                   28px;
}

.post-card {
	background:    var(--dark);
	border:        1px solid var(--border);
	border-radius: 4px;
	overflow:      hidden;
	transition:    all var(--trans);
}

.post-card:hover {
	border-color: var(--gold);
	box-shadow:   var(--shadow-gold);
	transform:    translateY(-4px);
}

.post-card__thumb {
	width:      100%;
	height:     200px;
	object-fit: cover;
	background: var(--mid);
	display:    flex;
	align-items:center;
	justify-content:center;
	color:      var(--gray);
	font-size:  2rem;
}

.post-card__thumb img {
	width:      100%;
	height:     200px;
	object-fit: cover;
}

.post-card__body { padding: 24px; }

.post-card__cat {
	font-size:    0.7rem;
	letter-spacing:2px;
	text-transform:uppercase;
	color:        var(--gold);
	margin-bottom:8px;
	display:      block;
}

.post-card__title {
	font-family:  var(--font-heading);
	font-size:    1.1rem;
	font-weight:  700;
	color:        var(--off-white);
	margin-bottom:12px;
	line-height:  1.3;
}

.post-card__title a { color: inherit; }
.post-card__title a:hover { color: var(--gold); }

.post-card__excerpt {
	font-size:   0.875rem;
	color:       var(--gray);
	line-height: 1.6;
	margin-bottom:16px;
}

.post-card__meta {
	font-size: 0.8rem;
	color:     var(--gray);
}

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

.pagination .page-numbers {
	padding:      8px 16px;
	background:   var(--dark);
	border:       1px solid var(--border);
	color:        var(--gray-light);
	border-radius:3px;
	transition:   all var(--trans);
}

.pagination .page-numbers:hover,
.pagination .page-numbers.current {
	background:   var(--gold);
	border-color: var(--gold);
	color:        var(--black);
}

/* =========================================================
   20. SIDEBAR
   ========================================================= */

.sidebar { }

.widget {
	background:    var(--dark);
	border:        1px solid var(--border);
	border-radius: 4px;
	padding:       28px;
	margin-bottom: 24px;
}

.widget-title {
	font-family:    var(--font-heading);
	font-size:      1rem;
	font-weight:    700;
	letter-spacing: 2px;
	text-transform: uppercase;
	color:          var(--gold);
	margin-bottom:  20px;
	padding-bottom: 12px;
	border-bottom:  1px solid var(--border);
}

/* =========================================================
   21. FOOTER
   ========================================================= */

#site-footer {
	background-color: var(--black);
	border-top:       1px solid var(--border);
	padding-top:      70px;
}

.footer-grid {
	display:               grid;
	grid-template-columns: 1.5fr 1fr 1.2fr;
	gap:                   50px;
	padding-bottom:        50px;
	border-bottom:         1px solid var(--border);
}

.footer-brand__logo {
	margin-bottom: 20px;
}

.footer-brand__logo img {
	height:    45px;
	width:     auto;
	max-width: 160px;
}

.footer-brand__name {
	font-family:    var(--font-heading);
	font-size:      1.3rem;
	font-weight:    700;
	letter-spacing: 2px;
	color:          var(--white);
	margin-bottom:  4px;
}

.footer-brand__name span { color: var(--gold); }

.footer-brand__tagline {
	font-size:      0.75rem;
	letter-spacing: 2px;
	text-transform: uppercase;
	color:          var(--gray);
	margin-bottom:  20px;
}

.footer-brand__desc {
	font-size:   0.875rem;
	color:       var(--gray);
	line-height: 1.7;
	max-width:   300px;
	margin-bottom:24px;
}

.social-links {
	display: flex;
	gap:     12px;
}

.social-link {
	width:           38px;
	height:          38px;
	border-radius:   50%;
	background:      var(--dark);
	border:          1px solid var(--border);
	display:         flex;
	align-items:     center;
	justify-content: center;
	color:           var(--gray);
	font-size:       0.9rem;
	transition:      all var(--trans);
}

.social-link:hover {
	background:   var(--gold);
	border-color: var(--gold);
	color:        var(--black);
	transform:    translateY(-2px);
}

.footer-col h4 {
	font-family:    var(--font-heading);
	font-size:      0.85rem;
	font-weight:    700;
	letter-spacing: 3px;
	text-transform: uppercase;
	color:          var(--gold);
	margin-bottom:  24px;
}

.footer-links {
	list-style: none;
	padding:    0;
	margin:     0;
}

.footer-links li {
	margin-bottom: 12px;
}

.footer-links a {
	color:      var(--gray);
	font-size:  0.9rem;
	transition: color var(--trans);
	display:    flex;
	align-items:center;
	gap:        8px;
}

.footer-links a::before {
	content:    '';
	display:    block;
	width:      4px;
	height:     1px;
	background: var(--gold);
	flex-shrink:0;
	transition: width var(--trans);
}

.footer-links a:hover {
	color: var(--gold);
}
.footer-links a:hover::before { width: 12px; }

.footer-contact-item {
	display:       flex;
	align-items:   flex-start;
	gap:           14px;
	margin-bottom: 20px;
	font-size:     0.875rem;
}

.footer-contact-item:last-child { margin-bottom: 0; }

.footer-contact-item i {
	color:      var(--gold);
	font-size:  1rem;
	width:      16px;
	flex-shrink:0;
	margin-top: 2px;
}

.footer-contact-item a {
	color:      var(--gray);
	transition: color var(--trans);
}
.footer-contact-item a:hover { color: var(--gold); }

.footer-contact-item span { color: var(--gray); }

/* Footer bottom bar */
.footer-bottom {
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	flex-wrap:       wrap;
	gap:             16px;
	padding:         24px 0;
	font-size:       0.8rem;
	color:           var(--gray);
}

.footer-bottom a {
	color:      inherit;
	transition: color var(--trans);
}
.footer-bottom a:hover { color: var(--gold); }

/* =========================================================
   22. WOOCOMMERCE — HIDE CART
   ========================================================= */

.woocommerce-mini-cart,
.cart-contents,
a.cart-contents,
.woocommerce-cart-form,
li.cart,
.wc-block-mini-cart,
.wp-block-woocommerce-mini-cart,
.header-cart,
.site-header-cart,
.cart-icon,
.mini-cart { display: none !important; }

/* =========================================================
   23. ANIMATIONS & KEYFRAMES
   ========================================================= */

/* Stagger children */
.stagger > *:nth-child(1) { transition-delay: 0.05s; }
.stagger > *:nth-child(2) { transition-delay: 0.1s;  }
.stagger > *:nth-child(3) { transition-delay: 0.15s; }
.stagger > *:nth-child(4) { transition-delay: 0.2s;  }
.stagger > *:nth-child(5) { transition-delay: 0.25s; }
.stagger > *:nth-child(6) { transition-delay: 0.3s;  }

/* Gold shimmer on borders */
@keyframes shimmer {
	0%   { background-position: -200% center; }
	100% { background-position:  200% center; }
}

/* =========================================================
   24. RESPONSIVE — TABLET (≤ 992px)
   ========================================================= */

@media ( max-width: 992px ) {

	:root { --section-pad: 70px; }

	.stats-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.stat-block {
		border-bottom: 1px solid var(--border);
	}

	.stat-block:nth-child(2)  { border-right: none; }
	.stat-block:nth-child(3)  { border-bottom: none; }
	.stat-block:nth-child(4)  { border-right: none; border-bottom: none; }

	.footer-grid {
		grid-template-columns: 1fr 1fr;
	}

	.footer-col:first-child {
		grid-column: 1 / -1;
	}

	.about-intro { grid-template-columns: 1fr; }
	.about-values { grid-template-columns: 1fr 1fr; }

	.contact-layout { grid-template-columns: 1fr; }

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

/* =========================================================
   25. RESPONSIVE — MOBILE (≤ 768px)
   ========================================================= */

@media ( max-width: 768px ) {

	:root { --section-pad: 50px; }

	/* Hide desktop nav; show hamburger */
	.primary-nav    { display: none; }
	.header-phone   { display: none; }
	.hamburger      { display: flex; }

	.hero__headline { font-size: 2rem; }
	.hero__cta-group { flex-direction: column; align-items: flex-start; }

	.stats-grid {
		grid-template-columns: 1fr 1fr;
	}

	.about-values { grid-template-columns: 1fr; }
	.footer-grid  { grid-template-columns: 1fr; }

	.grid--2 { grid-template-columns: 1fr; }
	.grid--3 { grid-template-columns: 1fr; }
	.grid--4 { grid-template-columns: 1fr 1fr; }

	.form-row--2 { grid-template-columns: 1fr; }

	.post-nav { flex-direction: column; }

	.testimonial-slider { grid-template-columns: 1fr; }
	.team-grid          { grid-template-columns: repeat(2, 1fr); }
}

@media ( max-width: 480px ) {

	.stats-grid { grid-template-columns: 1fr; }
	.stat-block { border-right: none; }

	.hero__contact { flex-direction: column; align-items: flex-start; }
	.cta-banner__buttons { flex-direction: column; align-items: center; }

	.team-grid { grid-template-columns: 1fr; }
	.grid--4   { grid-template-columns: 1fr; }
}
