:root {
	--th-gold: #c8a97e;
	--th-gold-dark: #b08b5b;
	--th-black: #1a1a1a;
	--th-ink: #222222;
	--th-muted: #706b63;
	--th-bg: #f7f5f2;
	--th-white: #ffffff;
	--th-border: rgba(0, 0, 0, 0.08);
	--th-dark-border: rgba(255, 255, 255, 0.12);
	--th-serif: "Playfair Display", "Cormorant Garamond", Georgia, serif;
	--th-sans: "Inter", "Manrope", Arial, sans-serif;
	--th-max: 1240px;
	--th-space: clamp(72px, 9vw, 136px);
}

html { scroll-behavior: smooth; }
body { background: var(--th-bg); color: var(--th-ink); font-family: var(--th-sans); }
#wrapper { background: var(--th-bg); overflow: clip; }
.th-container { width: min(calc(100% - 40px), var(--th-max)); margin-inline: auto; }
.th-section { padding-block: var(--th-space); }
.th-home img { display: block; width: 100%; height: auto; object-fit: cover; }
.th-home h1, .th-home h2, .th-home h3 { font-family: var(--th-serif); color: inherit; letter-spacing: 0; font-weight: 500; }
.th-home h1 { font-size: clamp(54px, 7vw, 106px); line-height: 0.96; max-width: 960px; margin: 0; }
.th-home h2 { font-size: clamp(38px, 5vw, 52px); line-height: 1.02; margin: 0; }
.th-home h3 { font-size: clamp(24px, 2vw, 34px); line-height: 1.1; margin: 0; }
.th-home p { font-size: 17px; line-height: 1.8; color: var(--th-muted); padding: 0; }
.th-eyebrow { color: var(--th-gold-dark) !important; font-size: 12px !important; text-transform: uppercase; letter-spacing: 0.28em; font-weight: 700; margin: 0 0 22px; }

.th-header { position: fixed; inset: 0 0 auto; z-index: 1000; transition: background .35s ease, border-color .35s ease, transform .35s ease; border-bottom: 1px solid transparent; }
.th-header.is-scrolled, .th-header.header-fixed-top { background: rgba(255, 255, 255, 0.94); backdrop-filter: blur(18px); border-color: rgba(0,0,0,.1); box-shadow: 0 10px 36px rgba(26,26,26,.08); }
body:not(.home) .th-header { background: rgba(26, 26, 26, 0.82); backdrop-filter: blur(18px); border-color: rgba(255,255,255,.1); }
body:not(.home) .th-header.is-scrolled,
body:not(.home) .th-header.header-fixed-top { background: rgba(255, 255, 255, 0.94); border-color: rgba(0,0,0,.1); }
.th-header__inner { width: min(calc(100% - 40px), 1380px); height: 92px; margin-inline: auto; display: grid; grid-template-columns: 230px 1fr; align-items: center; gap: 28px; }
.th-header__brand { display: inline-flex; align-items: center; max-width: 220px; }
.th-header__brand img { max-width: 100%; height: auto; filter: drop-shadow(0 12px 24px rgba(0,0,0,.22)); }
.th-header.is-scrolled .th-header__brand img, .th-header.header-fixed-top .th-header__brand img { filter: none; }
.th-header__nav { display: flex; align-items: center; justify-content: flex-end; gap: 30px; }
.th-menu { display: flex; align-items: center; justify-content: center; gap: clamp(16px, 2vw, 34px); margin: 0; list-style: none; }
.th-menu li { position: relative; margin: 0; }
.th-menu a { color: #fff; font-size: 13px; letter-spacing: .12em; text-transform: uppercase; font-weight: 700; text-shadow: 0 1px 16px rgba(0,0,0,.28); }
.th-header.is-scrolled .th-menu a, .th-header.header-fixed-top .th-menu a { color: #2a2723; text-shadow: none; }
body:not(.home) .th-header:not(.is-scrolled):not(.header-fixed-top) .th-menu a { color: rgba(255,255,255,.92); }
.th-menu .sub-menu { position: absolute; top: calc(100% + 24px); left: 50%; z-index: 20; min-width: 240px; margin: 0; padding: 14px 0; list-style: none; background: rgba(26, 26, 26, .94); border: 1px solid rgba(255,255,255,.12); box-shadow: 0 24px 70px rgba(0,0,0,.22); backdrop-filter: blur(18px); opacity: 0; visibility: hidden; transform: translate(-50%, 12px); transition: opacity .22s ease, transform .22s ease, visibility .22s ease; }
.th-menu li:hover > .sub-menu,
.th-menu li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translate(-50%, 0); }
.th-menu .sub-menu:before { content: ""; position: absolute; left: 0; right: 0; top: -24px; height: 24px; }
.th-menu .sub-menu li { width: 100%; }
.th-menu .sub-menu a { display: block; padding: 11px 20px; color: #fff !important; white-space: nowrap; letter-spacing: .08em; font-size: 12px; }
.th-menu .sub-menu a:hover,
.th-menu .sub-menu a:focus { background: rgba(200,169,126,.14); color: var(--th-gold) !important; }
.th-menu .menu-item-has-children > a:after { content: ""; display: inline-block; width: 6px; height: 6px; margin-left: 9px; border-right: 1px solid currentColor; border-bottom: 1px solid currentColor; transform: translateY(-3px) rotate(45deg); }
.th-menu-close { display: none; }
.th-header__cta, .th-btn { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 0 24px; border: 1px solid transparent; font-size: 13px; letter-spacing: .08em; text-transform: uppercase; font-weight: 800; transition: transform .28s ease, background .28s ease, color .28s ease, border-color .28s ease; cursor: pointer; }
.th-header__cta, .th-btn--primary { background: var(--th-gold); color: #161616 !important; }
.th-header__cta:hover, .th-btn--primary:hover { background: var(--th-gold-dark); transform: translateY(-2px); }
.th-btn--light { border-color: rgba(255,255,255,.5); color: #fff !important; background: rgba(255,255,255,.04); }
.th-btn--light:hover { background: #fff; color: var(--th-ink) !important; }
.th-menu-toggle { display: none; }

.th-hero { min-height: 100svh; position: relative; display: grid; align-items: center; isolation: isolate; overflow: hidden; background: #111; color: #fff; }
.th-hero__media { position: absolute; inset: 0; z-index: -2; background-image: linear-gradient(90deg, rgba(0,0,0,.78), rgba(0,0,0,.34) 50%, rgba(0,0,0,.12)), var(--hero-image); background-size: cover; background-position: center; animation: th-kenburns 18s ease-in-out infinite alternate; }
.th-hero:after { content: ""; position: absolute; inset: auto 0 0; height: 36vh; background: linear-gradient(transparent, rgba(0,0,0,.5)); z-index: -1; }
.th-hero__content { padding-top: 92px; }
.th-hero__lead { color: rgba(255,255,255,.82) !important; font-size: clamp(18px, 2vw, 26px) !important; margin: 28px 0 34px; }
.th-actions { display: flex; flex-wrap: wrap; gap: 14px; }
.th-hero__meta { position: absolute; right: 42px; bottom: 36px; display: flex; gap: 28px; color: rgba(255,255,255,.7); font-size: 12px; letter-spacing: .18em; text-transform: uppercase; }
.th-scroll { position: absolute; left: 50%; bottom: 32px; width: 24px; height: 42px; border: 1px solid rgba(255,255,255,.44); border-radius: 999px; transform: translateX(-50%); }
.th-scroll span { position: absolute; left: 50%; top: 8px; width: 4px; height: 4px; border-radius: 50%; background: #fff; transform: translateX(-50%); animation: th-scroll 1.6s infinite; }

.th-about { display: grid; grid-template-columns: minmax(0, 1.04fr) minmax(320px, .82fr); gap: clamp(36px, 7vw, 96px); align-items: center; }
.th-about__image { margin: 0; height: clamp(520px, 62vw, 760px); }
.th-about__copy p:not(.th-eyebrow) { margin-top: 26px; }
.th-about__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 38px 0; border-top: 1px solid var(--th-border); border-bottom: 1px solid var(--th-border); padding-block: 24px; }
.th-about__stats strong { font-family: var(--th-serif); font-size: clamp(28px, 3vw, 44px); font-weight: 500; }
.th-about__stats span { display: block; margin-top: 8px; font-family: var(--th-sans); color: var(--th-muted); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; }
.th-link { color: var(--th-ink); border-bottom: 1px solid var(--th-gold); padding-bottom: 6px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; font-size: 13px; }

.th-section__head { margin-bottom: clamp(34px, 5vw, 64px); }
.th-section__head h2 { max-width: 780px; }
.th-section__head--split { display: flex; align-items: end; justify-content: space-between; gap: 30px; }
.th-service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--th-border); border: 1px solid var(--th-border); }
.th-service-card { position: relative; min-height: 460px; overflow: hidden; background: #111; color: #fff; }
.th-service-card img { position: absolute; inset: 0; opacity: .74; transition: transform .8s ease, opacity .5s ease; }
.th-service-card:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 25%, rgba(0,0,0,.82)); }
.th-service-card div { position: absolute; inset: auto 28px 28px; z-index: 1; }
.th-service-card p { color: rgba(255,255,255,.74); margin-top: 14px; }
.th-service-card:hover img { transform: scale(1.08); opacity: .95; }

.th-projects { background: #fff; }
.th-filters { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; }
.th-filters button { border: 1px solid var(--th-border); background: transparent; color: var(--th-ink); height: 40px; padding: 0 16px; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; }
.th-filters button.is-active, .th-filters button:hover { background: var(--th-black); color: #fff; }
.th-masonry { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 240px; gap: 18px; }
.th-project-card { position: relative; overflow: hidden; background: #ddd; color: #fff; }
.th-project-card.wide { grid-column: span 2; }
.th-project-card.tall { grid-row: span 2; }
.th-project-card img { transition: transform .8s ease, filter .4s ease; }
.th-project-card:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 35%, rgba(0,0,0,.78)); opacity: .8; transition: opacity .3s ease; }
.th-project-card span { position: absolute; z-index: 1; left: 22px; right: 22px; bottom: 20px; transform: translateY(12px); opacity: 0; transition: .32s ease; }
.th-project-card small { display: block; margin-bottom: 8px; color: var(--th-gold); letter-spacing: .16em; text-transform: uppercase; }
.th-project-card strong { display: block; font-family: var(--th-serif); font-size: 30px; font-weight: 500; }
.th-project-card:hover img { transform: scale(1.08); filter: saturate(1.08); }
.th-project-card:hover span { transform: translateY(0); opacity: 1; }
.th-project-card.is-hidden { display: none; }

.th-compare { display: grid; grid-template-columns: .72fr 1.1fr; gap: clamp(28px, 6vw, 78px); align-items: center; }
.th-compare__slider { position: relative; height: clamp(380px, 50vw, 640px); overflow: hidden; background: #ddd; }
.th-compare__slider img:nth-child(2) { position: absolute; inset: 0; clip-path: inset(0 calc(100% - var(--pos)) 0 0); }
.th-compare__slider:after { content: ""; position: absolute; top: 0; bottom: 0; left: var(--pos); width: 2px; background: #fff; transform: translateX(-1px); }
.th-compare__slider input { position: absolute; inset: 0; opacity: 0; cursor: ew-resize; z-index: 2; }

.th-process { background: #eee9e2; }
.th-timeline { display: grid; grid-template-columns: repeat(7, 1fr); gap: 0; list-style: none; counter-reset: item; margin: 0 auto; padding: 0; }
.th-timeline li { position: relative; padding: 34px 18px 0 0; border-top: 1px solid rgba(0,0,0,.18); font-weight: 800; letter-spacing: .08em; text-transform: uppercase; font-size: 13px; }
.th-timeline li:before { content: ""; position: absolute; top: -5px; left: 0; width: 10px; height: 10px; border-radius: 50%; background: var(--th-gold-dark); }
.th-timeline span { display: block; color: var(--th-gold-dark); margin-bottom: 12px; }

.th-why { background: var(--th-black); color: #fff; }
.th-why .th-home p, .th-why p, .th-why h2, .th-why h3 { color: inherit; }
.th-feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--th-dark-border); border: 1px solid var(--th-dark-border); }
.th-feature-grid article { padding: clamp(30px, 4vw, 52px); background: #1f1f1f; transition: background .28s ease, transform .28s ease; }
.th-feature-grid i { color: var(--th-gold); font-size: 24px; margin-bottom: 24px; }
.th-feature-grid p { color: rgba(255,255,255,.64); margin-top: 16px; }
.th-feature-grid article:hover { background: #26221d; transform: translateY(-3px); }

.th-testimonials { text-align: center; }
.th-testimonial-track { position: relative; min-height: 310px; }
.th-testimonial-track article { display: none; max-width: 900px; margin: 0 auto; background: #fff; padding: clamp(34px, 5vw, 72px); border: 1px solid var(--th-border); box-shadow: 0 24px 70px rgba(26,26,26,.07); }
.th-testimonial-track article.is-active { display: block; animation: th-fade .6s ease; }
.th-testimonial-track div { color: var(--th-gold-dark); letter-spacing: .18em; margin-bottom: 20px; }
.th-testimonial-track blockquote { background: transparent; color: var(--th-ink); font-family: var(--th-serif); font-size: clamp(28px, 3.5vw, 48px); line-height: 1.18; margin: 0; padding: 0; }
.th-testimonial-track p { margin-top: 24px; font-weight: 800; color: var(--th-ink); }
.th-testimonial-track span { display: block; color: var(--th-muted); font-weight: 400; }

.th-stats { background: #fff; padding: clamp(42px, 7vw, 84px) 0; border-block: 1px solid var(--th-border); }
.th-stats .th-container { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.th-stats strong { font-family: var(--th-serif); font-size: clamp(44px, 6vw, 86px); font-weight: 500; }
.th-stats small { display: block; margin-top: 10px; color: var(--th-muted); font-family: var(--th-sans); font-size: 12px; letter-spacing: .16em; text-transform: uppercase; }

.th-cta { color: #fff; min-height: 560px; display: grid; place-items: center; text-align: center; background-image: linear-gradient(rgba(0,0,0,.62), rgba(0,0,0,.68)), var(--cta-image); background-size: cover; background-attachment: fixed; background-position: center; }
.th-cta h2 { max-width: 860px; margin: 0 auto 32px; }
.th-blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.th-blog-card { background: transparent; color: var(--th-ink); }
.th-blog-card img { height: 300px; margin-bottom: 22px; transition: transform .6s ease; }
.th-blog-card small { color: var(--th-gold-dark); letter-spacing: .14em; text-transform: uppercase; }
.th-blog-card h3 { margin-top: 10px; font-size: 30px; }
.th-blog-card h3,
.th-blog-card:hover h3,
.th-blog-card:focus h3 { color: var(--th-ink); }
.th-blog-card:hover,
.th-blog-card:focus { color: var(--th-ink); }
.th-blog-card:hover small,
.th-blog-card:focus small { color: var(--th-gold-dark); }
.th-blog-card:hover img { transform: translateY(-4px); }

.th-footer { background: #111; color: #fff; padding: 84px 0 28px; }
.th-footer__grid { display: grid; grid-template-columns: 1.1fr 1fr .6fr 1.1fr; gap: 42px; }
.th-footer h2, .th-footer h3 { color: #fff; }
.th-footer p, .th-footer a { color: rgba(255,255,255,.68); }
.th-footer a { display: block; margin: 8px 0; }
.th-footer__logo { width: min(280px, 86vw); height: auto; object-fit: contain; margin-bottom: 22px; }
.th-map iframe { width: 100%; height: 230px; filter: grayscale(1) invert(.9); border: 0; }
.th-footer__bottom { display: flex; justify-content: space-between; gap: 20px; margin-top: 58px; padding-top: 24px; border-top: 1px solid var(--th-dark-border); color: rgba(255,255,255,.42); font-size: 13px; }

.th-inquiry { position: fixed; inset: 0; z-index: 2000; display: grid; place-items: center; background: rgba(17,15,12,.72); backdrop-filter: blur(10px); opacity: 0; pointer-events: none; transition: opacity .25s ease; }
.th-inquiry.is-open { opacity: 1; pointer-events: auto; }
.th-inquiry__panel { width: min(calc(100% - 32px), 590px); max-height: min(92svh, 820px); overflow: auto; background: linear-gradient(145deg, #fffaf2 0%, #f7f2ea 54%, #ffffff 100%); color: var(--th-ink); padding: clamp(26px, 4vw, 40px); position: relative; border: 1px solid rgba(200,169,126,.28); box-shadow: 0 34px 100px rgba(0,0,0,.32); }
.th-inquiry__panel:before { content: ""; position: absolute; inset: 16px; border: 1px solid rgba(200,169,126,.18); pointer-events: none; }
.th-inquiry__panel > * { position: relative; z-index: 1; }
.th-inquiry__panel > button { position: absolute; top: 14px; right: 14px; z-index: 2; display: grid; place-items: center; width: 40px; height: 40px; border: 1px solid rgba(0,0,0,.08); border-radius: 50%; background: rgba(255,255,255,.82); color: #2a2723; font-size: 28px; line-height: 1; padding: 0; cursor: pointer; transition: background .25s ease, transform .25s ease, color .25s ease; }
.th-inquiry__panel > button:hover { background: var(--th-black); color: #fff; transform: rotate(90deg); }
.th-inquiry__panel .th-eyebrow { color: var(--th-gold-dark) !important; margin-bottom: 16px; }
.th-inquiry__panel h2 { margin: 0 0 20px; color: #1f1d1a; font-family: var(--th-serif); font-size: clamp(34px, 4vw, 46px); line-height: 1.05; font-weight: 500; letter-spacing: 0; }
.th-inquiry .wpcf7 { color: var(--th-ink); }
.th-inquiry .wpcf7 form p { padding: 0; margin: 0 0 10px; color: #4c463e !important; font-size: 14px; font-weight: 700; line-height: 1.45; }
.th-inquiry .wpcf7 label { color: #4c463e !important; font-size: 14px; font-weight: 700; }
.th-inquiry .wpcf7-form-control-wrap { display: block; }
.th-inquiry input:not([type="submit"]), .th-inquiry textarea, .th-inquiry select { width: 100%; min-height: 46px; margin: 5px 0 0; background: rgba(255,255,255,.96) !important; border: 1px solid rgba(26,26,26,.18) !important; color: #1f1d1a !important; box-shadow: inset 0 1px 0 rgba(255,255,255,.7); outline: none; transition: border-color .25s ease, box-shadow .25s ease, background .25s ease; }
.th-inquiry textarea { height: 104px !important; min-height: 104px; resize: vertical; }
.th-inquiry input:not([type="submit"]):focus, .th-inquiry textarea:focus, .th-inquiry select:focus { background: #fff !important; border-color: var(--th-gold-dark) !important; box-shadow: 0 0 0 4px rgba(200,169,126,.18); }
.th-inquiry input::placeholder, .th-inquiry textarea::placeholder { color: #8d867c; opacity: 1; }
.th-inquiry .wpcf7-submit { width: 100%; min-height: 50px; margin-top: 8px; background: var(--th-black) !important; color: #fff !important; border: 1px solid var(--th-black) !important; font-size: 13px; letter-spacing: .12em; text-transform: uppercase; font-weight: 800; box-shadow: 0 14px 34px rgba(26,26,26,.16); transition: background .25s ease, border-color .25s ease, transform .25s ease, box-shadow .25s ease; }
.th-inquiry .wpcf7-submit:hover { background: var(--th-gold-dark) !important; border-color: var(--th-gold-dark) !important; color: #fff !important; transform: translateY(-2px); box-shadow: 0 18px 42px rgba(176,139,91,.24); }
.th-inquiry .wpcf7-spinner { display: block; margin: 12px auto 0; }
.th-inquiry .wpcf7-not-valid-tip { margin-top: 6px; color: #9f3b28; font-size: 13px; font-weight: 600; }
.th-inquiry .wpcf7-response-output { margin: 16px 0 0 !important; padding: 12px 14px !important; border-color: rgba(176,139,91,.36) !important; background: rgba(255,255,255,.72); color: var(--th-ink); font-size: 14px; line-height: 1.5; }
.th-mobile-cta { display: none; }

[data-reveal] { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
[data-reveal].is-visible { opacity: 1; transform: none; }

.th-services-page { background: var(--th-bg); color: var(--th-ink); }
.th-services-page h1,
.th-services-page h2,
.th-services-page h3 { font-family: var(--th-serif); letter-spacing: 0; font-weight: 500; color: inherit; }
.th-services-hero { position: relative; min-height: 72svh; display: grid; align-items: end; padding: 150px 0 86px; color: #fff; isolation: isolate; overflow: hidden; background-image: linear-gradient(90deg, rgba(0,0,0,.78), rgba(0,0,0,.34)), var(--service-hero); background-size: cover; background-position: center; }
.th-services-hero:after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.55)); }
.th-services-hero h1 { max-width: 980px; margin: 0; font-size: clamp(52px, 7vw, 112px); line-height: .98; }
.th-services-hero p:not(.th-eyebrow) { max-width: 680px; margin: 28px 0 34px; color: rgba(255,255,255,.78); font-size: clamp(18px, 2vw, 24px); line-height: 1.65; }
.th-service-intro { display: grid; grid-template-columns: .9fr .82fr; gap: clamp(34px, 7vw, 96px); padding-block: var(--th-space); border-bottom: 1px solid var(--th-border); }
.th-service-intro h2 { margin: 0; font-size: clamp(38px, 5vw, 74px); line-height: 1.04; }
.th-service-intro__copy p { margin: 0 0 28px; color: var(--th-muted); font-size: 17px; line-height: 1.85; }
.th-service-intro__copy ul { display: grid; gap: 14px; margin: 0; padding: 0; list-style: none; }
.th-service-intro__copy li { position: relative; padding-left: 28px; color: var(--th-ink); font-weight: 700; }
.th-service-intro__copy li:before { content: ""; position: absolute; left: 0; top: .75em; width: 12px; height: 1px; background: var(--th-gold-dark); }
.th-service-catalog { padding-block: var(--th-space); background: #fff; }
.th-service-quote { border: 0; background: transparent; height: auto; color: var(--th-ink); cursor: pointer; }
.th-service-list { display: grid; gap: 28px; }
.th-service-row { display: grid; grid-template-columns: minmax(300px, .72fr) minmax(0, 1fr); min-height: 420px; border: 1px solid var(--th-border); background: var(--th-bg); overflow: hidden; }
.th-service-row:nth-child(even) { grid-template-columns: minmax(0, 1fr) minmax(300px, .72fr); }
.th-service-row:nth-child(even) .th-service-row__image { order: 2; }
.th-service-row__image { position: relative; overflow: hidden; background: #ddd; }
.th-service-row__image img { transition: transform .8s ease, filter .4s ease; }
.th-service-row:hover .th-service-row__image img { transform: scale(1.06); filter: saturate(1.06); }
.th-service-row__content { display: flex; flex-direction: column; justify-content: center; padding: clamp(28px, 5vw, 70px); }
.th-service-row__content > span { color: var(--th-gold-dark); font-size: 13px; font-weight: 800; letter-spacing: .22em; margin-bottom: 20px; }
.th-service-row__content h3 { margin: 0; font-size: clamp(34px, 4vw, 62px); line-height: 1.02; }
.th-service-row__content h3 a { color: var(--th-ink); }
.th-service-row__content p { max-width: 620px; margin: 22px 0 0; padding: 0; color: var(--th-muted); font-size: 17px; line-height: 1.8; }
.th-service-row__meta { display: flex; flex-wrap: wrap; gap: 10px; margin: 28px 0 34px; }
.th-service-row__meta small { border: 1px solid var(--th-border); padding: 8px 12px; color: var(--th-muted); letter-spacing: .12em; text-transform: uppercase; font-size: 11px; }
.th-service-empty { text-align: center; padding: 64px 24px; border: 1px solid var(--th-border); background: var(--th-bg); }
.th-service-cta { padding-block: var(--th-space); background: var(--th-black); color: #fff; text-align: center; }
.th-service-cta h2 { max-width: 900px; margin: 0 auto 32px; font-size: clamp(38px, 5vw, 78px); line-height: 1.04; }
.th-archive-service-card { display: grid; grid-template-columns: 360px minmax(0, 1fr); gap: 34px; align-items: stretch; margin: 0 0 34px; padding: 0; background: #fff; border: 1px solid var(--th-border); overflow: hidden; }
.th-archive-service-card__image { min-height: 280px; overflow: hidden; background: #ddd; }
.th-archive-service-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s ease; }
.th-archive-service-card:hover .th-archive-service-card__image img { transform: scale(1.06); }
.th-archive-service-card__content { padding: clamp(28px, 4vw, 52px); }
.th-archive-service-card__content h2 { margin: 0; font-size: clamp(32px, 4vw, 54px); line-height: 1.04; font-family: var(--th-serif); letter-spacing: 0; }
.th-archive-service-card__content h2 a { color: var(--th-ink); }
.th-archive-service-card__content p:not(.th-eyebrow) { margin: 20px 0 28px; padding: 0; color: var(--th-muted); font-size: 17px; line-height: 1.75; }
.th-service-detail { background: var(--th-bg); color: var(--th-ink); }
.th-service-detail h1,
.th-service-detail h2,
.th-service-detail h3 { font-family: var(--th-serif); letter-spacing: 0; font-weight: 500; color: inherit; }
.th-service-detail-hero { min-height: 76svh; display: grid; align-items: end; padding: 152px 0 88px; color: #fff; background-image: linear-gradient(90deg, rgba(0,0,0,.78), rgba(0,0,0,.22)), var(--detail-hero); background-size: cover; background-position: center; position: relative; isolation: isolate; }
.th-service-detail-hero:after { content: ""; position: absolute; inset: auto 0 0; z-index: -1; height: 40%; background: linear-gradient(transparent, rgba(0,0,0,.55)); }
.th-service-detail-hero h1 { max-width: 980px; margin: 0; font-size: clamp(52px, 7vw, 112px); line-height: .96; }
.th-service-detail-hero p:not(.th-eyebrow) { max-width: 720px; margin: 28px 0 34px; color: rgba(255,255,255,.78); font-size: clamp(18px, 2vw, 24px); line-height: 1.65; }
.th-service-detail-body { display: grid; grid-template-columns: 360px minmax(0, 1fr); gap: clamp(38px, 7vw, 96px); padding-block: var(--th-space); align-items: start; }
.th-service-detail-aside { position: sticky; top: 120px; display: grid; gap: 22px; }
.th-service-detail-aside > div { border: 1px solid var(--th-border); background: #fff; padding: 30px; }
.th-service-detail-aside ul { display: grid; gap: 14px; margin: 0; padding: 0; list-style: none; }
.th-service-detail-aside li { position: relative; padding-left: 24px; color: var(--th-muted); line-height: 1.6; }
.th-service-detail-aside li:before { content: ""; position: absolute; left: 0; top: .78em; width: 10px; height: 1px; background: var(--th-gold-dark); }
.th-service-detail-card { background: var(--th-black) !important; color: #fff; }
.th-service-detail-card h2 { margin: 0; font-size: 34px; line-height: 1.05; }
.th-service-detail-card p { margin: 16px 0 24px; padding: 0; color: rgba(255,255,255,.68); }
.th-service-detail-content { background: #fff; border: 1px solid var(--th-border); padding: clamp(34px, 6vw, 84px); }
.th-service-detail-content h2 { margin: 0 0 22px; font-size: clamp(36px, 5vw, 70px); line-height: 1.04; }
.th-service-detail-content h3 { margin-top: 38px; font-size: clamp(28px, 3vw, 42px); }
.th-service-detail-content p,
.th-service-detail-content li { color: var(--th-muted); font-size: 18px; line-height: 1.85; }
.th-service-detail-content p { padding: 0; margin: 0 0 24px; }
.th-service-detail-content img { height: auto; margin: 34px 0; }
.th-detail-process { padding-block: var(--th-space); background: #eee9e2; }
.th-detail-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(0,0,0,.1); border: 1px solid rgba(0,0,0,.1); list-style: none; margin: 0 auto; padding: 0; }
.th-detail-steps li { background: #f7f5f2; padding: clamp(28px, 4vw, 48px); }
.th-detail-steps span { display: block; color: var(--th-gold-dark); font-weight: 800; letter-spacing: .2em; margin-bottom: 22px; }
.th-detail-steps strong { display: block; font-family: var(--th-serif); font-size: 34px; font-weight: 500; color: var(--th-ink); }
.th-detail-steps p { margin: 14px 0 0; padding: 0; color: var(--th-muted); line-height: 1.7; }
.th-related-services { padding-block: var(--th-space); }
.th-related-services__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.th-related-service { position: relative; height: 420px; overflow: hidden; background: #111; color: #fff; }
.th-related-service img { transition: transform .7s ease, opacity .4s ease; opacity: .78; }
.th-related-service span { position: absolute; left: 24px; right: 24px; bottom: 24px; font-family: var(--th-serif); font-size: 34px; line-height: 1.05; }
.th-related-service:hover img { transform: scale(1.06); opacity: .96; }
.th-service-detail-cta { padding-block: var(--th-space); background: var(--th-black); color: #fff; text-align: center; }
.th-service-detail-cta h2 { max-width: 920px; margin: 0 auto 32px; font-size: clamp(38px, 5vw, 78px); line-height: 1.04; }
.th-projects-page { background: var(--th-bg); color: var(--th-ink); }
.th-projects-page h1,
.th-projects-page h2,
.th-projects-page h3 { font-family: var(--th-serif); letter-spacing: 0; font-weight: 500; color: inherit; }
.th-projects-hero { min-height: 78svh; display: grid; align-items: end; padding: 152px 0 88px; color: #fff; background-image: linear-gradient(90deg, rgba(0,0,0,.78), rgba(0,0,0,.24)), var(--projects-hero); background-size: cover; background-position: center; position: relative; isolation: isolate; }
.th-projects-hero:after { content: ""; position: absolute; inset: auto 0 0; z-index: -1; height: 42%; background: linear-gradient(transparent, rgba(0,0,0,.6)); }
.th-projects-hero h1 { max-width: 1020px; margin: 0; font-size: clamp(54px, 8vw, 124px); line-height: .94; }
.th-projects-hero p:not(.th-eyebrow) { max-width: 700px; margin: 28px 0 34px; color: rgba(255,255,255,.78); font-size: clamp(18px, 2vw, 24px); line-height: 1.65; }
.th-projects-intro { display: grid; grid-template-columns: .95fr .78fr; gap: clamp(34px, 7vw, 96px); padding-block: var(--th-space); border-bottom: 1px solid var(--th-border); }
.th-projects-intro h2 { margin: 0; font-size: clamp(38px, 5vw, 74px); line-height: 1.04; }
.th-projects-intro p { margin: 0; padding: 0; color: var(--th-muted); font-size: 17px; line-height: 1.85; }
.th-projects-intro__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 34px; padding-top: 26px; border-top: 1px solid var(--th-border); }
.th-projects-intro__stats strong { font-family: var(--th-serif); font-size: clamp(30px, 4vw, 52px); font-weight: 500; }
.th-projects-intro__stats span { display: block; margin-top: 8px; color: var(--th-muted); font-family: var(--th-sans); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; }
.th-project-gallery { padding-block: var(--th-space); background: #fff; }
.th-project-page-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 260px; gap: 18px; }
.th-project-page-card { position: relative; overflow: hidden; background: #111; color: #fff; }
.th-project-page-card.is-large { grid-column: span 2; grid-row: span 2; }
.th-project-page-card.is-wide { grid-column: span 2; }
.th-project-page-card img { transition: transform .8s ease, opacity .4s ease; opacity: .84; }
.th-project-page-card:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 34%, rgba(0,0,0,.82)); }
.th-project-page-card span { position: absolute; z-index: 1; left: 24px; right: 24px; bottom: 24px; transform: translateY(12px); opacity: 0; transition: opacity .3s ease, transform .3s ease; }
.th-project-page-card small { display: block; color: var(--th-gold); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 8px; }
.th-project-page-card strong { display: block; font-family: var(--th-serif); font-size: clamp(28px, 3vw, 46px); font-weight: 500; line-height: 1.04; }
.th-project-page-card:hover img { transform: scale(1.07); opacity: 1; }
.th-project-page-card:hover span,
.th-project-page-card:focus span { opacity: 1; transform: none; }
.th-project-page-card.is-hidden { display: none; }
.th-project-cta { padding-block: var(--th-space); background: var(--th-black); color: #fff; text-align: center; }
.th-project-cta h2 { max-width: 900px; margin: 0 auto 32px; font-size: clamp(38px, 5vw, 78px); line-height: 1.04; }
.th-archive-project-card { display: grid; grid-template-columns: 420px minmax(0, 1fr); gap: 34px; align-items: stretch; margin: 0 0 34px; padding: 0; background: #fff; border: 1px solid var(--th-border); overflow: hidden; }
.th-archive-project-card__image { min-height: 320px; overflow: hidden; background: #ddd; }
.th-archive-project-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s ease; }
.th-archive-project-card:hover .th-archive-project-card__image img { transform: scale(1.06); }
.th-archive-project-card__content { padding: clamp(28px, 4vw, 52px); }
.th-archive-project-card__content h2 { margin: 0; font-size: clamp(32px, 4vw, 54px); line-height: 1.04; font-family: var(--th-serif); letter-spacing: 0; }
.th-archive-project-card__content h2 a { color: var(--th-ink); }
.th-archive-project-card__content p:not(.th-eyebrow) { margin: 20px 0 28px; padding: 0; color: var(--th-muted); font-size: 17px; line-height: 1.75; }
.th-project-detail { background: var(--th-bg); color: var(--th-ink); }
.th-project-detail h1,
.th-project-detail h2,
.th-project-detail h3 { font-family: var(--th-serif); letter-spacing: 0; font-weight: 500; color: inherit; }
.th-project-detail-hero { min-height: 82svh; display: grid; align-items: end; padding: 152px 0 88px; color: #fff; background-image: linear-gradient(90deg, rgba(0,0,0,.78), rgba(0,0,0,.2)), var(--project-detail-hero); background-size: cover; background-position: center; position: relative; isolation: isolate; }
.th-project-detail-hero:after { content: ""; position: absolute; inset: auto 0 0; z-index: -1; height: 44%; background: linear-gradient(transparent, rgba(0,0,0,.62)); }
.th-project-detail-hero h1 { max-width: 1050px; margin: 0; font-size: clamp(54px, 8vw, 124px); line-height: .94; }
.th-project-detail-hero p:not(.th-eyebrow) { max-width: 740px; margin: 28px 0 34px; color: rgba(255,255,255,.78); font-size: clamp(18px, 2vw, 24px); line-height: 1.65; }
.th-project-detail-meta { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--th-border); border: 1px solid var(--th-border); margin-top: -44px; position: relative; z-index: 2; }
.th-project-detail-meta div { background: #fff; padding: clamp(22px, 3vw, 36px); }
.th-project-detail-meta span { display: block; color: var(--th-gold-dark); font-size: 11px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; margin-bottom: 10px; }
.th-project-detail-meta strong { font-family: var(--th-serif); font-size: clamp(24px, 3vw, 38px); font-weight: 500; color: var(--th-ink); }
.th-project-detail-story { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: clamp(36px, 7vw, 92px); padding-block: var(--th-space); align-items: start; }
.th-project-detail-content { background: #fff; border: 1px solid var(--th-border); padding: clamp(34px, 6vw, 84px); }
.th-project-detail-content h2 { margin: 0 0 24px; font-size: clamp(38px, 5vw, 74px); line-height: 1.04; }
.th-project-detail-content p,
.th-project-detail-content li { color: var(--th-muted); font-size: 18px; line-height: 1.85; }
.th-project-detail-content p { padding: 0; margin: 0 0 24px; }
.th-project-detail-content img { height: auto; margin: 34px 0; }
.th-project-detail-aside { position: sticky; top: 120px; background: var(--th-black); color: #fff; padding: 34px; }
.th-project-detail-aside h2 { margin: 0 0 24px; font-size: 40px; }
.th-project-detail-aside ul { display: grid; gap: 14px; margin: 0 0 30px; padding: 0; list-style: none; }
.th-project-detail-aside li { position: relative; padding-left: 24px; color: rgba(255,255,255,.7); line-height: 1.65; }
.th-project-detail-aside li:before { content: ""; position: absolute; left: 0; top: .82em; width: 10px; height: 1px; background: var(--th-gold); }
.th-project-detail-gallery { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 340px; gap: 18px; padding-bottom: var(--th-space); }
.th-project-detail-gallery a { display: block; overflow: hidden; background: #ddd; }
.th-project-detail-gallery a.is-wide { grid-column: span 2; grid-row: span 2; }
.th-project-detail-gallery img { transition: transform .7s ease; }
.th-project-detail-gallery a:hover img { transform: scale(1.05); }
.th-project-detail-process { padding-block: var(--th-space); background: #eee9e2; }
.th-project-detail-process__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(0,0,0,.1); border: 1px solid rgba(0,0,0,.1); }
.th-project-detail-process__grid article { background: var(--th-bg); padding: clamp(30px, 4vw, 52px); }
.th-project-detail-process__grid span { display: block; color: var(--th-gold-dark); font-weight: 800; letter-spacing: .2em; margin-bottom: 20px; }
.th-project-detail-process__grid h3 { margin: 0; font-size: 38px; }
.th-project-detail-process__grid p { margin: 14px 0 0; padding: 0; color: var(--th-muted); line-height: 1.7; }
.th-project-detail-related { padding-block: var(--th-space); }
.th-project-detail-related__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.th-related-project { position: relative; height: 430px; overflow: hidden; background: #111; color: #fff; }
.th-related-project img { opacity: .82; transition: transform .7s ease, opacity .4s ease; }
.th-related-project span { position: absolute; left: 24px; right: 24px; bottom: 24px; font-family: var(--th-serif); font-size: 34px; line-height: 1.05; }
.th-related-project:hover img { transform: scale(1.06); opacity: 1; }
.th-project-detail-cta { padding-block: var(--th-space); background: var(--th-black); color: #fff; text-align: center; }
.th-project-detail-cta h2 { max-width: 920px; margin: 0 auto 32px; font-size: clamp(38px, 5vw, 78px); line-height: 1.04; }
.th-blog-page,
.th-post-detail { background: var(--th-bg); color: var(--th-ink); }
.th-blog-page img,
.th-post-detail img { display: block; max-width: 100%; }
.th-blog-page h1,
.th-blog-page h2,
.th-post-detail h1,
.th-post-detail h2,
.th-post-detail h3 { font-family: var(--th-serif); letter-spacing: 0; font-weight: 500; color: inherit; }
.th-blog-hero,
.th-post-detail-hero { min-height: 68svh; display: grid; align-items: end; padding: 152px 0 84px; color: #fff; background-image: linear-gradient(90deg, rgba(0,0,0,.78), rgba(0,0,0,.24)), var(--blog-hero); background-size: cover; background-position: center; position: relative; isolation: isolate; }
.th-post-detail-hero { background-image: linear-gradient(90deg, rgba(0,0,0,.78), rgba(0,0,0,.24)), var(--post-hero); }
.th-blog-hero:after,
.th-post-detail-hero:after { content: ""; position: absolute; inset: auto 0 0; z-index: -1; height: 42%; background: linear-gradient(transparent, rgba(0,0,0,.62)); }
.th-blog-hero h1,
.th-post-detail-hero h1 { max-width: 1040px; margin: 0; font-size: clamp(22px, 8vw, 38px); line-height: 1.4; }
.th-blog-hero p:not(.th-eyebrow),
.th-post-detail-hero p:not(.th-eyebrow) { max-width: 720px; margin: 28px 0 0; padding: 0; color: rgba(255,255,255,.78); font-size: clamp(18px, 2vw, 24px); line-height: 1.65; }
.th-blog-featured { padding-block: var(--th-space); }
.th-featured-post { display: grid; grid-template-columns: 1.2fr .82fr; min-height: 560px; background: #111; color: #fff; overflow: hidden; }
.th-featured-post img { width: 100%; height: 100%; object-fit: cover; opacity: .9; transition: transform .8s ease; }
.th-featured-post span { display: flex; flex-direction: column; justify-content: center; padding: clamp(32px, 6vw, 78px); background: var(--th-black); }
.th-featured-post small { color: var(--th-gold); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 18px; }
.th-featured-post strong { font-family: var(--th-serif); font-size: clamp(18px, 5vw, 22px); line-height: 1.42; font-weight: 500; }
.th-featured-post em { margin-top: 28px; color: #fff; font-style: normal; border-bottom: 1px solid var(--th-gold); width: max-content; padding-bottom: 6px; }
.th-featured-post:hover img { transform: scale(1.05); }
.th-blog-listing { padding-bottom: var(--th-space); background: #fff; padding-top: var(--th-space);}
.th-blog-page-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.th-post-card { background: var(--th-bg); border: 1px solid var(--th-border); overflow: hidden; }
.th-post-card__image { display: block; height: 300px; overflow: hidden; background: #ddd; }
.th-post-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s ease; }
.th-post-card:hover .th-post-card__image img { transform: scale(1.06); }
.th-post-card__content { padding: 28px; }
.th-post-card__content small { display: block; color: var(--th-gold-dark); font-size: 11px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; margin-bottom: 14px; }
.th-post-card__content h2 { margin: 0; font-size: clamp(28px, 3vw, 42px); line-height: 1.08; }
.th-post-card__content h2 a { color: var(--th-ink); }
.th-post-card__content p { margin: 18px 0 24px; padding: 0; color: var(--th-muted); line-height: 1.75; }
.th-pagination { grid-column: 1 / -1; margin-top: 24px; }
.th-blog-cta { padding-block: var(--th-space); background: var(--th-black); color: #fff; text-align: center; }
.th-blog-cta h2 { max-width: 900px; margin: 0 auto 32px; font-size: clamp(38px, 5vw, 78px); line-height: 1.04; }
.th-post-detail-body { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: clamp(36px, 7vw, 88px); padding-block: var(--th-space); align-items: start; }
.th-post-detail-content { background: #fff; border: 1px solid var(--th-border); padding: clamp(34px, 6vw, 86px); }
.th-post-detail-content[data-reveal] { opacity: 1; transform: none; }
.th-post-detail-content h2 { margin: 36px 0 20px; font-size: clamp(34px, 4vw, 58px); line-height: 1.08; }
.th-post-detail-content h3 { margin: 30px 0 16px; font-size: clamp(26px, 3vw, 38px); }
.th-post-detail-content p,
.th-post-detail-content li { color: var(--th-muted); font-size: 18px; line-height: 1.9; }
.th-post-detail-content p { padding: 0; margin: 0 0 24px; }
.th-post-detail-content img { height: auto; margin: 34px 0; }
.th-post-detail-content .th-post-media-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin: 34px 0; }
.th-post-detail-content .th-post-media-grid + .th-post-media-grid { margin-top: -16px; }
.th-post-detail-content .th-post-media-item { position: relative; display: block; overflow: hidden; margin: 0; background: #e8e2d8; cursor: zoom-in; }
.th-post-detail-content .th-post-media-item:nth-child(3n + 1) { grid-column: span 2; }
.th-post-detail-content .th-post-media-item:after { content: "Xem ảnh"; position: absolute; left: 16px; bottom: 16px; padding: 8px 11px; background: rgba(26,26,26,.78); color: #fff; font-size: 11px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; opacity: 0; transform: translateY(8px); transition: opacity .25s ease, transform .25s ease; }
.th-post-detail-content .th-post-media-item img { width: 100%; height: 100%; min-height: 360px; max-height: 640px; object-fit: cover; margin: 0; transition: transform .75s ease, filter .35s ease; }
.th-post-detail-content .th-post-media-item:hover img { transform: scale(1.045); filter: saturate(1.04); }
.th-post-detail-content .th-post-media-item:hover:after { opacity: 1; transform: none; }
.th-post-detail-content .th-post-media-item a { display: block; height: 100%; }
.th-post-detail-content .th-post-media-item figcaption { position: absolute; left: 0; right: 0; bottom: 0; margin: 0; padding: 42px 18px 16px; background: linear-gradient(transparent, rgba(0,0,0,.62)); color: #fff; font-size: 13px; line-height: 1.5; }
.th-post-lightbox { position: fixed; inset: 0; z-index: 2200; display: grid; place-items: center; padding: 32px; background: rgba(12,11,10,.9); opacity: 0; pointer-events: none; transition: opacity .24s ease; }
.th-post-lightbox.is-open { opacity: 1; pointer-events: auto; }
.th-post-lightbox img { display: block; max-width: min(100%, 1180px); max-height: calc(100svh - 96px); object-fit: contain; box-shadow: 0 28px 90px rgba(0,0,0,.45); }
.th-post-lightbox button { position: fixed; top: 18px; right: 18px; display: grid; place-items: center; width: 46px; height: 46px; border: 1px solid rgba(255,255,255,.24); border-radius: 50%; background: rgba(255,255,255,.08); color: #fff; font-size: 30px; line-height: 1; padding: 0; cursor: pointer; }
.th-post-lightbox button:hover { background: var(--th-gold); color: #111; }
.th-post-detail-aside { position: sticky; top: 120px; display: grid; gap: 22px; }
.th-post-detail-aside > div { background: #fff; border: 1px solid var(--th-border); padding: 28px; }
.th-post-detail-aside a { display: block; color: var(--th-ink); padding: 13px 0; border-bottom: 1px solid var(--th-border); font-weight: 800; }
.th-post-advice { background: var(--th-black) !important; color: #fff; }
.th-post-advice h2 { margin: 0; font-size: 34px; line-height: 1.05; }
.th-post-advice p { margin: 16px 0 24px; padding: 0; color: rgba(255,255,255,.68); }
.th-post-related { padding-bottom: var(--th-space); }

.th-contact-page { background: var(--th-bg); color: var(--th-ink); }
.th-contact-page h1,
.th-contact-page h2,
.th-contact-page h3 { font-family: var(--th-serif); letter-spacing: 0; font-weight: 500; color: inherit; }
.th-contact-hero { min-height: 74svh; display: grid; align-items: end; padding: 152px 0 88px; color: #fff; background-image: linear-gradient(90deg, rgba(0,0,0,.82), rgba(0,0,0,.38) 54%, rgba(0,0,0,.18)), var(--contact-hero); background-size: cover; background-position: center; position: relative; isolation: isolate; }
.th-contact-hero:after { content: ""; position: absolute; inset: auto 0 0; z-index: -1; height: 42%; background: linear-gradient(transparent, rgba(0,0,0,.62)); }
.th-contact-hero h1 { max-width: 980px; margin: 0; font-size: clamp(50px, 7vw, 104px); line-height: .98; }
.th-contact-hero p:not(.th-eyebrow) { max-width: 720px; margin: 28px 0 34px; padding: 0; color: rgba(255,255,255,.82); font-size: clamp(18px, 2vw, 24px); line-height: 1.65; }
.th-contact-info { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; margin-top: -54px; position: relative; z-index: 2; background: var(--th-border); border: 1px solid var(--th-border); }
.th-contact-info article { min-height: 220px; background: #fff; padding: clamp(28px, 4vw, 46px); }
.th-contact-info i { color: var(--th-gold-dark); font-size: 28px; margin-bottom: 24px; }
.th-contact-info span { display: block; margin-bottom: 12px; color: var(--th-gold-dark); font-size: 12px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; }
.th-contact-info a,
.th-contact-info p { color: var(--th-ink); font-size: clamp(18px, 2vw, 24px); line-height: 1.45; margin: 0; padding: 0; font-family: var(--th-serif); }
.th-contact-main { padding-block: var(--th-space); }
.th-contact-main__grid { display: grid; grid-template-columns: minmax(0, .82fr) minmax(420px, 1fr); gap: clamp(36px, 7vw, 92px); align-items: start; }
.th-contact-main__copy h2 { margin: 0; font-size: clamp(38px, 5vw, 76px); line-height: 1.04; }
.th-contact-main__copy p:not(.th-eyebrow) { margin: 26px 0 30px; padding: 0; color: var(--th-muted); font-size: 17px; line-height: 1.85; }
.th-contact-main__copy ul { display: grid; gap: 14px; margin: 0; padding: 0; list-style: none; }
.th-contact-main__copy li { position: relative; padding-left: 28px; color: var(--th-ink); font-weight: 800; line-height: 1.6; }
.th-contact-main__copy li:before { content: ""; position: absolute; left: 0; top: .78em; width: 12px; height: 1px; background: var(--th-gold-dark); }
.th-contact-form { background: linear-gradient(145deg, #fffaf2 0%, #f7f2ea 58%, #ffffff 100%); border: 1px solid rgba(200,169,126,.28); padding: clamp(28px, 5vw, 54px); box-shadow: 0 26px 80px rgba(26,26,26,.08); }
.th-contact-form .wpcf7 { color: var(--th-ink); }
.th-contact-form .wpcf7 form p { margin: 0 0 14px; padding: 0; color: #4c463e !important; font-size: 14px; font-weight: 800; line-height: 1.5; }
.th-contact-form .wpcf7 label { color: #4c463e !important; font-size: 14px; font-weight: 800; }
.th-contact-form .wpcf7-form-control-wrap { display: block; }
.th-contact-form input:not([type="submit"]),
.th-contact-form textarea,
.th-contact-form select { width: 100%; min-height: 54px; margin: 6px 0 0; background: rgba(255,255,255,.96) !important; border: 1px solid rgba(26,26,26,.18) !important; color: #1f1d1a !important; outline: none; box-shadow: inset 0 1px 0 rgba(255,255,255,.7); transition: border-color .25s ease, box-shadow .25s ease, background .25s ease; }
.th-contact-form textarea { height: 150px !important; min-height: 150px; resize: vertical; }
.th-contact-form input:not([type="submit"]):focus,
.th-contact-form textarea:focus,
.th-contact-form select:focus { background: #fff !important; border-color: var(--th-gold-dark) !important; box-shadow: 0 0 0 4px rgba(200,169,126,.18); }
.th-contact-form input::placeholder,
.th-contact-form textarea::placeholder { color: #8d867c; opacity: 1; }
.th-contact-form .wpcf7-submit { width: 100%; min-height: 54px; margin-top: 8px; background: var(--th-black) !important; color: #fff !important; border: 1px solid var(--th-black) !important; font-size: 13px; letter-spacing: .12em; text-transform: uppercase; font-weight: 800; box-shadow: 0 14px 34px rgba(26,26,26,.16); transition: background .25s ease, border-color .25s ease, transform .25s ease, box-shadow .25s ease; }
.th-contact-form .wpcf7-submit:hover { background: var(--th-gold-dark) !important; border-color: var(--th-gold-dark) !important; color: #fff !important; transform: translateY(-2px); box-shadow: 0 18px 42px rgba(176,139,91,.24); }
.th-contact-form .wpcf7-spinner { display: block; margin: 12px auto 0; }
.th-contact-form .wpcf7-not-valid-tip { margin-top: 6px; color: #9f3b28; font-size: 13px; font-weight: 700; }
.th-contact-form .wpcf7-response-output { margin: 16px 0 0 !important; padding: 12px 14px !important; border-color: rgba(176,139,91,.36) !important; background: rgba(255,255,255,.76); color: var(--th-ink); font-size: 14px; line-height: 1.5; }
.th-contact-map { padding-bottom: var(--th-space); }
.th-contact-map iframe { display: block; width: 100%; height: clamp(360px, 42vw, 560px); border: 0; filter: grayscale(.72) contrast(1.05); }

@keyframes th-kenburns { from { transform: scale(1); } to { transform: scale(1.08); } }
@keyframes th-scroll { 0% { transform: translate(-50%, 0); opacity: 1; } 100% { transform: translate(-50%, 18px); opacity: 0; } }
@keyframes th-fade { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

@media (max-width: 1100px) {
	.th-header__inner { grid-template-columns: 190px 1fr; height: 78px; }
	.th-header__brand img { max-width: 184px; }
	.th-menu-toggle { display: inline-flex; flex-direction: column; justify-content: center; gap: 8px; justify-self: end; width: 48px; height: 48px; border: 1px solid rgba(255,255,255,.24); background: rgba(0,0,0,.16); padding: 0 12px; }
	.th-menu-toggle span { height: 2px; background: #fff; }
	.th-header.is-scrolled .th-menu-toggle span { background: var(--th-ink); }
	.th-header__nav { position: fixed; inset: 0; min-height: 100svh; background: rgba(26,26,26,.96); backdrop-filter: blur(20px); display: grid; place-content: center; gap: 30px; transform: translateX(100%); transition: transform .36s ease; }
	.th-header__nav.is-open { transform: none; }
	.th-menu-close { position: fixed; top: 18px; right: 18px; z-index: 2; display: grid; place-items: center; width: 46px; height: 46px; border: 1px solid rgba(255,255,255,.28); border-radius: 50%; background: rgba(255,255,255,.06); color: #fff; font-size: 30px; line-height: 1; padding: 0; }
	.th-menu-close:hover { background: var(--th-gold); color: #111; }
	.th-menu { flex-direction: column; gap: 22px; }
	.th-menu li { text-align: center; }
	.th-menu a, .th-header.is-scrolled .th-menu a { color: #fff; font-size: 18px; }
	.th-menu .menu-item-has-children > a:after { width: 7px; height: 7px; margin-left: 10px; transform: translateY(-4px) rotate(45deg); }
	.th-menu .sub-menu { position: static; min-width: 0; margin: 12px 0 0; padding: 0; background: transparent; border: 0; box-shadow: none; backdrop-filter: none; opacity: 1; visibility: visible; transform: none; }
	.th-menu .sub-menu:before { display: none; }
	.th-menu .sub-menu a { padding: 7px 0; color: rgba(255,255,255,.68) !important; font-size: 13px; letter-spacing: .14em; }
	.th-menu .sub-menu a:hover,
	.th-menu .sub-menu a:focus { background: transparent; color: var(--th-gold) !important; }
	.th-service-grid, .th-feature-grid { grid-template-columns: repeat(2, 1fr); }
	.th-masonry { grid-template-columns: repeat(2, 1fr); }
	.th-footer__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 760px) {
	.th-container { width: min(calc(100% - 28px), var(--th-max)); }
	.th-section { padding-block: 76px; }
	.th-home h1 { font-size: clamp(48px, 15vw, 66px); }
	.th-home h2 { font-size: clamp(34px, 10vw, 48px); }
	.th-hero { min-height: 92svh; }
	.th-hero__meta, .th-scroll { display: none; }
	.th-actions { align-items: stretch; flex-direction: column; max-width: 280px; }
	.th-about, .th-compare { grid-template-columns: 1fr; }
	.th-about__image { height: 430px; }
	.th-about__stats, .th-stats .th-container { grid-template-columns: 1fr 1fr; }
	.th-section__head--split { display: block; }
	.th-filters { justify-content: flex-start; margin-top: 24px; }
	.th-service-grid, .th-feature-grid, .th-blog-grid, .th-footer__grid { grid-template-columns: 1fr; }
	.th-service-card { min-height: 420px; }
	.th-masonry { display: block; }
	.th-project-card { display: block; height: 420px; margin-bottom: 16px; }
	.th-project-card.wide, .th-project-card.tall { grid-column: auto; grid-row: auto; }
	.th-project-card span { opacity: 1; transform: none; }
	.th-timeline { display: block; }
	.th-timeline li { border-top: 0; border-left: 1px solid rgba(0,0,0,.18); padding: 0 0 30px 28px; }
	.th-timeline li:before { top: 4px; left: -5px; }
	.th-cta { background-attachment: scroll; min-height: 460px; }
	.th-footer__bottom { display: block; }
	.th-mobile-cta { position: fixed; z-index: 900; left: 0; right: 0; bottom: 0; display: grid; grid-template-columns: 1fr 1fr; background: #111; box-shadow: 0 -12px 40px rgba(0,0,0,.2); }
	.th-mobile-cta a, .th-mobile-cta button { min-height: 56px; border: 0; display: grid; place-items: center; color: #fff; background: #111; font-weight: 800; letter-spacing: .04em; }
	.th-mobile-cta button { background: var(--th-gold); color: #111; }
	.th-inquiry { top: 78px; z-index: 990; align-items: end; }
	.th-inquiry__panel { width: 100%; max-height: calc(100svh - 78px); padding: 34px 22px 28px; border-inline: 0; }
	.th-inquiry__panel:before { inset: 10px; }
	.th-inquiry__panel h2 { font-size: clamp(34px, 11vw, 46px); margin-bottom: 22px; }
	.th-inquiry input:not([type="submit"]), .th-inquiry textarea, .th-inquiry select { min-height: 50px; }
	.th-inquiry textarea { min-height: 130px; }
	.page-scroll-up { z-index: 800 !important; }
	.th-inquiry.is-open ~ .page-scroll-up { display: none; }
	body { padding-bottom: 56px; }
	.box-action { bottom: 76px !important; left: 18px !important; }
	.th-services-hero { min-height: 68svh; padding: 128px 0 64px; }
	.th-services-hero h1 { font-size: clamp(44px, 14vw, 64px); }
	.th-service-intro { grid-template-columns: 1fr; padding-block: 74px; }
	.th-service-catalog { padding-block: 74px; }
	.th-service-row,
	.th-service-row:nth-child(even) { display: block; min-height: 0; }
	.th-service-row:nth-child(even) .th-service-row__image { order: initial; }
	.th-service-row__image { height: 320px; }
	.th-service-row__content { padding: 30px 22px 34px; }
	.th-service-row__content h3 { font-size: 36px; }
	.th-service-row__meta { margin-bottom: 26px; }
	.th-archive-service-card { display: block; }
	.th-archive-service-card__image { height: 280px; }
	.th-service-detail-hero { min-height: 68svh; padding: 128px 0 64px; }
	.th-service-detail-hero h1 { font-size: clamp(44px, 14vw, 64px); }
	.th-service-detail-body { grid-template-columns: 1fr; padding-block: 74px; }
	.th-service-detail-aside { position: static; }
	.th-service-detail-content { padding: 30px 22px; }
	.th-detail-steps,
	.th-related-services__grid { grid-template-columns: 1fr; }
	.th-related-service { height: 340px; }
	.th-projects-hero { min-height: 68svh; padding: 128px 0 64px; }
	.th-projects-hero h1 { font-size: clamp(44px, 14vw, 66px); }
	.th-projects-intro { grid-template-columns: 1fr; padding-block: 74px; }
	.th-projects-intro__stats { grid-template-columns: 1fr 1fr; }
	.th-project-gallery { padding-block: 74px; }
	.th-project-page-grid { display: block; }
	.th-project-page-card,
	.th-project-page-card.is-large,
	.th-project-page-card.is-wide { display: block; height: 380px; margin-bottom: 16px; }
	.th-project-page-card span { opacity: 1; transform: none; }
	.th-archive-project-card { display: block; }
	.th-archive-project-card__image { height: 300px; }
	.th-project-detail-hero { min-height: 72svh; padding: 128px 0 64px; }
	.th-project-detail-hero h1 { font-size: clamp(44px, 14vw, 66px); }
	.th-project-detail-meta { grid-template-columns: 1fr 1fr; margin-top: 0; }
	.th-project-detail-story { grid-template-columns: 1fr; padding-block: 74px; }
	.th-project-detail-aside { position: static; }
	.th-project-detail-content { padding: 30px 22px; }
	.th-project-detail-gallery { display: block; padding-bottom: 74px; }
	.th-project-detail-gallery a,
	.th-project-detail-gallery a.is-wide { display: block; height: 340px; margin-bottom: 16px; }
	.th-project-detail-process__grid,
	.th-project-detail-related__grid { grid-template-columns: 1fr; }
	.th-related-project { height: 340px; }
	.th-blog-hero,
	.th-post-detail-hero { min-height: 62svh; padding: 128px 0 64px; }
	.th-blog-hero h1,
	.th-post-detail-hero h1 { font-size: clamp(44px, 14vw, 66px); }
	.th-featured-post { display: block; min-height: 0; }
	.th-featured-post img { height: 320px; object-fit: cover; }
	.th-blog-page-grid { grid-template-columns: 1fr; }
	.th-post-card__image { height: 280px; }
	.th-post-detail-body { grid-template-columns: 1fr; padding-block: 74px; }
	.th-post-detail-content { padding: 30px 22px; }
	.th-post-detail-content .th-post-media-grid { grid-template-columns: 1fr; gap: 14px; margin: 26px 0; }
	.th-post-detail-content .th-post-media-item:nth-child(3n + 1) { grid-column: auto; }
	.th-post-detail-content .th-post-media-item img { min-height: 260px; max-height: 420px; }
	.th-post-lightbox { padding: 18px; }
	.th-post-lightbox img { max-height: calc(100svh - 78px); }
	.th-post-detail-aside { position: static; }
	.th-contact-hero { min-height: 68svh; padding: 128px 0 64px; }
	.th-contact-hero h1 { font-size: clamp(44px, 14vw, 66px); }
	.th-contact-info { grid-template-columns: 1fr; margin-top: 0; }
	.th-contact-info article { min-height: 0; }
	.th-contact-main { padding-block: 74px; }
	.th-contact-main__grid { grid-template-columns: 1fr; }
	.th-contact-form { padding: 28px 22px; }
	.th-contact-form textarea { height: 130px !important; min-height: 130px; }
	.th-contact-map { padding-bottom: 74px; }
}
