/* =============================================================================
   Technoglobi Theme — main.css
   Sistema de design completo. As CSS Custom Properties são definidas
   dinamicamente em inc/dynamic-css.php a partir do WordPress Customizer.
   ============================================================================= */

/* ─── Reset & Base ─────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
    font-size: var(--tg-font-size-base, 16px);
}

body {
    font-family: var(--tg-font, 'Exo', sans-serif);
    color: var(--tg-text);
    background: var(--tg-bg);
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}
.site-main { flex: 1; }

img, video, svg { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; }
ul, ol { list-style: none; }
input, textarea, select, button { font-family: inherit; font-size: inherit; }

/* Skip Link */
.skip-link {
    position: absolute;
    top: -100%;
    left: 1rem;
    padding: .5rem 1rem;
    background: var(--tg-accent);
    color: var(--tg-primary);
    font-weight: 700;
    border-radius: var(--tg-radius-sm);
    z-index: 9999;
    transition: top var(--tg-transition);
}
.skip-link:focus { top: 1rem; }

/* ─── Container ────────────────────────────────────────────────────────────── */
.tg-container {
    width: 100%;
    max-width: var(--tg-container-max, 1280px);
    margin-inline: auto;
    padding-inline: var(--tg-container-pad, 1.5rem);
}

/* ─── Typography ───────────────────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--tg-font);
    font-weight: 700;
    line-height: 1.2;
    color: var(--tg-text);
}
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.5rem); }
h4 { font-size: 1.15rem; }

p { max-width: 70ch; }
p + p { margin-top: .875rem; }

/* Prose — content areas */
.prose h1, .prose h2, .prose h3, .prose h4 { margin-top: 1.75em; margin-bottom: .5em; }
.prose p { margin-bottom: 1rem; max-width: 72ch; }
.prose ul, .prose ol { padding-left: 1.5rem; margin-bottom: 1rem; list-style: initial; }
.prose li { margin-bottom: .35rem; }
.prose a { color: var(--tg-accent); text-decoration: underline; text-underline-offset: 3px; }
.prose strong { font-weight: 700; }
.prose blockquote { border-left: 4px solid var(--tg-accent); padding-left: 1.25rem; font-style: italic; color: var(--tg-text-muted); }
.prose img { border-radius: var(--tg-radius-md); margin-block: 1.5rem; }
.prose table { width: 100%; border-collapse: collapse; margin-bottom: 1.5rem; }
.prose th, .prose td { padding: .625rem .875rem; border: 1px solid var(--tg-border); text-align: left; }
.prose th { background: var(--tg-bg-alt); font-weight: 600; }

/* ─── Buttons ──────────────────────────────────────────────────────────────── */
.tg-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .75rem 1.75rem;
    border-radius: var(--tg-radius-full);
    font-weight: 600;
    font-size: .9375rem;
    letter-spacing: .01em;
    border: 2px solid transparent;
    transition: all var(--tg-transition);
    white-space: nowrap;
    cursor: pointer;
    text-decoration: none;
}
.tg-btn:focus-visible { outline: 3px solid var(--tg-accent); outline-offset: 3px; }

.tg-btn--sm  { padding: .5rem 1.25rem; font-size: .875rem; }
.tg-btn--lg  { padding: .9375rem 2.25rem; font-size: 1rem; }
.tg-btn--full { width: 100%; justify-content: center; }

/* Primary */
.tg-btn--primary {
    background: var(--tg-primary);
    color: #fff;
    border-color: var(--tg-primary);
}
.tg-btn--primary:hover {
    background: color-mix(in srgb, var(--tg-primary) 85%, black);
    border-color: color-mix(in srgb, var(--tg-primary) 85%, black);
    transform: translateY(-2px);
    box-shadow: var(--tg-shadow-primary);
}

/* Accent */
.tg-btn--accent {
    background: var(--tg-accent);
    color: var(--tg-primary);
    border-color: var(--tg-accent);
    font-weight: 700;
}
.tg-btn--accent:hover {
    background: var(--tg-accent-dark);
    border-color: var(--tg-accent-dark);
    transform: translateY(-2px);
    box-shadow: var(--tg-shadow-accent);
}

/* Outline Dark */
.tg-btn--outline {
    background: transparent;
    color: var(--tg-primary);
    border-color: var(--tg-primary);
}
.tg-btn--outline:hover {
    background: var(--tg-primary);
    color: #fff;
    transform: translateY(-2px);
}

/* Outline White */
.tg-btn--outline-white {
    background: transparent;
    color: #fff;
    border-color: rgba(255,255,255,.6);
}
.tg-btn--outline-white:hover {
    background: rgba(255,255,255,.15);
    border-color: #fff;
    transform: translateY(-2px);
}

/* ─── Badges / Labels ──────────────────────────────────────────────────────── */
.tg-badge {
    display: inline-flex;
    align-items: center;
    padding: .3rem .875rem;
    border-radius: var(--tg-radius-full);
    font-size: .8125rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    background: var(--tg-accent-light);
    color: var(--tg-accent-dark, var(--tg-primary));
}
.tg-badge--accent-outline {
    background: transparent;
    border: 1.5px solid rgba(var(--tg-accent-rgb), .6);
    color: var(--tg-accent);
}

/* ─── Section Header ───────────────────────────────────────────────────────── */
.tg-section-header { margin-bottom: 3.5rem; }
.tg-section-header--center { text-align: center; }
.tg-section-header--center p { margin-inline: auto; }
.tg-section-header .tg-badge { margin-bottom: .875rem; }
.tg-section-header__title {
    margin-bottom: .875rem;
    color: var(--tg-text);
}
.tg-section-header--dark .tg-section-header__title { color: #fff; }
.tg-section-header--dark .tg-section-header__subtitle { color: rgba(255,255,255,.75); }
.tg-section-header__subtitle {
    font-size: 1.0625rem;
    color: var(--tg-text-muted);
    font-weight: 400;
    max-width: 62ch;
    line-height: 1.7;
}

/* ─── Animations ───────────────────────────────────────────────────────────── */
[data-animate] {
    opacity: 0;
    transform: translateY(32px);
    transition: opacity .6s cubic-bezier(.4,0,.2,1), transform .6s cubic-bezier(.4,0,.2,1);
}
[data-animate="fade-left"]  { transform: translateX(-40px); }
[data-animate="fade-right"] { transform: translateX(40px); }
[data-animate="fade-up"]    { transform: translateY(40px); }
[data-animate].is-visible {
    opacity: 1;
    transform: none;
}
@media (prefers-reduced-motion: reduce) {
    [data-animate] { opacity: 1; transform: none; transition: none; }
}

/* ─── ═══════════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════════ */
.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background: var(--tg-primary);
    transition: background var(--tg-transition), box-shadow var(--tg-transition), padding var(--tg-transition);
}
/* Transparente no topo */
.header-transparent .site-header { background: transparent; }
.header-transparent .site-header.is-scrolled { background: var(--tg-primary); box-shadow: 0 2px 20px rgba(0,0,0,.2); }
/* Sempre sólido */
body:not(.header-transparent) .site-header { box-shadow: 0 2px 20px rgba(0,0,0,.15); }

.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    height: 72px;
    transition: height var(--tg-transition);
}
.site-header.is-scrolled .site-header__inner { height: 60px; }

/* Logo */
.site-header__brand { flex-shrink: 0; }
.site-header__logo a { display: block; }
.site-header__logo img { height: 40px; width: auto; }
.site-header__name {
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -.02em;
}

/* Nav */
.site-header__nav { flex: 1; display: flex; justify-content: center; }
.nav-menu { display: flex; align-items: center; gap: .25rem; }
.nav-menu li { position: relative; }
.nav-menu a {
    display: block;
    padding: .5rem .875rem;
    color: rgba(255,255,255,.85);
    font-size: .9rem;
    font-weight: 500;
    border-radius: var(--tg-radius-sm);
    transition: color var(--tg-transition), background var(--tg-transition);
}
.nav-menu a:hover,
.nav-menu .current-menu-item > a { color: var(--tg-accent); }
/* Dropdown */
.nav-menu .sub-menu {
    position: absolute;
    top: calc(100% + .5rem);
    left: 50%;
    transform: translateX(-50%) translateY(-8px);
    min-width: 200px;
    background: var(--tg-primary);
    border-radius: var(--tg-radius-md);
    box-shadow: var(--tg-shadow-xl);
    padding: .5rem;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--tg-transition), transform var(--tg-transition);
    border: 1px solid rgba(255,255,255,.1);
    z-index: 100;
}
.nav-menu li:hover > .sub-menu,
.nav-menu li:focus-within > .sub-menu {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}
.nav-menu .sub-menu a { color: rgba(255,255,255,.8); font-size: .875rem; border-radius: var(--tg-radius-sm); }
.nav-menu .sub-menu a:hover { color: var(--tg-accent); background: rgba(255,255,255,.06); }

/* Header Actions */
.site-header__actions { display: flex; align-items: center; gap: .875rem; flex-shrink: 0; }
.site-header__phone {
    display: flex;
    align-items: center;
    gap: .375rem;
    color: rgba(255,255,255,.8);
    font-size: .875rem;
    transition: color var(--tg-transition);
}
.site-header__phone:hover { color: var(--tg-accent); }
.site-header__phone svg { flex-shrink: 0; }

/* Mobile Toggle */
.nav-toggle {
    display: none;
    background: transparent;
    border: none;
    color: #fff;
    padding: .375rem;
    border-radius: var(--tg-radius-sm);
    transition: background var(--tg-transition);
}
.nav-toggle:hover { background: rgba(255,255,255,.1); }
.nav-toggle__icon--close { display: none; }
.nav-toggle[aria-expanded="true"] .nav-toggle__icon--open  { display: none; }
.nav-toggle[aria-expanded="true"] .nav-toggle__icon--close { display: block; }

/* ─── Mobile Menu ──────────────────────────────────────────────────────────── */
.mobile-menu {
    position: fixed;
    inset: 72px 0 0 0;
    background: var(--tg-primary);
    z-index: 999;
    overflow-y: auto;
    transform: translateX(-100%);
    transition: transform var(--tg-transition-slow);
}
.mobile-menu.is-open { transform: none; }
.mobile-menu__overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.5);
    z-index: 998;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--tg-transition-slow);
}
.mobile-menu.is-open ~ .mobile-menu__overlay { opacity: 1; pointer-events: auto; }
.mobile-menu__inner { padding: 2rem 1.5rem; }
.mobile-nav-menu li a {
    display: block;
    padding: .875rem 0;
    color: rgba(255,255,255,.85);
    font-size: 1.1rem;
    font-weight: 500;
    border-bottom: 1px solid rgba(255,255,255,.08);
    transition: color var(--tg-transition), padding-left var(--tg-transition);
}
.mobile-nav-menu li a:hover { color: var(--tg-accent); padding-left: .5rem; }
.mobile-menu__cta { margin-top: 2rem; width: 100%; justify-content: center; }
.mobile-menu__social { margin-top: 1.5rem; }

/* ─── ═══════════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════════ */
.tg-hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    background: var(--tg-primary);
    overflow: hidden;
    padding-top: 72px; /* header height */
}
.tg-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.tg-hero__bg-img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center;
}
.tg-hero__overlay {
    position: absolute;
    inset: 0;
    background: var(--tg-primary);
}
.tg-hero__pattern {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle, rgba(var(--tg-accent-rgb),.06) 1px, transparent 1px);
    background-size: 32px 32px;
    pointer-events: none;
}

.tg-hero__inner {
    position: relative;
    z-index: 1;
    padding-block: 6rem 4rem;
}
.tg-hero--split .tg-hero__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}
.tg-hero--centered .tg-hero__inner { text-align: center; max-width: 800px; margin-inline: auto; }

.tg-hero__text { display: flex; flex-direction: column; align-items: flex-start; gap: 1.25rem; }
.tg-hero--centered .tg-hero__text { align-items: center; }

.tg-hero__title {
    color: #fff;
    font-size: clamp(2.25rem, 5vw, 3.75rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -.03em;
}
/* Destaque em partes do título */
.tg-hero__title em, .tg-hero__title strong { color: var(--tg-accent); font-style: normal; }

.tg-hero__subtitle {
    color: rgba(255,255,255,.78);
    font-size: clamp(1rem, 2vw, 1.2rem);
    font-weight: 400;
    line-height: 1.7;
    max-width: 52ch;
}

.tg-hero__actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: .5rem; }

/* Visual */
.tg-hero__visual { position: relative; }
.tg-hero__visual-inner { position: relative; }
.tg-hero__visual-img {
    width: 100%;
    border-radius: var(--tg-radius-xl);
    box-shadow: var(--tg-shadow-xl);
}
.tg-hero__visual-deco {
    position: absolute;
    inset: -1.5rem;
    border: 2px solid rgba(var(--tg-accent-rgb),.2);
    border-radius: calc(var(--tg-radius-xl) + 1.5rem);
    pointer-events: none;
    animation: deco-pulse 4s ease-in-out infinite;
}
@keyframes deco-pulse {
    0%, 100% { opacity: .6; transform: scale(1); }
    50% { opacity: 1; transform: scale(1.02); }
}

/* Scroll indicator */
.tg-hero__scroll {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.tg-hero__scroll-dot {
    width: 24px; height: 40px;
    border: 2px solid rgba(255,255,255,.4);
    border-radius: var(--tg-radius-full);
    position: relative;
}
.tg-hero__scroll-dot::after {
    content: '';
    position: absolute;
    top: 6px; left: 50%;
    transform: translateX(-50%);
    width: 4px; height: 8px;
    background: var(--tg-accent);
    border-radius: var(--tg-radius-full);
    animation: scroll-dot 2s ease-in-out infinite;
}
@keyframes scroll-dot {
    0% { top: 6px; opacity: 1; }
    80% { top: 20px; opacity: 0; }
    100% { top: 6px; opacity: 0; }
}

/* ─── ═══════════════════════════════════════════════════════════════
   STATS
   ═══════════════════════════════════════════════════════════════ */
.tg-stats { padding-block: 3.5rem; }
.tg-stats--primary { background: var(--tg-primary); }
.tg-stats--accent  { background: var(--tg-accent); }
.tg-stats--light   { background: var(--tg-bg-alt); }

.tg-stats__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
}
.tg-stats__item {
    text-align: center;
    padding: 1.5rem;
    position: relative;
}
.tg-stats__item:not(:last-child)::after {
    content: '';
    position: absolute;
    right: 0;
    top: 25%; bottom: 25%;
    width: 1px;
    background: rgba(255,255,255,.15);
}
.tg-stats--light .tg-stats__item:not(:last-child)::after { background: var(--tg-border); }
.tg-stats--accent .tg-stats__item:not(:last-child)::after { background: rgba(var(--tg-primary-rgb),.2); }

.tg-stats__number {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: .125rem;
    line-height: 1;
    margin-bottom: .5rem;
}
.tg-stats--primary .tg-stats__number,
.tg-stats--primary .tg-stats__label { color: #fff; }
.tg-stats--accent  .tg-stats__number,
.tg-stats--accent  .tg-stats__label { color: var(--tg-primary); }
.tg-stats--light   .tg-stats__number { color: var(--tg-primary); }

.tg-stats__count {
    font-size: clamp(2.25rem, 4vw, 3.25rem);
    font-weight: 800;
    color: var(--tg-accent);
    letter-spacing: -.03em;
}
.tg-stats--accent .tg-stats__count { color: var(--tg-primary); }
.tg-stats--light  .tg-stats__count { color: var(--tg-accent-dark, var(--tg-accent)); }

.tg-stats__suffix {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--tg-accent);
}
.tg-stats__label {
    font-size: .875rem;
    font-weight: 500;
    letter-spacing: .02em;
    color: rgba(255,255,255,.7);
    text-transform: uppercase;
}
.tg-stats--light .tg-stats__label { color: var(--tg-text-muted); }

/* ─── ═══════════════════════════════════════════════════════════════
   ABOUT
   ═══════════════════════════════════════════════════════════════ */
.tg-about { padding-block: var(--tg-section-py); background: var(--tg-bg); }
.tg-about__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    align-items: center;
}
.tg-about__visual-inner {
    position: relative;
    border-radius: var(--tg-radius-xl);
    overflow: visible;
}
.tg-about__img {
    width: 100%;
    border-radius: var(--tg-radius-xl);
    box-shadow: var(--tg-shadow-xl);
    aspect-ratio: 7/8;
    object-fit: cover;
}
.tg-about__img-placeholder { border-radius: var(--tg-radius-xl); overflow: hidden; aspect-ratio: 7/8; }
.tg-about__img-placeholder svg { width: 100%; height: 100%; }

.tg-about__badge {
    position: absolute;
    bottom: -1.5rem;
    right: -1.5rem;
    background: var(--tg-accent);
    color: var(--tg-primary);
    padding: 1.25rem 1.5rem;
    border-radius: var(--tg-radius-lg);
    text-align: center;
    box-shadow: var(--tg-shadow-accent);
    min-width: 130px;
}
.tg-about__badge-number { display: block; font-size: 2rem; font-weight: 800; line-height: 1; }
.tg-about__badge-text { font-size: .8rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }

.tg-about__content .tg-section-header { margin-bottom: 1.5rem; }
.tg-about__text { color: var(--tg-text-muted); font-size: 1.0625rem; line-height: 1.75; margin-bottom: 2rem; }

.tg-about__features {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .875rem 1.5rem;
    margin-bottom: 2.5rem;
}
.tg-about__feature {
    display: flex;
    align-items: center;
    gap: .625rem;
    font-size: .9375rem;
    font-weight: 500;
}
.tg-about__feature-icon { font-size: 1.25rem; flex-shrink: 0; }
.tg-about__feature-icon--check {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 22px; height: 22px;
    background: var(--tg-accent-light);
    color: var(--tg-accent-dark, var(--tg-primary));
    border-radius: 50%;
}

/* ─── ═══════════════════════════════════════════════════════════════
   SERVICES
   ═══════════════════════════════════════════════════════════════ */
.tg-services {
    padding-block: var(--tg-section-py);
}
.tg-services--white   { background: var(--tg-bg); }
.tg-services--light   { background: var(--tg-bg-alt); }
.tg-services--primary { background: var(--tg-primary); }
.tg-services--primary .tg-section-header__title { color: #fff; }
.tg-services--primary .tg-section-header__subtitle { color: rgba(255,255,255,.7); }

.tg-services__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.tg-service-card {
    position: relative;
    background: var(--tg-bg);
    border: 1px solid var(--tg-border);
    border-radius: var(--tg-radius-lg);
    padding: 2.25rem 2rem;
    overflow: hidden;
    transition: transform var(--tg-transition), box-shadow var(--tg-transition), border-color var(--tg-transition);
}
.tg-services--primary .tg-service-card {
    background: rgba(255,255,255,.06);
    border-color: rgba(255,255,255,.1);
}
.tg-service-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--tg-shadow-xl);
    border-color: var(--tg-accent);
}
.tg-service-card__accent {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: var(--tg-accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--tg-transition);
}
.tg-service-card:hover .tg-service-card__accent { transform: scaleX(1); }

.tg-service-card__icon {
    width: 60px; height: 60px;
    background: var(--tg-accent-light);
    border-radius: var(--tg-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.75rem;
    margin-bottom: 1.25rem;
    transition: background var(--tg-transition), transform var(--tg-transition);
}
.tg-service-card:hover .tg-service-card__icon { background: var(--tg-accent); transform: scale(1.1); }
.tg-services--primary .tg-service-card__icon { background: rgba(var(--tg-accent-rgb), .15); }

.tg-service-card__title {
    font-size: 1.125rem;
    font-weight: 700;
    margin-bottom: .625rem;
    color: var(--tg-text);
}
.tg-services--primary .tg-service-card__title { color: #fff; }
.tg-service-card__desc {
    font-size: .9375rem;
    color: var(--tg-text-muted);
    line-height: 1.65;
    margin-bottom: 1.25rem;
}
.tg-services--primary .tg-service-card__desc { color: rgba(255,255,255,.65); }
.tg-service-card__link {
    display: inline-flex;
    align-items: center;
    gap: .375rem;
    font-size: .875rem;
    font-weight: 600;
    color: var(--tg-accent);
    transition: gap var(--tg-transition);
}
.tg-service-card__link:hover { gap: .625rem; }

/* ─── ═══════════════════════════════════════════════════════════════
   PORTFOLIO
   ═══════════════════════════════════════════════════════════════ */
.tg-portfolio { padding-block: var(--tg-section-py); background: var(--tg-bg); }
.tg-portfolio__grid {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    margin-bottom: 3rem;
    justify-content: center;
}
.tg-portfolio__footer { text-align: center; }
.tg-portfolio__empty { text-align: center; padding: 4rem; color: var(--tg-text-muted); background: var(--tg-bg-alt); border-radius: var(--tg-radius-lg); }

.tg-portfolio-card { flex: 1 1 260px; max-width: 380px; border-radius: var(--tg-radius-lg); overflow: hidden; background: var(--tg-bg); box-shadow: var(--tg-shadow-md); transition: transform var(--tg-transition), box-shadow var(--tg-transition); }
.tg-portfolio-card:hover { transform: translateY(-6px); box-shadow: var(--tg-shadow-xl); }
.tg-portfolio-card__link { display: block; text-decoration: none; }
.tg-portfolio-card__media { position: relative; overflow: hidden; aspect-ratio: 4/3; }
.tg-portfolio-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--tg-transition-slow); }
.tg-portfolio-card:hover .tg-portfolio-card__media img { transform: scale(1.08); }
.tg-portfolio-card__placeholder { width: 100%; height: 100%; }
.tg-portfolio-card__overlay {
    position: absolute;
    inset: 0;
    background: rgba(var(--tg-primary-rgb), .7);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity var(--tg-transition);
}
.tg-portfolio-card:hover .tg-portfolio-card__overlay { opacity: 1; }
.tg-portfolio-card__overlay-icon { color: var(--tg-accent); }
.tg-portfolio-card__info { padding: 1.25rem 1.5rem; }
.tg-portfolio-card__cat { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--tg-accent); margin-bottom: .375rem; display: block; }
.tg-portfolio-card__title { font-size: 1rem; font-weight: 700; color: var(--tg-text); margin-bottom: .25rem; }
.tg-portfolio-card__client { font-size: .875rem; color: var(--tg-text-muted); }

/* ─── ═══════════════════════════════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════════════════════════════ */
.tg-testimonials { padding-block: var(--tg-section-py); }
.tg-testimonials--primary { background: var(--tg-primary); }
.tg-testimonials--light   { background: var(--tg-bg); }
.tg-testimonials--alt     { background: var(--tg-bg-alt); }
.tg-testimonials__empty { text-align: center; padding: 3rem; color: rgba(255,255,255,.6); }

.tg-testimonials__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    align-items: start; /* cards não esticam para a altura da linha */
}

.tg-testimonial-card {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--tg-radius-lg);
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    transition: transform var(--tg-transition), box-shadow var(--tg-transition);
}
.tg-testimonials--light .tg-testimonial-card,
.tg-testimonials--alt .tg-testimonial-card {
    background: var(--tg-bg);
    border-color: var(--tg-border);
}
.tg-testimonial-card:hover { transform: translateY(-4px); box-shadow: var(--tg-shadow-xl); }

.tg-testimonial-card__quote-icon { color: var(--tg-accent); opacity: .6; }
.tg-testimonial-card__stars { display: flex; gap: .2rem; }
.tg-star--filled svg { fill: #f59e0b; color: #f59e0b; }
.tg-star--empty svg  { fill: rgba(0,0,0,.15); color: rgba(0,0,0,.15); }
.tg-testimonials--primary .tg-star--empty svg { fill: rgba(255,255,255,.2); color: rgba(255,255,255,.2); }

.tg-testimonial-card__text {
    font-size: .9375rem;
    line-height: 1.7;
    color: rgba(255,255,255,.8);
    font-style: italic;
}
.tg-testimonials--light .tg-testimonial-card__text,
.tg-testimonials--alt   .tg-testimonial-card__text { color: var(--tg-text-muted); }

.tg-testimonial-card__author {
    display: flex;
    align-items: center;
    gap: .875rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255,255,255,.1);
}
.tg-testimonials--light .tg-testimonial-card__author,
.tg-testimonials--alt   .tg-testimonial-card__author { border-top-color: var(--tg-border); }

.tg-testimonial-card__avatar { flex-shrink: 0; }
.tg-testimonial-card__avatar img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; }
.tg-testimonial-card__avatar--initials {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: var(--tg-accent);
    color: var(--tg-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 1.25rem;
}
.tg-testimonial-card__name {
    display: block;
    font-weight: 700;
    font-size: .9375rem;
    color: #fff;
    font-style: normal;
}
.tg-testimonials--light .tg-testimonial-card__name,
.tg-testimonials--alt   .tg-testimonial-card__name { color: var(--tg-text); }
.tg-testimonial-card__role { font-size: .8125rem; color: rgba(255,255,255,.6); }
.tg-testimonials--light .tg-testimonial-card__role,
.tg-testimonials--alt   .tg-testimonial-card__role { color: var(--tg-text-light); }

/* ─── ═══════════════════════════════════════════════════════════════
   TEAM
   ═══════════════════════════════════════════════════════════════ */
.tg-team { padding-block: var(--tg-section-py); }
.tg-team--white { background: var(--tg-bg); }
.tg-team--light { background: var(--tg-bg-alt); }
.tg-team__empty { text-align: center; padding: 3rem; color: var(--tg-text-muted); }

.tg-team__grid {
    display: grid;
    gap: 2rem;
}
.tg-team__grid--1 { grid-template-columns: 1fr; max-width: 320px; margin-inline: auto; }
.tg-team__grid--2 { grid-template-columns: repeat(2, 1fr); }
.tg-team__grid--3 { grid-template-columns: repeat(3, 1fr); }
.tg-team__grid--4 { grid-template-columns: repeat(4, 1fr); }

.tg-team-card {
    background: var(--tg-bg);
    border-radius: var(--tg-radius-lg);
    overflow: hidden;
    box-shadow: var(--tg-shadow-md);
    transition: transform var(--tg-transition), box-shadow var(--tg-transition);
    text-align: center;
}
.tg-team-card:hover { transform: translateY(-6px); box-shadow: var(--tg-shadow-xl); }

.tg-team-card__photo { position: relative; overflow: hidden; aspect-ratio: 3/4; }
.tg-team-card__photo img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--tg-transition-slow); }
.tg-team-card:hover .tg-team-card__photo img { transform: scale(1.05); }
.tg-team-card__photo-placeholder {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--tg-primary) 0%, color-mix(in srgb, var(--tg-primary) 60%, var(--tg-accent)) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    font-weight: 800;
    color: var(--tg-accent);
}
.tg-team-card__info { padding: 1.5rem; }
.tg-team-card__name { font-size: 1.0625rem; font-weight: 700; color: var(--tg-text); margin-bottom: .25rem; }
.tg-team-card__role { font-size: .875rem; color: var(--tg-accent); font-weight: 600; margin-bottom: .875rem; }
.tg-team-card__bio { font-size: .875rem; color: var(--tg-text-muted); line-height: 1.6; margin-bottom: 1rem; }
.tg-team-card__links { display: flex; justify-content: center; gap: .625rem; }
.tg-team-card__links a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    background: var(--tg-bg-alt);
    border-radius: 50%;
    color: var(--tg-text-muted);
    transition: background var(--tg-transition), color var(--tg-transition);
}
.tg-team-card__links a:hover { background: var(--tg-accent); color: var(--tg-primary); }

/* ─── ═══════════════════════════════════════════════════════════════
   PRICING
   ═══════════════════════════════════════════════════════════════ */
.tg-pricing { padding-block: var(--tg-section-py); background: var(--tg-bg-alt); }
.tg-pricing__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    align-items: start;
}

.tg-pricing-card {
    position: relative;
    background: var(--tg-bg);
    border: 2px solid var(--tg-border);
    border-radius: var(--tg-radius-xl);
    padding: 2.5rem 2rem;
    transition: transform var(--tg-transition), box-shadow var(--tg-transition), border-color var(--tg-transition);
}
.tg-pricing-card:hover { transform: translateY(-4px); box-shadow: var(--tg-shadow-xl); }
.tg-pricing-card--featured {
    background: var(--tg-primary);
    border-color: var(--tg-primary);
    transform: scale(1.04);
    box-shadow: var(--tg-shadow-primary);
    z-index: 1;
}
.tg-pricing-card--featured:hover { transform: scale(1.04) translateY(-4px); }

.tg-pricing-card__badge {
    position: absolute;
    top: -1rem;
    left: 50%;
    transform: translateX(-50%);
    background: var(--tg-accent);
    color: var(--tg-primary);
    padding: .3rem 1.25rem;
    border-radius: var(--tg-radius-full);
    font-size: .8125rem;
    font-weight: 800;
    letter-spacing: .04em;
    white-space: nowrap;
    box-shadow: var(--tg-shadow-accent);
}
.tg-pricing-card__header { margin-bottom: 2rem; }
.tg-pricing-card__name {
    font-size: 1.0625rem;
    font-weight: 700;
    margin-bottom: 1.25rem;
    color: var(--tg-text);
}
.tg-pricing-card--featured .tg-pricing-card__name { color: rgba(255,255,255,.8); }

.tg-pricing-card__price { display: flex; align-items: baseline; flex-wrap: wrap; gap: .25rem; }
.tg-pricing-card__amount { font-size: 2.75rem; font-weight: 800; color: var(--tg-primary); letter-spacing: -.04em; line-height: 1; }
.tg-pricing-card--featured .tg-pricing-card__amount { color: var(--tg-accent); }
.tg-pricing-card__period { font-size: .9rem; color: var(--tg-text-muted); font-weight: 500; }
.tg-pricing-card--featured .tg-pricing-card__period { color: rgba(255,255,255,.6); }

.tg-pricing-card__features {
    display: flex;
    flex-direction: column;
    gap: .75rem;
    margin-bottom: 2rem;
    padding: 1.5rem 0;
    border-top: 1px solid var(--tg-border);
    border-bottom: 1px solid var(--tg-border);
}
.tg-pricing-card--featured .tg-pricing-card__features {
    border-color: rgba(255,255,255,.1);
}
.tg-pricing-card__features li {
    display: flex;
    align-items: center;
    gap: .625rem;
    font-size: .9375rem;
    color: var(--tg-text);
}
.tg-pricing-card--featured .tg-pricing-card__features li { color: rgba(255,255,255,.85); }
.tg-pricing-card__check { color: var(--tg-accent); flex-shrink: 0; }
.tg-pricing-card__footer { margin-top: .5rem; }

/* ─── ═══════════════════════════════════════════════════════════════
   FAQ
   ═══════════════════════════════════════════════════════════════ */
.tg-faq { padding-block: var(--tg-section-py); background: var(--tg-bg); }
.tg-faq__accordion { max-width: 760px; margin-inline: auto; display: flex; flex-direction: column; gap: .75rem; }

.tg-faq__item {
    border: 1px solid var(--tg-border);
    border-radius: var(--tg-radius-md);
    overflow: hidden;
    transition: border-color var(--tg-transition), box-shadow var(--tg-transition);
}
.tg-faq__item:has(.tg-faq__question[aria-expanded="true"]),
.tg-faq__item.is-open {
    border-color: var(--tg-accent);
    box-shadow: 0 0 0 3px var(--tg-accent-light);
}

.tg-faq__question {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    background: transparent;
    border: none;
    text-align: left;
    font-size: 1rem;
    font-weight: 600;
    color: var(--tg-text);
    cursor: pointer;
    transition: background var(--tg-transition), color var(--tg-transition);
}
.tg-faq__question:hover { background: var(--tg-bg-alt); color: var(--tg-primary); }
.tg-faq__question[aria-expanded="true"] { color: var(--tg-accent-dark, var(--tg-primary)); background: var(--tg-accent-light); }
.tg-faq__icon { flex-shrink: 0; transition: transform var(--tg-transition); }
.tg-faq__question[aria-expanded="true"] .tg-faq__icon { transform: rotate(180deg); color: var(--tg-accent); }

.tg-faq__answer { overflow: hidden; }
.tg-faq__answer[hidden] { display: none; }
.tg-faq__answer-inner {
    padding: 0 1.5rem 1.25rem;
    font-size: .9375rem;
    color: var(--tg-text-muted);
    line-height: 1.7;
}

/* ─── ═══════════════════════════════════════════════════════════════
   CTA BANNER
   ═══════════════════════════════════════════════════════════════ */
.tg-cta {
    position: relative;
    padding-block: 5rem;
    overflow: hidden;
}
.tg-cta--primary  { background: var(--tg-primary); }
.tg-cta--gradient { background: linear-gradient(135deg, var(--tg-primary) 0%, color-mix(in srgb, var(--tg-primary) 40%, var(--tg-accent)) 100%); }
.tg-cta--accent   { background: var(--tg-accent); }
.tg-cta--dark     { background: #0d1a22; }

.tg-cta__pattern {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 28px 28px;
    pointer-events: none;
}
.tg-cta__inner { position: relative; z-index: 1; text-align: center; max-width: 700px; margin-inline: auto; }
.tg-cta__title { font-size: clamp(1.75rem, 3.5vw, 2.75rem); color: #fff; margin-bottom: 1rem; font-weight: 800; letter-spacing: -.02em; }
.tg-cta--accent .tg-cta__title { color: var(--tg-primary); }
.tg-cta__subtitle { font-size: 1.0625rem; color: rgba(255,255,255,.78); margin-bottom: 2.5rem; line-height: 1.7; max-width: 52ch; margin-inline: auto; }
.tg-cta--accent .tg-cta__subtitle { color: rgba(var(--tg-primary-rgb), .8); }
.tg-cta__actions { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; }

/* ─── ═══════════════════════════════════════════════════════════════
   CONTACT
   ═══════════════════════════════════════════════════════════════ */
.tg-contact { padding-block: var(--tg-section-py); background: var(--tg-bg); }
.tg-contact__grid {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 5rem;
    align-items: start;
}

.tg-contact__details { display: flex; flex-direction: column; gap: 1.5rem; margin-bottom: 2rem; }
.tg-contact__detail { display: flex; gap: 1rem; align-items: flex-start; }
.tg-contact__detail-icon {
    flex-shrink: 0;
    width: 44px; height: 44px;
    background: var(--tg-accent-light);
    border-radius: var(--tg-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--tg-accent-dark, var(--tg-primary));
}
.tg-contact__detail div { display: flex; flex-direction: column; gap: .2rem; padding-top: .5rem; }
.tg-contact__detail strong { font-size: .8125rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--tg-text-light); }
.tg-contact__detail span, .tg-contact__detail a { font-size: .9375rem; color: var(--tg-text); }
.tg-contact__detail a:hover { color: var(--tg-accent); }

.tg-contact__social { margin-bottom: 1.5rem; }
.tg-contact__map {
    border-radius: var(--tg-radius-lg);
    overflow: hidden;
    box-shadow: var(--tg-shadow-md);
}
.tg-contact__map iframe { display: block; }

/* Form */
.tg-contact__form-wrap {
    background: var(--tg-bg);
    border: 1px solid var(--tg-border);
    border-radius: var(--tg-radius-xl);
    padding: 2.5rem;
    box-shadow: var(--tg-shadow-lg);
}
.tg-form-row { display: flex; gap: 1.25rem; }
.tg-form-row--2 > * { flex: 1; }
.tg-form-field { display: flex; flex-direction: column; gap: .375rem; margin-bottom: 1.25rem; }
.tg-form-field label { font-size: .875rem; font-weight: 600; color: var(--tg-text); }
.tg-form-field input,
.tg-form-field textarea,
.tg-form-field select {
    width: 100%;
    padding: .75rem 1rem;
    background: var(--tg-bg-alt);
    border: 1.5px solid var(--tg-border);
    border-radius: var(--tg-radius-md);
    font-size: .9375rem;
    color: var(--tg-text);
    transition: border-color var(--tg-transition), box-shadow var(--tg-transition);
}
.tg-form-field input:focus,
.tg-form-field textarea:focus,
.tg-form-field select:focus {
    outline: none;
    border-color: var(--tg-accent);
    box-shadow: 0 0 0 3px var(--tg-accent-light);
    background: var(--tg-bg);
}
.tg-form-field textarea { resize: vertical; min-height: 130px; }
.tg-form-field input:invalid:not(:placeholder-shown) { border-color: #ef4444; }
.tg-form-feedback {
    padding: .875rem 1rem;
    border-radius: var(--tg-radius-md);
    font-size: .9375rem;
    font-weight: 500;
    margin-top: .5rem;
}
.tg-form-feedback--success { background: #f0fdf4; color: #166534; border: 1px solid #bbf7d0; }
.tg-form-feedback--error   { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }

/* ─── ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.site-footer { padding-top: 5rem; }
.footer--primary { background: var(--tg-primary); color: rgba(255,255,255,.75); }
.footer--dark    { background: #0d1a22; color: rgba(255,255,255,.7); }
.footer--light   { background: var(--tg-bg-alt); color: var(--tg-text-muted); }

.footer__grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1.5fr;
    gap: 3rem 2rem;
    padding-bottom: 4rem;
}
.footer__logo { margin-bottom: 1.25rem; }
.footer__logo img { height: 40px; width: auto; }
.footer__site-name { font-size: 1.375rem; font-weight: 700; color: #fff; margin-bottom: 1rem; display: block; }
.footer--light .footer__site-name { color: var(--tg-primary); }
.footer__about { font-size: .9375rem; line-height: 1.7; margin-bottom: 1.5rem; max-width: 32ch; }
.footer__col-title { font-size: .8125rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 1.25rem; color: #fff; }
.footer--light .footer__col-title { color: var(--tg-text); }
.footer__menu li + li { margin-top: .625rem; }
.footer__menu a { font-size: .9375rem; opacity: .75; transition: opacity var(--tg-transition), padding-left var(--tg-transition), color var(--tg-transition); }
.footer__menu a:hover { opacity: 1; color: var(--tg-accent); padding-left: .375rem; }
.footer--light .footer__menu a { color: var(--tg-text-muted); }
.footer--light .footer__menu a:hover { color: var(--tg-accent-dark, var(--tg-primary)); }

.footer__contact { display: flex; flex-direction: column; gap: .875rem; }
.footer__contact li { display: flex; align-items: flex-start; gap: .625rem; font-size: .9375rem; }
.footer__contact svg { flex-shrink: 0; opacity: .6; margin-top: 2px; }
.footer__contact a { opacity: .75; transition: opacity var(--tg-transition), color var(--tg-transition); }
.footer__contact a:hover { opacity: 1; color: var(--tg-accent); }

/* Bottom Bar */
.footer__bottom {
    border-top: 1px solid rgba(255,255,255,.1);
    padding-block: 1.5rem;
}
.footer--light .footer__bottom { border-top-color: var(--tg-border); }
.footer__bottom-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.footer__copyright { font-size: .875rem; opacity: .65; }
.footer__copyright a { opacity: 1; color: var(--tg-accent); font-weight: 600; }
.footer__copyright a:hover { text-decoration: underline; }
.footer__legal-nav { display: flex; gap: 1.25rem; }
.footer__legal-nav a { font-size: .875rem; opacity: .65; transition: opacity var(--tg-transition); }
.footer__legal-nav a:hover { opacity: 1; }

/* ─── Social ────────────────────────────────────────────────────── */
.tg-social { display: flex; gap: .625rem; flex-wrap: wrap; }
.tg-social li { list-style: none; }
.tg-social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px; height: 38px;
    border-radius: 50%;
    background: rgba(255,255,255,.1);
    color: rgba(255,255,255,.7);
    transition: background var(--tg-transition), color var(--tg-transition), transform var(--tg-transition);
}
.tg-social a:hover { background: var(--tg-accent); color: var(--tg-primary); transform: translateY(-2px); }
.footer--light .tg-social a { background: var(--tg-border); color: var(--tg-text-muted); }
.footer--light .tg-social a:hover { background: var(--tg-accent); color: var(--tg-primary); }

/* ─── ═══════════════════════════════════════════════════════════════
   BLOG — Archive + Cards
   ═══════════════════════════════════════════════════════════════ */
.blog-archive { padding-top: 0; }
.archive-hero,
.tg-archive-hero {
    position: relative;
    width: 100%;
    box-sizing: border-box;
    background: linear-gradient(135deg, var(--tg-primary) 0%, color-mix(in srgb, var(--tg-primary) 80%, var(--tg-accent)) 100%);
    padding-top: calc(72px + 3.5rem);
    padding-bottom: 3.5rem;
    margin-bottom: 0;
}
.tg-archive-hero--bg-primary { background: linear-gradient(135deg, var(--tg-primary) 0%, color-mix(in srgb, var(--tg-primary) 80%, var(--tg-accent)) 100%); }
.tg-archive-hero--bg-dark    { background: var(--tg-dark); }
.tg-archive-hero--bg-accent  { background: var(--tg-accent); }
.tg-archive-hero--has-image  { background-size: cover; background-position: center; }
.tg-archive-hero__overlay    { position: absolute; inset: 0; background: #000; pointer-events: none; z-index: 0; }
.tg-archive-hero__content    { position: relative; z-index: 1; max-width: 700px; }
.tg-archive-hero__title      { color: #fff; font-size: clamp(1.75rem, 4vw, 2.75rem); font-weight: 800; margin: .5rem 0 0; }
.tg-archive-hero__subtitle   { color: rgba(255,255,255,.85); font-size: 1.05rem; margin-top: .75rem; }
.archive-hero__inner         { max-width: 700px; }
.archive-hero__title         { color: #fff; font-size: clamp(1.75rem, 4vw, 2.75rem); margin-bottom: .75rem; }
.archive-hero__description   { color: rgba(255,255,255,.75); font-size: 1.05rem; line-height: 1.65; }

.content-grid {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 3rem;
    padding-block: 4rem;
    align-items: start;
}
.content-main { min-width: 0; }
.content-sidebar { position: sticky; top: 100px; }

.posts-grid { display: grid; gap: 2rem; }
.posts-grid--2 { grid-template-columns: repeat(2, 1fr); }
.posts-grid--3 { grid-template-columns: repeat(3, 1fr); }

.post-card {
    background: var(--tg-bg);
    border-radius: var(--tg-radius-lg);
    overflow: hidden;
    box-shadow: var(--tg-shadow-md);
    transition: transform var(--tg-transition), box-shadow var(--tg-transition);
    border: 1px solid var(--tg-border);
}
.post-card:hover { transform: translateY(-4px); box-shadow: var(--tg-shadow-xl); }
.post-card__thumb { display: block; position: relative; overflow: hidden; aspect-ratio: 16/9; }
.post-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--tg-transition-slow); }
.post-card:hover .post-card__thumb img { transform: scale(1.05); }
.post-card__cat {
    position: absolute;
    bottom: .75rem; left: .75rem;
    background: var(--tg-accent);
    color: var(--tg-primary);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .04em;
    padding: .25rem .75rem;
    border-radius: var(--tg-radius-full);
    text-transform: uppercase;
}
.post-card__body { padding: 1.5rem; }
.post-card__title { font-size: 1.1rem; font-weight: 700; margin-block: .75rem; line-height: 1.35; }
.post-card__title a { color: var(--tg-text); transition: color var(--tg-transition); }
.post-card__title a:hover { color: var(--tg-primary); }
.post-card__excerpt { font-size: .9rem; color: var(--tg-text-muted); line-height: 1.65; margin-bottom: 1.25rem; }
.post-card__link { display: inline-flex; align-items: center; gap: .375rem; font-size: .875rem; font-weight: 700; color: var(--tg-primary); transition: gap var(--tg-transition); }
.post-card__link:hover { gap: .625rem; color: var(--tg-accent-dark, var(--tg-primary)); }

/* Post Meta */
.post-meta { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; font-size: .8125rem; color: var(--tg-text-light); }
.post-meta__cats a { color: var(--tg-accent); font-weight: 600; }
.post-meta__cats a:hover { text-decoration: underline; }

/* Blog Single */
.blog-single { background: var(--tg-bg); }
.post-hero {
    position: relative;
    padding-block: 5rem 3rem;
    background: var(--tg-primary);
    margin-bottom: 0;
}
.post-hero--has-image { min-height: 50vh; display: flex; align-items: flex-end; }
.post-hero__bg { position: absolute; inset: 0; }
.post-hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.post-hero__overlay { position: absolute; inset: 0; background: rgba(var(--tg-primary-rgb),.75); }
.post-hero__inner { position: relative; z-index: 1; max-width: 800px; }
.post-hero__title { color: #fff; font-size: clamp(1.75rem, 4vw, 3rem); margin-block: 1rem; }
.post-hero__title + * { margin-top: 0; }
.post-hero .post-meta { color: rgba(255,255,255,.65); }
.post-hero .post-meta__cats a { color: var(--tg-accent); }

.blog-post { padding-block: 3rem 2rem; }
.page-featured-image { margin-bottom: 2.5rem; }
.page-featured-image__img { border-radius: var(--tg-radius-lg); width: 100%; aspect-ratio: 16/6; object-fit: cover; }

/* Post Navigation */
.post-navigation { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--tg-border); }
.post-navigation .nav-links { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.post-navigation a { display: flex; flex-direction: column; gap: .25rem; padding: 1.25rem; background: var(--tg-bg-alt); border-radius: var(--tg-radius-md); transition: background var(--tg-transition); }
.post-navigation a:hover { background: var(--tg-accent-light); }
.nav-subtitle { font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--tg-text-light); }
.nav-title { font-size: .9375rem; font-weight: 600; color: var(--tg-text); line-height: 1.4; }
.nav-next { text-align: right; }

/* Author Box */
.author-box { display: flex; gap: 1.25rem; align-items: flex-start; padding: 2rem; background: var(--tg-bg-alt); border-radius: var(--tg-radius-lg); margin-top: 3rem; }
.author-box__avatar img { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.author-box__name { font-size: 1rem; font-weight: 700; margin-bottom: .375rem; }
.author-box__bio { font-size: .9rem; color: var(--tg-text-muted); line-height: 1.65; }

/* Related Posts */
.related-posts { padding-block: 4rem; background: var(--tg-bg-alt); }
.related-posts__title { font-size: 1.5rem; font-weight: 700; margin-bottom: 2rem; }

/* Sidebar Widgets */
.sidebar .widget { margin-bottom: 2rem; }
.widget__title { font-size: 1rem; font-weight: 700; margin-bottom: 1rem; padding-bottom: .625rem; border-bottom: 2px solid var(--tg-accent); }
.widget ul li { padding: .375rem 0; border-bottom: 1px solid var(--tg-border-light); font-size: .9375rem; }
.widget ul li a:hover { color: var(--tg-accent); }

/* Pagination */
.pagination { margin-top: 3rem; }
.pagination .page-numbers { display: flex; gap: .5rem; flex-wrap: wrap; list-style: none; }
.pagination .page-numbers li a,
.pagination .page-numbers li span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 40px; height: 40px;
    padding: 0 .75rem;
    border-radius: var(--tg-radius-sm);
    background: var(--tg-bg-alt);
    border: 1px solid var(--tg-border);
    font-size: .875rem;
    font-weight: 600;
    color: var(--tg-text);
    transition: all var(--tg-transition);
}
.pagination .page-numbers li a:hover { background: var(--tg-primary); color: #fff; border-color: var(--tg-primary); }
.pagination .page-numbers li span.current { background: var(--tg-primary); color: #fff; border-color: var(--tg-primary); }

/* Breadcrumb */
.breadcrumb { display: flex; align-items: center; gap: .5rem; font-size: .85rem; margin-bottom: 1rem; color: var(--tg-text-muted); flex-wrap: wrap; }
.breadcrumb a { color: var(--tg-text-muted); transition: color var(--tg-transition); }
.breadcrumb a:hover { color: var(--tg-accent); }
.breadcrumb--light a, .breadcrumb--light span { color: rgba(255,255,255,.7); }
.breadcrumb--light a:hover { color: var(--tg-accent); }

/* ─── ═══════════════════════════════════════════════════════════════
   INNER PAGES
   ═══════════════════════════════════════════════════════════════ */
.page-hero {
    background: var(--tg-primary);
    padding-block: 4rem;
    margin-bottom: 0;
}
.page-hero__inner { max-width: 700px; }
.page-hero__title { color: #fff; font-size: clamp(1.75rem, 4vw, 2.75rem); }
.page-content-grid { display: grid; grid-template-columns: 1fr; padding-block: 4rem; max-width: 860px; }

/* ─── ═══════════════════════════════════════════════════════════════
   404
   ═══════════════════════════════════════════════════════════════ */
.error-404 { padding-block: 0; }
.error-404__section { padding-block: 8rem 6rem; background: var(--tg-bg-alt); min-height: 80vh; display: flex; align-items: center; }
.error-404__inner { text-align: center; max-width: 600px; margin-inline: auto; }
.error-404__number { font-size: clamp(6rem, 15vw, 10rem); font-weight: 900; color: var(--tg-accent); line-height: 1; letter-spacing: -.05em; opacity: .8; }
.error-404__title { font-size: clamp(1.5rem, 3vw, 2rem); margin-bottom: 1rem; }
.error-404__text { color: var(--tg-text-muted); margin-bottom: 2rem; font-size: 1.05rem; }
.error-404__actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin-bottom: 2.5rem; }
.error-404__search { max-width: 400px; margin-inline: auto; }
.error-404__search p { color: var(--tg-text-muted); font-size: .9rem; margin-bottom: .75rem; }
.search-form { display: flex; gap: .5rem; }
.search-form input[type=search] { flex: 1; padding: .75rem 1rem; border: 1.5px solid var(--tg-border); border-radius: var(--tg-radius-md); font-size: .9375rem; background: var(--tg-bg); }
.search-form input[type=search]:focus { outline: none; border-color: var(--tg-accent); }
.search-form button { padding: .75rem 1.25rem; background: var(--tg-accent); color: var(--tg-primary); border: none; border-radius: var(--tg-radius-md); font-weight: 700; transition: background var(--tg-transition); cursor: pointer; }
.search-form button:hover { background: var(--tg-accent-dark, var(--tg-primary)); color: #fff; }

/* No Results */
.no-results { text-align: center; padding: 5rem 1rem; }
.no-results__icon { font-size: 4rem; margin-bottom: 1rem; opacity: .5; }
.no-results__title { font-size: 1.5rem; margin-bottom: .75rem; }
.no-results__text { color: var(--tg-text-muted); margin-bottom: 2rem; font-size: 1.05rem; }

/* ─── Comments ──────────────────────────────────────────────────── */
.comment-list { margin-top: 2rem; }
.comment-respond { margin-top: 3rem; padding: 2rem; background: var(--tg-bg-alt); border-radius: var(--tg-radius-lg); }
.comment-reply-title { font-size: 1.25rem; font-weight: 700; margin-bottom: 1.5rem; }
.comment-form label { display: block; font-size: .875rem; font-weight: 600; margin-bottom: .375rem; }
.comment-form input[type=text],
.comment-form input[type=email],
.comment-form input[type=url],
.comment-form textarea { width: 100%; padding: .75rem 1rem; border: 1.5px solid var(--tg-border); border-radius: var(--tg-radius-md); margin-bottom: 1rem; background: var(--tg-bg); }
.comment-form input:focus, .comment-form textarea:focus { outline: none; border-color: var(--tg-accent); }
.comment-form .submit { background: var(--tg-accent); color: var(--tg-primary); border: none; padding: .75rem 2rem; border-radius: var(--tg-radius-full); font-weight: 700; cursor: pointer; transition: background var(--tg-transition); }
.comment-form .submit:hover { background: var(--tg-accent-dark); }

/* ─── ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .site-header__nav { display: none; }
    .nav-toggle { display: flex; }
    .tg-hero--split .tg-hero__inner { grid-template-columns: 1fr; gap: 3rem; }
    .tg-hero__visual { display: none; }
    .tg-hero--split .tg-hero__text { align-items: center; }
    .tg-hero--split { text-align: center; }
    .tg-about__grid { grid-template-columns: 1fr; gap: 3rem; }
    .tg-about__visual { display: none; }
    .tg-services__grid { grid-template-columns: repeat(2, 1fr); }
    .tg-testimonials__grid { grid-template-columns: repeat(2, 1fr); }
    .tg-team__grid--3, .tg-team__grid--4 { grid-template-columns: repeat(2, 1fr); }
    .tg-pricing__grid { grid-template-columns: 1fr; max-width: 480px; margin-inline: auto; }
    .tg-pricing-card--featured { transform: scale(1); }
    .footer__grid { grid-template-columns: 1fr 1fr; }
    .content-grid { grid-template-columns: 1fr; }
    .content-sidebar { position: static; }
    .tg-contact__grid { grid-template-columns: 1fr; gap: 3rem; }
    .tg-stats__grid { grid-template-columns: repeat(2, 1fr); }
    .tg-stats__item:nth-child(2)::after { display: none; }
}

@media (max-width: 768px) {
    :root { --tg-section-py: 4rem; }
    .tg-services__grid { grid-template-columns: 1fr; }
    .tg-portfolio__grid { justify-content: flex-start; }
    .tg-portfolio-card { flex: 1 1 100%; max-width: 100%; }
    .tg-testimonials__grid { grid-template-columns: 1fr; }
    .tg-team__grid--3, .tg-team__grid--4 { grid-template-columns: 1fr; }
    .tg-hero__actions { flex-direction: column; align-items: center; }
    .tg-cta__actions { flex-direction: column; align-items: center; }
    .tg-about__features { grid-template-columns: 1fr; }
    .footer__grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .posts-grid--2, .posts-grid--3 { grid-template-columns: 1fr; }
    .tg-form-row--2 { flex-direction: column; }
    .footer__bottom-inner { flex-direction: column; text-align: center; }
    .tg-contact__form-wrap { padding: 1.5rem; }
    .site-header__phone { display: none; }
}

@media (max-width: 480px) {
    :root { --tg-container-pad: 1rem; }
    .site-header__cta { display: none; }
    .tg-stats__grid { grid-template-columns: 1fr 1fr; }
}

/* ─── Print ──────────────────────────────────────────────────────── */
@media print {
    .site-header, .mobile-menu, .tg-hero__scroll { display: none; }
    body { color: #000; }
}

/* ═══════════════════════════════════════════════════════════════════
   V2.0 — NEW STYLES
   Notification bar, bg types, section layouts, custom block,
   page templates, v2 section variants, filter, palettes, etc.
   ═══════════════════════════════════════════════════════════════════ */

/* ─── Notification Bar ──────────────────────────────────────────── */
.tg-notif-bar {
    padding: .65rem 1rem;
    font-size: .875rem;
    font-weight: 500;
    overflow: hidden;
}
.tg-notif-bar--accent   { background: var(--tg-accent); color: var(--tg-primary); }
.tg-notif-bar--primary  { background: var(--tg-primary); color: #fff; }
.tg-notif-bar--dark     { background: #111; color: #fff; }
.tg-notif-bar--warning  { background: #f59e0b; color: #111; }
.tg-notif-bar__inner    { display: flex; align-items: center; justify-content: center; gap: 1rem; }
.tg-notif-bar__text     { margin: 0; display: flex; align-items: center; flex-wrap: wrap; gap: .4rem; justify-content: center; }
.tg-notif-bar__link     { font-weight: 600; text-decoration: underline; display: inline-flex; align-items: center; gap: .25rem; }
.tg-notif-bar__close    { background: none; border: none; cursor: pointer; color: inherit; padding: .25rem; margin-left: auto; display: flex; align-items: center; opacity: .7; transition: opacity .2s; flex-shrink: 0; }
.tg-notif-bar__close:hover { opacity: 1; }

/* ─── Section Background Types ──────────────────────────────────── */
.tg-section { position: relative; }
.tg-section--bg-white   { background: #fff; }
.tg-section--bg-light   { background: var(--tg-bg-alt); }
.tg-section--bg-primary { background: var(--tg-primary); color: #fff; }
.tg-section--bg-accent  { background: var(--tg-accent); color: var(--tg-primary); }
.tg-section--bg-dark    { background: #111; color: #fff; }
.tg-section--bg-image   { background-size: cover; background-position: center; }

.tg-section--padding-none    { padding-block: 0; }
.tg-section--padding-compact { padding-block: calc(var(--tg-section-py) * .5); }
.tg-section--padding-normal  { padding-block: var(--tg-section-py); }
.tg-section--padding-large   { padding-block: calc(var(--tg-section-py) * 1.5); }

.tg-section--wide .tg-container { max-width: 1400px; }
.tg-section--full .tg-container { max-width: 100%; padding-inline: 2rem; }
.tg-section--contained .tg-container { /* default */ }

.tg-section__overlay {
    position: absolute;
    inset: 0;
    background: #000;
    pointer-events: none;
    z-index: 0;
}
.tg-section > .tg-container { position: relative; z-index: 1; }

/* Dark-bg heading/text overrides */
.tg-section--bg-primary .tg-section-header__title,
.tg-section--bg-primary .tg-section-header__subtitle,
.tg-section--bg-dark .tg-section-header__title,
.tg-section--bg-dark .tg-section-header__subtitle { color: #fff; }
.tg-section--bg-primary .tg-badge,
.tg-section--bg-dark .tg-badge { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.2); }

/* ─── Hero v2.0 ──────────────────────────────────────────────────── */
.tg-hero--centered .tg-hero__inner { justify-content: center; text-align: center; }
.tg-hero--centered .tg-hero__actions { justify-content: center; }
.tg-hero--fullscreen { min-height: 100svh; }
.tg-hero--minimal { min-height: 60vh; }
.tg-hero--minimal .tg-hero__bg { display: none; }
.tg-hero--minimal { background: var(--tg-primary); }

.tg-hero__highlight { color: var(--tg-accent); }

.tg-hero__video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tg-hero__mini-stats {
    display: flex;
    gap: 2rem;
    margin-top: 2rem;
    flex-wrap: wrap;
}
.tg-hero--centered .tg-hero__mini-stats { justify-content: center; }
.tg-hero__mini-stat { text-align: left; }
.tg-hero__mini-stat strong { display: block; font-size: 1.5rem; font-weight: 800; color: var(--tg-accent); }
.tg-hero__mini-stat span { font-size: .8rem; opacity: .8; text-transform: uppercase; letter-spacing: .05em; }

/* ─── Stats v2.0 ─────────────────────────────────────────────────── */
.tg-stats__grid--2 { grid-template-columns: repeat(2, 1fr); }
.tg-stats__grid--3 { grid-template-columns: repeat(3, 1fr); }
.tg-stats__grid--4 { grid-template-columns: repeat(4, 1fr); }
.tg-stats__icon { margin-bottom: .75rem; font-size: 2rem; }
.tg-stats__icon img { width: 2.5rem; height: 2.5rem; object-fit: contain; }

/* ─── About v2.0 ─────────────────────────────────────────────────── */
.tg-about--image-right .tg-about__grid { direction: rtl; }
.tg-about--image-right .tg-about__grid > * { direction: ltr; }
.tg-about--no-image .tg-about__grid { grid-template-columns: 1fr; max-width: 760px; margin-inline: auto; }
.tg-about--image-top .tg-about__visual-top { margin-bottom: 3rem; border-radius: var(--tg-radius-lg); overflow: hidden; }
.tg-about--image-top .tg-about__visual-top img { width: 100%; height: 400px; object-fit: cover; }
.tg-about--image-top .tg-about__text-center { max-width: 760px; margin-inline: auto; text-align: center; }
.tg-about__img--circle { border-radius: 50%; }
.tg-about__img--square { border-radius: 4px; }
.tg-about__img--rounded { border-radius: var(--tg-radius-lg); }
.tg-about__text--2 { margin-top: 1rem; }
.tg-about__feature-icon img { width: 1.5rem; height: 1.5rem; object-fit: contain; }

/* ─── Services v2.0 ──────────────────────────────────────────────── */
.tg-services__grid--grid-2 { grid-template-columns: repeat(2, 1fr); }
.tg-services__grid--grid-4 { grid-template-columns: repeat(4, 1fr); }

.tg-service-card__icon-inner { display: flex; align-items: center; justify-content: center; }
.tg-service-card__icon-inner img { width: 2.5rem; height: 2.5rem; object-fit: contain; }
.tg-service-card__icon-inner--emoji { font-size: 2rem; }

/* Card styles */
.tg-service-card--bordered { border: 2px solid var(--tg-border); }
.tg-service-card--shadow   { box-shadow: 0 8px 32px rgba(0,0,0,.08); border: none; }
.tg-service-card--minimal  { background: transparent; border: none; padding: 1.5rem 0; }
.tg-service-card--is-featured { grid-column: span 2; background: var(--tg-primary); color: #fff; }
.tg-service-card--is-featured .tg-service-card__link { color: var(--tg-accent); }

/* Services List Layout */
.tg-services__list { display: flex; flex-direction: column; gap: 2rem; }
.tg-service-item { display: grid; grid-template-columns: auto 1fr; gap: 2rem; align-items: start; background: var(--tg-bg-alt); border-radius: var(--tg-radius-md); padding: 2rem; }
.tg-service-item__media { width: 200px; border-radius: var(--tg-radius-sm); overflow: hidden; }
.tg-service-item__media img { width: 100%; height: 150px; object-fit: cover; }
.tg-service-item__body { display: flex; align-items: flex-start; gap: 1.5rem; }
.tg-service-item__icon { font-size: 2rem; flex-shrink: 0; }
.tg-service-item__icon img { width: 3rem; height: 3rem; object-fit: contain; }
.tg-service-item__title { font-size: 1.25rem; font-weight: 700; margin-bottom: .5rem; color: var(--tg-heading); }
.tg-service-item__desc { color: var(--tg-text-muted); margin-bottom: 1rem; }
.tg-service-item__link { color: var(--tg-accent); font-weight: 600; display: inline-flex; align-items: center; gap: .3rem; text-decoration: none; }
.tg-service-item__link:hover { gap: .6rem; }

.tg-services__featured-wrap { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--tg-grid-gap); }
.tg-services__footer { text-align: center; margin-top: 3rem; }

/* ─── Portfolio v2.0 ─────────────────────────────────────────────── */
.tg-portfolio__grid--grid-2 { grid-template-columns: repeat(2, 1fr); }
.tg-portfolio__grid--grid-4 { grid-template-columns: repeat(4, 1fr); }

.tg-portfolio__filter {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    justify-content: center;
    margin-bottom: 2.5rem;
}
.tg-portfolio__filter-btn {
    background: none;
    border: 1.5px solid var(--tg-border);
    border-radius: var(--tg-radius-full);
    padding: .4rem 1.25rem;
    font-size: .875rem;
    font-weight: 500;
    cursor: pointer;
    transition: background var(--tg-transition), color var(--tg-transition), border-color var(--tg-transition);
    color: var(--tg-text);
}
.tg-portfolio__filter-btn:hover,
.tg-portfolio__filter-btn.is-active {
    background: var(--tg-accent);
    border-color: var(--tg-accent);
    color: var(--tg-primary);
}

/* ─── Pricing v2.0 ───────────────────────────────────────────────── */
.tg-pricing__grid--2-cols { grid-template-columns: repeat(2, 1fr); }
.tg-pricing__grid--4-cols { grid-template-columns: repeat(4, 1fr); }
.tg-pricing__grid--5-cols { grid-template-columns: repeat(5, 1fr); gap: 1rem; }
.tg-pricing__grid--5-cols .tg-pricing-card { padding: 1.5rem; }

.tg-pricing-card__icon { margin-bottom: 1rem; font-size: 2rem; display: flex; justify-content: center; }
.tg-pricing-card__icon img { width: 3rem; height: 3rem; object-fit: contain; }
.tg-pricing-card__desc { font-size: .875rem; color: var(--tg-text-muted); margin-bottom: .75rem; }
.tg-pricing-card__feature--excluded { opacity: .45; text-decoration: line-through; }
.tg-pricing-card__feature--excluded .tg-pricing-card__check { color: #ef4444; }
.tg-pricing-card__note {
    font-size: .8rem;
    color: var(--tg-text-muted);
    text-align: center;
    padding: .75rem 1rem 0;
    border-top: 1px solid var(--tg-border);
    margin-top: 1rem;
}
.tg-pricing__note {
    text-align: center;
    color: var(--tg-text-muted);
    font-size: .875rem;
    margin-top: 2rem;
}

/* ─── FAQ v2.0 ───────────────────────────────────────────────────── */
.tg-faq--two-col .tg-faq__two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    align-items: start;
}
.tg-faq--with-image .tg-faq__split {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 4rem;
    align-items: start;
}
.tg-faq__img { width: 100%; border-radius: var(--tg-radius-lg); object-fit: cover; max-height: 500px; }
.tg-faq__image-col { position: sticky; top: 5rem; }
.tg-faq__accordion-col .tg-faq__accordion { margin-top: 0; }

/* ─── CTA v2.0 ───────────────────────────────────────────────────── */
.tg-cta--split .tg-cta__split {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 3rem;
    flex-wrap: wrap;
}
.tg-cta--split .tg-cta__split-text { flex: 1; min-width: 280px; }
.tg-cta--split .tg-cta__actions { flex-shrink: 0; }
.tg-cta--split .tg-cta__title { font-size: clamp(1.5rem, 2.5vw, 2rem); margin-bottom: .5rem; }

/* ─── Contact v2.0 ───────────────────────────────────────────────── */
.tg-contact__form-only { max-width: 680px; margin-inline: auto; }
.tg-contact__info-only { max-width: 680px; margin-inline: auto; }
.tg-contact__grid--info-map { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; }
.tg-contact__map-wrap iframe { width: 100%; height: 450px; border-radius: var(--tg-radius-md); }

/* ─── Custom Blocks ──────────────────────────────────────────────── */
.tg-custom-block { position: relative; }

/* Text only */
.tg-custom-block__text-only { max-width: 760px; margin-inline: auto; }

/* Two columns */
.tg-custom-block__two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
}

/* Split (text + image) */
.tg-custom-block__split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}
.tg-custom-block__split--img-right .tg-custom-block__image-col { order: 1; }
.tg-custom-block__split--img-right .tg-custom-block__text-col  { order: 0; }
.tg-custom-block__img { width: 100%; border-radius: var(--tg-radius-lg); object-fit: cover; }
.tg-custom-block__text-col { display: flex; flex-direction: column; gap: 1.5rem; }

/* Card grid */
.tg-custom-block__cards {
    display: grid;
    gap: var(--tg-grid-gap);
    margin-top: 3rem;
}
.tg-custom-block__cards--1 { grid-template-columns: 1fr; max-width: 560px; margin-inline: auto; }
.tg-custom-block__cards--2 { grid-template-columns: repeat(2, 1fr); }
.tg-custom-block__cards--3 { grid-template-columns: repeat(3, 1fr); }
.tg-custom-block__cards--4 { grid-template-columns: repeat(4, 1fr); }

.tg-custom-block__card {
    background: var(--tg-bg-alt);
    border-radius: var(--tg-radius-md);
    padding: 1.75rem;
    display: flex;
    flex-direction: column;
    gap: .75rem;
    transition: box-shadow var(--tg-transition);
}
.tg-custom-block__card:hover { box-shadow: 0 8px 32px rgba(0,0,0,.08); }
.tg-custom-block__card-icon { font-size: 2rem; }
.tg-custom-block__card-icon img { width: 2.5rem; height: 2.5rem; object-fit: contain; }
.tg-custom-block__card-title { font-size: 1.1rem; font-weight: 700; color: var(--tg-heading); margin: 0; }
.tg-custom-block__card-content { color: var(--tg-text-muted); font-size: .925rem; margin: 0; }
.tg-custom-block__intro { max-width: 760px; margin-inline: auto; text-align: center; margin-bottom: 1rem; }
.tg-custom-block__cta { text-align: center; margin-top: 2.5rem; }

/* Feature list (inside split blocks) */
.tg-custom-block__feature-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .75rem; }
.tg-custom-block__feature-list li { display: flex; gap: .75rem; align-items: flex-start; font-size: .95rem; }
.tg-custom-block__feature-list li > span:first-child { color: var(--tg-accent); flex-shrink: 0; margin-top: .1em; }

/* ─── Page Hero (inner pages) ────────────────────────────────────── */
.tg-page-hero {
    position: relative;
    width: 100%;
    min-height: 320px;
    display: flex;
    align-items: center;
    background: var(--tg-primary);
    background-size: cover;
    background-position: center;
    padding-top: calc(72px + 4rem);
    padding-bottom: 4rem;
    overflow: hidden;
    box-sizing: border-box;
}
.tg-page-hero--compact {
    min-height: 240px;
    padding-top: calc(72px + 2.5rem);
    padding-bottom: 2.5rem;
}
.tg-page-hero__overlay {
    position: absolute;
    inset: 0;
    background: var(--tg-primary);
    opacity: .8;
}
.tg-page-hero__content { position: relative; z-index: 1; color: #fff; }
.tg-page-hero__title {
    font-size: clamp(2rem, 4.5vw, 3.25rem);
    font-weight: 800;
    margin-bottom: .5rem;
    line-height: 1.1;
    letter-spacing: -.02em;
}
.tg-page-hero__subtitle {
    font-size: 1.0625rem;
    opacity: .85;
    max-width: 560px;
    margin-top: .75rem;
    line-height: 1.65;
}

/* Breadcrumb */
.tg-breadcrumb { display: flex; gap: .5rem; align-items: center; margin-bottom: 1rem; font-size: .875rem; opacity: .75; }
.tg-breadcrumb a { color: inherit; text-decoration: none; }
.tg-breadcrumb a:hover { opacity: 1; text-decoration: underline; }
.tg-breadcrumb--light,
.tg-breadcrumb--light a { color: rgba(255,255,255,.75); }
.tg-breadcrumb--light a:hover { color: var(--tg-accent); opacity: 1; text-decoration: none; }

/* Values grid (About page template) */
.tg-values__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 2rem;
    margin-top: 2.5rem;
}
.tg-values__item { text-align: center; display: flex; flex-direction: column; align-items: center; gap: .75rem; }
.tg-values__icon { font-size: 2.5rem; color: var(--tg-accent); }
.tg-values__icon img { width: 3rem; height: 3rem; object-fit: contain; }
.tg-values__text { font-weight: 600; font-size: .95rem; color: var(--tg-heading); margin: 0; }

/* ─── Landing page ───────────────────────────────────────────────── */
.tg-landing .tg-landing__header {
    background: var(--tg-primary);
    padding: 1rem 0;
    position: sticky;
    top: 0;
    z-index: 100;
}
.tg-landing__header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.tg-landing__site-name {
    font-size: 1.25rem;
    font-weight: 800;
    color: #fff;
    text-decoration: none;
}
.tg-landing__footer {
    background: var(--tg-primary);
    color: #fff;
    padding: 1.5rem 0;
}
.tg-landing__footer-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
}
.tg-landing .footer__copyright { margin: 0; font-size: .875rem; opacity: .75; color: #fff; }
.tg-landing .footer__legal-nav a { color: #fff; opacity: .75; font-size: .875rem; }

/* ─── Contact page template ──────────────────────────────────────── */
.tg-contact-map-full { margin-top: 0; }
.tg-contact-map-full iframe { display: block; }

/* Container narrow */
.tg-container--narrow { max-width: 760px; }

/* Page hero height variants */
.tg-page-hero--large      { min-height: 480px; }
.tg-page-hero--fullscreen { min-height: 100svh; }

/* Page intro paragraph */
.tg-page-intro {
    font-size: 1.15rem;
    line-height: 1.7;
    color: var(--tg-text-muted);
    text-align: center;
    max-width: 680px;
    margin-inline: auto;
}

/* ─── Footer v2.0 ────────────────────────────────────────────────── */
.footer--minimal .footer__bottom { padding-block: 2rem; }
.footer__grid--3-col { grid-template-columns: 2fr 1fr 1fr; }
.footer__grid--minimal { display: none; }
.footer--minimal .footer__bottom-inner { flex-direction: column; text-align: center; gap: 1rem; }
.footer__minimal-social { justify-content: center; }

/* ─── Color Palette CSS classes ──────────────────────────────────── */
/* Applied dynamically via tg_apply_color_palette() in wp_head */
/* All palette rules are inline :root{} overrides — see inc/helpers.php */

/* ─── Testimonials v2.0 ──────────────────────────────────────────── */
.tg-testimonials__grid--grid-2 { grid-template-columns: repeat(2, 1fr); }

/* ─── Team v2.0 ──────────────────────────────────────────────────── */
.tg-team-card--horizontal {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
    padding: 1.5rem;
    background: var(--tg-bg-alt);
    border-radius: var(--tg-radius-md);
}
.tg-team-card--horizontal .tg-team-card__photo { width: 120px; height: 120px; border-radius: var(--tg-radius-sm); overflow: hidden; flex-shrink: 0; }
.tg-team-card--horizontal .tg-team-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.tg-team-card--minimal .tg-team-card__photo { border-radius: 50%; }
.tg-team-card--minimal .tg-team-card__bio { display: none; }

/* ─── Responsive v2.0 additions ─────────────────────────────────── */
@media (max-width: 1024px) {
    .tg-services__grid--grid-4 { grid-template-columns: repeat(2, 1fr); }
    .tg-pricing__grid--4-cols  { grid-template-columns: repeat(2, 1fr); }
    .tg-pricing__grid--5-cols  { grid-template-columns: repeat(3, 1fr); }
    .tg-custom-block__cards--4 { grid-template-columns: repeat(2, 1fr); }
    .tg-faq--with-image .tg-faq__split { grid-template-columns: 1fr; }
    .tg-faq__image-col { position: static; }
    .tg-services__featured-wrap { grid-template-columns: repeat(2, 1fr); }
    .tg-service-card--is-featured { grid-column: span 1; }
    .tg-custom-block__split { gap: 2.5rem; }
    .tg-contact__grid--info-map { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .tg-services__grid--grid-2 { grid-template-columns: 1fr; }
    .tg-services__grid--grid-4 { grid-template-columns: 1fr; }
    .tg-services__featured-wrap { grid-template-columns: 1fr; }
    .tg-services__list .tg-service-item { grid-template-columns: 1fr; }
    .tg-service-item__media { width: 100%; }
    .tg-service-item__media img { height: 200px; }
    .tg-pricing__grid--2-cols,
    .tg-pricing__grid--4-cols,
    .tg-pricing__grid--5-cols  { grid-template-columns: 1fr; }
    .tg-custom-block__two-col  { grid-template-columns: 1fr; }
    .tg-custom-block__split    { grid-template-columns: 1fr; }
    .tg-custom-block__cards--3,
    .tg-custom-block__cards--4 { grid-template-columns: 1fr 1fr; }
    .tg-faq--two-col .tg-faq__two-col { grid-template-columns: 1fr; }
    .tg-cta--split .tg-cta__split { flex-direction: column; text-align: center; }
    .tg-cta--split .tg-cta__actions { width: 100%; justify-content: center; }
    .tg-stats__grid--3,
    .tg-stats__grid--4 { grid-template-columns: repeat(2, 1fr); }
    .tg-testimonials__grid--grid-2 { grid-template-columns: 1fr; }
    .tg-team-card--horizontal { flex-direction: column; }
    .tg-team-card--horizontal .tg-team-card__photo { width: 100%; height: auto; }
    .tg-hero__mini-stats { gap: 1.25rem; }
}

@media (max-width: 480px) {
    .tg-custom-block__cards--2,
    .tg-custom-block__cards--3,
    .tg-custom-block__cards--4 { grid-template-columns: 1fr; }
    .tg-stats__grid--2,
    .tg-stats__grid--3,
    .tg-stats__grid--4 { grid-template-columns: 1fr 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════
   INNER PAGES v3 — Styles for About, Services, Contact templates
   ═══════════════════════════════════════════════════════════════════ */

/* ─── Page Hero background variants ─────────────────────────────── */
.tg-page-hero--bg-primary  { background: var(--tg-primary); }
.tg-page-hero--bg-dark     { background: var(--tg-dark, #0d1a22); }
.tg-page-hero--bg-accent   { background: var(--tg-accent); }
.tg-page-hero--bg-dark .tg-page-hero__title  { color: #fff; }
.tg-page-hero--bg-accent .tg-page-hero__title { color: var(--tg-primary); }
.tg-page-hero--bg-accent .tg-page-hero__subtitle { color: rgba(var(--tg-primary-rgb), .8); }

/* decorative subtle pattern on page hero */
.tg-page-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle, rgba(var(--tg-accent-rgb),.07) 1px, transparent 1px);
    background-size: 28px 28px;
    pointer-events: none;
    z-index: 0;
}
.tg-page-hero .tg-container { position: relative; z-index: 1; }

/* ─── About Content (inner page) ─────────────────────────────────── */
.tg-about__image-wrap {
    position: relative;
    border-radius: var(--tg-radius-xl);
    overflow: hidden;
}
.tg-about__image {
    width: 100%;
    display: block;
    border-radius: var(--tg-radius-xl);
    box-shadow: var(--tg-shadow-xl);
    aspect-ratio: 4/3;
    object-fit: cover;
}
.tg-about__body {
    font-size: 1.0625rem;
    line-height: 1.8;
    color: var(--tg-text-muted);
    max-width: 66ch;
}

/* About grid layout modifiers (inner page) */
.tg-about__grid--image-right {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}
.tg-about__grid--image-right .tg-about__text  { order: 0; }
.tg-about__grid--image-right .tg-about__image-wrap { order: 1; }

.tg-about__grid--image-left {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}
.tg-about__grid--image-left .tg-about__text  { order: 1; }
.tg-about__grid--image-left .tg-about__image-wrap { order: 0; }

.tg-about__grid.tg-about__grid--no-image,
.tg-about__grid--no-image {
    grid-template-columns: 1fr !important;
    max-width: 840px;
    margin-inline: auto;
}

/* ─── Values Grid ─────────────────────────────────────────────────── */
.tg-values-grid,
div.tg-values-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(175px, 1fr));
    gap: 1.25rem;
    margin-top: 2rem;
    width: 100%;
}
.tg-values-grid__item {
    display: flex !important;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 1.75rem 1.25rem;
    background: var(--tg-bg-alt);
    border-radius: var(--tg-radius-lg);
    border: 1px solid var(--tg-border);
    gap: .625rem;
    transition: transform var(--tg-transition), box-shadow var(--tg-transition), border-color var(--tg-transition);
}
.tg-values-grid__item:hover {
    transform: translateY(-4px);
    box-shadow: var(--tg-shadow-xl);
    border-color: var(--tg-accent);
}
.tg-values-grid__icon {
    font-size: 2.25rem;
    line-height: 1;
    display: block;
    margin-bottom: .25rem;
}
.tg-values-grid__title {
    font-size: .9375rem;
    font-weight: 700;
    color: var(--tg-text);
    margin: 0;
}
.tg-values-grid__text {
    font-size: .875rem;
    color: var(--tg-text-muted);
    line-height: 1.6;
    margin: 0;
}

/* ─── Stats prefix ────────────────────────────────────────────────── */
.tg-stats__prefix {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--tg-accent);
}

/* ─── Service card grid helper ────────────────────────────────────── */
.tg-services__grid--grid  { grid-template-columns: repeat(3, 1fr); }
.tg-services__grid--list  { grid-template-columns: 1fr; gap: 1rem; }
.tg-services__grid--list .tg-service-card {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1.5rem;
    align-items: start;
}
.tg-services__grid--list .tg-service-card .tg-service-card__icon { margin-bottom: 0; flex-shrink: 0; }

/* ─── Pricing card CTA button wrapper ────────────────────────────── */
.tg-pricing-card__cta { margin-top: .5rem; }
.tg-btn--block { width: 100%; justify-content: center; }

/* ─── Blog/Portfolio post grid (home.php / archive) ──────────────── */
.tg-posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 380px));
    gap: 2rem;
    justify-content: center;
}
.tg-posts-grid--2 { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); max-width: 860px; margin-inline: auto; }
.tg-posts-grid--3 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.tg-posts-grid--1 { grid-template-columns: 1fr; max-width: 700px; margin-inline: auto; }

/* ─── Post card (blog listing) ───────────────────────────────────── */
.tg-post-card {
    background: var(--tg-bg);
    border-radius: var(--tg-radius-lg);
    overflow: hidden;
    box-shadow: var(--tg-shadow-md);
    transition: transform var(--tg-transition), box-shadow var(--tg-transition);
    display: flex;
    flex-direction: column;
}
.tg-post-card:hover { transform: translateY(-5px); box-shadow: var(--tg-shadow-xl); }

/* Image area */
.tg-post-card__image-link {
    display: block;
    position: relative;
    overflow: hidden;
    aspect-ratio: 16/10;
    text-decoration: none;
}
.tg-post-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--tg-transition-slow);
    display: block;
}
.tg-post-card:hover .tg-post-card__image { transform: scale(1.05); }
.tg-post-card__image-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--tg-primary) 0%, color-mix(in srgb, var(--tg-primary) 70%, var(--tg-accent)) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
}

/* Category badge overlaid on image */
.tg-post-card__cat {
    position: absolute;
    bottom: .75rem;
    left: .75rem;
    background: var(--tg-accent);
    color: var(--tg-primary);
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: .2rem .65rem;
    border-radius: var(--tg-radius-full);
    pointer-events: none;
}

/* Body */
.tg-post-card__body {
    padding: 1.375rem 1.5rem 1.5rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.tg-post-card__meta {
    display: flex;
    gap: .75rem;
    align-items: center;
    font-size: .8125rem;
    color: var(--tg-text-muted);
    margin-bottom: .75rem;
}
.tg-post-card__date,
.tg-post-card__read-time { white-space: nowrap; }
.tg-post-card__title {
    font-size: 1.0625rem;
    font-weight: 700;
    line-height: 1.4;
    margin-bottom: .625rem;
    color: var(--tg-heading);
}
.tg-post-card__title a {
    text-decoration: none;
    color: inherit;
    transition: color var(--tg-transition);
}
.tg-post-card__title a:hover { color: var(--tg-accent); }
.tg-post-card__excerpt {
    font-size: .9375rem;
    color: var(--tg-text-muted);
    line-height: 1.65;
    margin-bottom: 1.25rem;
    flex: 1;
}
.tg-post-card__link {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-size: .9rem;
    font-weight: 600;
    color: var(--tg-accent);
    text-decoration: none;
    transition: gap var(--tg-transition), color var(--tg-transition);
    margin-top: auto;
}
.tg-post-card__link:hover { gap: .5rem; color: var(--tg-primary); }

/* ─── Portfolio archive filters ───────────────────────────────────── */
.tg-portfolio__filters {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    justify-content: center;
    margin-bottom: 2.5rem;
}
.tg-portfolio__filter {
    background: none;
    border: 1.5px solid var(--tg-border);
    border-radius: var(--tg-radius-full);
    padding: .4rem 1.25rem;
    font-size: .875rem;
    font-weight: 500;
    cursor: pointer;
    transition: background var(--tg-transition), color var(--tg-transition), border-color var(--tg-transition);
    color: var(--tg-text);
}
.tg-portfolio__filter:hover,
.tg-portfolio__filter--active {
    background: var(--tg-accent);
    border-color: var(--tg-accent);
    color: var(--tg-primary);
    font-weight: 700;
}

/* ─── Empty state ──────────────────────────────────────────────────── */
.tg-empty-state {
    text-align: center;
    padding: 4rem 2rem;
}
.tg-empty-state__icon { font-size: 3rem; display: block; margin-bottom: 1rem; opacity: .6; }
.tg-empty-state__title { font-size: 1.5rem; font-weight: 700; margin-bottom: .75rem; }
.tg-empty-state__text { color: var(--tg-text-muted); margin-bottom: 2rem; font-size: 1.05rem; }

/* ─── Responsive inner pages ──────────────────────────────────────── */
@media (max-width: 1024px) {
    .tg-about__grid--image-right,
    .tg-about__grid--image-left { grid-template-columns: 1fr; gap: 2.5rem; }
    .tg-about__grid--image-right .tg-about__image-wrap,
    .tg-about__grid--image-left  .tg-about__image-wrap { order: 0; }
    .tg-about__grid--image-right .tg-about__text,
    .tg-about__grid--image-left  .tg-about__text { order: 1; }
    .tg-services__grid--grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .tg-values-grid { grid-template-columns: repeat(2, 1fr); }
    .tg-services__grid--grid { grid-template-columns: 1fr; }
    .tg-services__grid--list .tg-service-card { grid-template-columns: 1fr; }
}

/* =============================================================================
   MELHORIAS v1.3 — Alinhamento, Horário por Dias, Homepage
   ============================================================================= */

/* ─── Alinhamento de texto por secção ───────────────────────────────────────── */
/* Substitui o antigo checkbox "Centrar cabeçalho" por um select de 3 opções.    */

.tg-section--align-center .tg-section-header,
.tg-section--align-center .tg-section-header p   { text-align: center; }
.tg-section--align-center .tg-section-header p   { margin-inline: auto; }
.tg-section--align-center .tg-section-header .tg-badge { display: table; margin-inline: auto; }

.tg-section--align-left .tg-section-header,
.tg-section--align-left .tg-section-header p     { text-align: left; }
.tg-section--align-left .tg-section-header p     { margin-inline: 0; }
.tg-section--align-left .tg-section-header .tg-badge { display: table; margin-inline: 0; }

.tg-section--align-right .tg-section-header,
.tg-section--align-right .tg-section-header p    { text-align: right; }
.tg-section--align-right .tg-section-header p    { margin-right: 0; margin-left: auto; }
.tg-section--align-right .tg-section-header .tg-badge { display: table; margin-left: auto; }

/* ─── Horário por dias — tabela ─────────────────────────────────────────────── */
.tg-contact__detail--schedule { align-items: flex-start !important; }
.tg-contact__schedule-wrap { flex: 1; }
.tg-contact__schedule-wrap strong { display: block; margin-bottom: .5rem; }
.tg-schedule { border-collapse: collapse; width: 100%; margin-top: .25rem; }
.tg-schedule__row { border-bottom: 1px solid rgba(0,0,0,.07); }
.tg-schedule__row:last-child { border-bottom: none; }
.tg-schedule__day {
    padding: .35rem .75rem .35rem 0;
    font-weight: 600;
    font-size: .875rem;
    color: var(--tg-text);
    white-space: nowrap;
    width: 55%;
}
.tg-schedule__hours {
    padding: .35rem 0;
    font-size: .875rem;
    color: var(--tg-text-muted);
    text-align: right;
}
.tg-schedule__row--closed .tg-schedule__hours {
    color: var(--tg-text-muted);
    font-style: italic;
    opacity: .7;
}

/* ─── Homepage: stats grid centrado com poucos itens ────────────────────────── */
.tg-stats__grid {
    justify-content: center;
}

/* ─── Homepage: cards de serviços — altura uniforme ─────────────────────────── */
.tg-services__grid {
    grid-auto-rows: 1fr;
}
.tg-service-card {
    display: flex;
    flex-direction: column;
}
.tg-service-card__desc { flex: 1; }

/* ─── Homepage: services footer CTA centrado ─────────────────────────────────── */
.tg-services__footer {
    text-align: center;
    margin-top: 3rem;
}

/* ─── Homepage: stats item — melhorias visuais ───────────────────────────────── */
.tg-stats__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

/* ─── Homepage: testimonials — card hover ─────────────────────────────────────── */
.tg-testimonial-card {
    transition: transform var(--tg-transition), box-shadow var(--tg-transition);
}
.tg-testimonial-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--tg-shadow-xl);
}

/* ─── Homepage: CTA section — melhorias ────────────────────────────────────── */
.tg-section--cta.tg-section--align-center .tg-cta__inner {
    text-align: center;
    align-items: center;
}
.tg-section--cta.tg-section--align-left .tg-cta__inner {
    text-align: left;
    align-items: flex-start;
}

/* ─── Homepage: hero — melhorias ────────────────────────────────────────────── */
.tg-hero--centered .tg-hero__text,
.tg-hero--fullscreen .tg-hero__text {
    text-align: center;
    align-items: center;
}
.tg-hero--centered .tg-hero__actions,
.tg-hero--fullscreen .tg-hero__actions {
    justify-content: center;
}

/* ─── Contact: mapa full-width (layout info-form) ───────────────────────────── */
.tg-contact__map--full {
    margin-top: 2.5rem;
    border-radius: var(--tg-radius-lg);
    overflow: hidden;
    line-height: 0; /* elimina espaço extra abaixo do iframe */
}
.tg-contact__map--full iframe {
    width: 100%;
    height: 420px;
    display: block;
    border: 0;
    border-radius: var(--tg-radius-lg);
}

/* ─── Contact: mapa side (layout info-map) ──────────────────────────────────── */
.tg-contact__map iframe,
.tg-contact__map-wrap iframe {
    width: 100% !important;
    max-width: 100%;
    display: block;
    border-radius: var(--tg-radius-lg);
    border: 0;
}
.tg-contact__map-wrap {
    min-height: 360px;
}

/* ─── About split layout: alinhamento consistente ─────────────────────────── */
/* O CSS tg-section--align-center não deve centrar o header dentro do split.    */
.tg-about--image-left .tg-about__content .tg-section-header,
.tg-about--image-right .tg-about__content .tg-section-header {
    text-align: left;
}
.tg-about--image-left .tg-about__content .tg-section-header p,
.tg-about--image-right .tg-about__content .tg-section-header p {
    text-align: left;
    margin-inline: 0;
}
.tg-about--image-left .tg-about__content .tg-section-header .tg-badge,
.tg-about--image-right .tg-about__content .tg-section-header .tg-badge {
    display: table;
    margin-left: 0;
    margin-right: auto;
}

/* ─── Responsive v1.3 ───────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .tg-schedule__day { width: 50%; }
    .tg-contact__map-wrap { min-height: 280px; }
    .tg-contact__map iframe,
    .tg-contact__map-wrap iframe { height: 280px !important; }
}

/* =============================================================================
   MELHORIAS v1.4 — About Page Layout & CPT UX
   ============================================================================= */

/* ─── About page: texto full-width (sem imagem) ─────────────────────────────── */
.tg-about__text--full {
    max-width: 760px;
    margin-inline: auto;
}
.tg-about__text--full .tg-about__body {
    font-size: 1.0625rem;
    line-height: 1.8;
    color: var(--tg-text);
}

/* ─── About page: grelha de valores standalone (fora do split) ──────────────── */
.tg-values-grid--standalone {
    margin-top: 3rem;
    padding-top: 2.5rem;
    border-top: 1px solid var(--tg-border);
}

/* ─── About page: split grid — texto alinhado à esquerda sempre ─────────────── */
.tg-about__grid--image-left .tg-about__text .tg-section-header,
.tg-about__grid--image-right .tg-about__text .tg-section-header {
    text-align: left;
}
.tg-about__grid--image-left .tg-about__text .tg-section-header p,
.tg-about__grid--image-right .tg-about__text .tg-section-header p {
    text-align: left;
    margin-inline: 0;
}

/* ─── CPT Admin: coluna de miniatura compacta ────────────────────────────────── */
.column-tg_thumb { width: 60px !important; }
.column-tg_rating { width: 120px; }
.column-tg_year { width: 70px; }

/* ─── About page: secção equipa — estado vazio ────────────────────────────────── */
#pg-about-team .tg-container > div:only-child {
    padding: 2rem 0;
}

/* ─── Portfolio single page ─────────────────────────────────────────────────── */
.tg-portfolio-single__hero {
    position: relative;
    min-height: 360px;
    display: flex;
    align-items: flex-end;
    background: var(--tg-primary);
    padding-block: 4rem 3rem;
}
.tg-portfolio-single__hero--no-image { background: linear-gradient(135deg, var(--tg-primary) 0%, color-mix(in srgb, var(--tg-primary) 70%, black) 100%); }
.tg-portfolio-single__hero-bg { position: absolute; inset: 0; overflow: hidden; z-index: 0; }
.tg-portfolio-single__hero-bg img { width: 100%; height: 100%; object-fit: cover; display: block; }
.tg-portfolio-single__hero-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.55); }
.tg-portfolio-single__hero .tg-container { position: relative; z-index: 1; width: 100%; }
.tg-portfolio-single__hero-inner { max-width: 800px; }

.tg-portfolio-single__title {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    color: #fff;
    line-height: 1.15;
    margin: .75rem 0 1.25rem;
}
.tg-portfolio-single__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .75rem 1.25rem;
}
.tg-portfolio-single__meta-badge {
    background: var(--tg-accent);
    color: var(--tg-primary);
    font-size: .8125rem;
    font-weight: 700;
    padding: .25rem .75rem;
    border-radius: var(--tg-radius-full);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.tg-portfolio-single__meta-item {
    font-size: .9375rem;
    color: rgba(255,255,255,.8);
}
.tg-portfolio-single__meta-label {
    font-weight: 600;
    color: rgba(255,255,255,.55);
    margin-right: .25rem;
}

.tg-portfolio-single__layout { max-width: 780px; }
.tg-portfolio-single__excerpt {
    font-size: 1.0625rem;
    line-height: 1.8;
    color: var(--tg-text);
    margin-bottom: 2rem;
}
.tg-portfolio-single__excerpt p { margin: 0; }

/* Conteúdo rico do editor (text, images, lists, etc.) */
.tg-portfolio-single__content {
    margin-bottom: 2.5rem;
    font-size: 1rem;
    line-height: 1.8;
    color: var(--tg-text);
}
.tg-portfolio-single__content h2,
.tg-portfolio-single__content h3,
.tg-portfolio-single__content h4 {
    margin-top: 2rem;
    margin-bottom: .75rem;
    color: var(--tg-heading);
    font-weight: 700;
    line-height: 1.3;
}
.tg-portfolio-single__content p { margin-bottom: 1.25rem; }
.tg-portfolio-single__content p:last-child { margin-bottom: 0; }
.tg-portfolio-single__content ul,
.tg-portfolio-single__content ol {
    padding-left: 1.5rem;
    margin-bottom: 1.25rem;
}
.tg-portfolio-single__content li { margin-bottom: .4rem; }
.tg-portfolio-single__content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--tg-radius);
    display: block;
    margin-block: 1.5rem;
}
.tg-portfolio-single__content figure { margin: 1.5rem 0; }
.tg-portfolio-single__content figcaption {
    font-size: .875rem;
    color: var(--tg-muted);
    text-align: center;
    margin-top: .5rem;
}
.tg-portfolio-single__content blockquote {
    border-left: 3px solid var(--tg-accent);
    margin: 1.5rem 0;
    padding: .75rem 1.25rem;
    background: var(--tg-bg-alt);
    border-radius: 0 var(--tg-radius) var(--tg-radius) 0;
    font-style: italic;
    color: var(--tg-muted);
}
.tg-portfolio-single__content a {
    color: var(--tg-accent);
    text-decoration: underline;
}

.tg-portfolio-single__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
}

/* ─── WordPress Galleries ──────────────────────────────────────────────────── */
.tg-portfolio-single__content .wp-block-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
    margin-block: 2rem;
}
.tg-portfolio-single__content .wp-block-gallery figure {
    margin: 0;
    overflow: hidden;
    border-radius: var(--tg-radius-md);
}
.tg-portfolio-single__content .wp-block-gallery img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 4/3;
    margin: 0;
}
.tg-portfolio-single__content .gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
    margin-block: 2rem;
}
.tg-portfolio-single__content .gallery-item {
    overflow: hidden;
    border-radius: var(--tg-radius-md);
}
.tg-portfolio-single__content .gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 4/3;
    margin: 0;
    border-radius: var(--tg-radius-md);
}

/* ─── Responsive v1.4 ───────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .tg-values-grid--standalone { padding-top: 2rem; margin-top: 2rem; }
    .tg-about__text--full { padding-inline: 0; }
    .tg-portfolio-single__hero { min-height: 260px; padding-block: 3rem 2rem; }
    .tg-portfolio-single__actions { flex-direction: column; align-items: stretch; }
    .tg-portfolio-single__actions .tg-btn { text-align: center; justify-content: center; }
    /* Blog cards: 1 coluna em mobile */
    .tg-posts-grid,
    .tg-posts-grid--2,
    .tg-posts-grid--3 { grid-template-columns: 1fr; max-width: 500px; margin-inline: auto; }
    /* Team grid: 2 cols no máximo em tablets */
    .tg-team__grid--3,
    .tg-team__grid--4 { grid-template-columns: repeat(2, 1fr); }
    /* Portfolio single content */
    .tg-portfolio-single__content img { margin-block: 1rem; }
}

/* =============================================================================
   CATÁLOGO
   ============================================================================= */

/* ─── Filtros ──────────────────────────────────────────────────────────────── */
.tg-catalog__filters {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    justify-content: center;
    margin-bottom: 2.5rem;
}
.tg-catalog__filter {
    background: none;
    border: 1.5px solid var(--tg-border);
    border-radius: var(--tg-radius-full);
    padding: .4rem 1.25rem;
    font-size: .875rem;
    font-weight: 500;
    cursor: pointer;
    transition: background var(--tg-transition), color var(--tg-transition), border-color var(--tg-transition);
    color: var(--tg-text);
}
.tg-catalog__filter:hover,
.tg-catalog__filter--active {
    background: var(--tg-accent);
    border-color: var(--tg-accent);
    color: var(--tg-primary);
    font-weight: 700;
}

/* ─── Grelha ───────────────────────────────────────────────────────────────── */
.tg-catalog__grid {
    display: grid;
    gap: 1.75rem;
    grid-template-columns: repeat(3, 1fr);
}
.tg-catalog__grid--2 { grid-template-columns: repeat(2, 1fr); }
.tg-catalog__grid--3 { grid-template-columns: repeat(3, 1fr); }
.tg-catalog__grid--4 { grid-template-columns: repeat(4, 1fr); }

.tg-catalog__empty { text-align: center; padding: 4rem; color: var(--tg-text-muted); }
.tg-catalog__pagination { margin-top: 3rem; text-align: center; }

/* ─── Card (espelha .tg-portfolio-card) ────────────────────────────────────── */
.tg-catalog-card { border-radius: var(--tg-radius-lg); overflow: hidden; background: var(--tg-bg); box-shadow: var(--tg-shadow-md); transition: transform var(--tg-transition), box-shadow var(--tg-transition); min-width: 0; }
.tg-catalog-card:hover { transform: translateY(-6px); box-shadow: var(--tg-shadow-xl); }
.tg-catalog-card__link { display: block; text-decoration: none; }

.tg-catalog-card__media { position: relative; overflow: hidden; aspect-ratio: 4/3; }
.tg-catalog-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--tg-transition-slow); }
.tg-catalog-card:hover .tg-catalog-card__media img { transform: scale(1.08); }
.tg-catalog-card__placeholder { width: 100%; height: 100%; }

.tg-catalog-card__overlay {
    position: absolute;
    inset: 0;
    background: rgba(var(--tg-primary-rgb), .7);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity var(--tg-transition);
}
.tg-catalog-card:hover .tg-catalog-card__overlay { opacity: 1; }
.tg-catalog-card__overlay-icon { color: var(--tg-accent); }

.tg-catalog-card__info { padding: 1.25rem 1.5rem; display: flex; flex-direction: column; gap: .375rem; }
.tg-catalog-card__cat { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--tg-accent); margin: 0; display: block; }
.tg-catalog-card__title { font-size: 1rem; font-weight: 700; color: var(--tg-text); margin: 0; line-height: 1.4; }
.tg-catalog-card__excerpt { font-size: .875rem; color: var(--tg-text-muted); margin: 0; line-height: 1.6; }
.tg-catalog-card__price { font-size: 1.125rem; color: var(--tg-primary); font-weight: 700; margin: 0; margin-top: .25rem; }

/* ─── Página individual ────────────────────────────────────────────────────── */

/* Hero do item */
.tg-catalog-single__hero {
    background: var(--tg-primary);
    padding-top: calc(72px + 2.5rem);
    padding-bottom: 2.5rem;
}
.tg-catalog-single__hero .tg-breadcrumb { margin-bottom: .75rem; }
.tg-catalog-single__title {
    font-size: clamp(1.6rem, 3.5vw, 2.5rem);
    font-weight: 800;
    color: #fff;
    margin: 0;
    line-height: 1.2;
}

/* Botão Voltar */
.tg-catalog-single__back-top {
    display: inline-flex;
    align-items: center;
    gap: .375rem;
    font-size: .875rem;
    color: var(--tg-text-muted);
    text-decoration: none;
    margin-bottom: 2rem;
    transition: color var(--tg-transition);
}
.tg-catalog-single__back-top:hover { color: var(--tg-primary); }

.tg-catalog-single { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; }
.tg-catalog-single__image-col { display: flex; flex-direction: column; gap: 1rem; }
.tg-catalog-single__image img { width: 100%; border-radius: var(--tg-radius-lg); display: block; }

.tg-catalog-single__meta { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1rem; }
.tg-catalog-single__cat {
    background: var(--tg-bg-alt);
    color: var(--tg-accent);
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: .3rem .75rem;
    border-radius: 2rem;
    text-decoration: none;
}
.tg-catalog-single__ref { font-size: .8125rem; color: var(--tg-text-muted); padding: .3rem 0; }
.tg-catalog-single__price { font-size: 2rem; font-weight: 800; color: var(--tg-primary); margin-bottom: 1.25rem; }
.tg-catalog-single__content {
    margin-bottom: 2rem;
    line-height: 1.8;
    color: var(--tg-text);
    font-size: 1rem;
}
.tg-catalog-single__content p { margin-bottom: 1rem; }
.tg-catalog-single__content p:last-child { margin-bottom: 0; }
.tg-catalog-single__content h2,
.tg-catalog-single__content h3 { margin-top: 1.5rem; margin-bottom: .5rem; }
.tg-catalog-single__content ul,
.tg-catalog-single__content ol { padding-left: 1.5rem; margin-bottom: 1rem; list-style: initial; }
.tg-catalog-single__content img { max-width: 100%; border-radius: var(--tg-radius-md); margin-block: 1rem; display: block; }

/* Galeria do item de catálogo */
.tg-catalog-single__gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
    margin-bottom: 2rem;
}
.tg-catalog-gallery__item {
    display: block;
    overflow: hidden;
    border-radius: var(--tg-radius-md);
    aspect-ratio: 4/3;
    border: 1px solid var(--tg-border);
}
.tg-catalog-gallery__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform var(--tg-transition-slow);
}
.tg-catalog-gallery__item:hover img { transform: scale(1.06); }

.tg-catalog-single__excerpt { font-size: 1rem; line-height: 1.8; color: var(--tg-text-muted); margin-bottom: 1.5rem; }
.tg-catalog-single__actions { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; }
.tg-catalog-single__back { font-size: .875rem; color: var(--tg-text-muted); text-decoration: none; }
.tg-catalog-single__back:hover { color: var(--tg-primary); }

/* ─── Responsivo ───────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .tg-catalog__grid--4 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 700px) {
    .tg-catalog__grid--2,
    .tg-catalog__grid--3,
    .tg-catalog__grid--4 { grid-template-columns: repeat(2, 1fr); }
    .tg-catalog-single { grid-template-columns: 1fr; gap: 2rem; }
}
@media (max-width: 480px) {
    .tg-catalog__grid--2,
    .tg-catalog__grid--3,
    .tg-catalog__grid--4 { grid-template-columns: 1fr; }
}
