*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --tk-red: #ED193A;
  --tk-red-dark: #C01130;
  --tk-red-deep: #8A0A20;
  --tk-navy: #262261;
  --tk-navy-dark: #1A1745;
  --tk-navy-light: #3530A0;
  --tk-gray: #4C4C4E;
  --tk-gray-light: #7A7A7C;
  --black: #0A0A10;
  --dark: #0F0F1A;
  --dark-navy: #111128;
  --white: #ffffff;
  --off-white: #F4F4F8;
  --light-gray: #EBEBF0;
  --glass: rgba(255,255,255,0.04);
  --glass-border: rgba(255,255,255,0.10);
  --font-display: 'Barlow Condensed', sans-serif;
  --font-body: 'Barlow', sans-serif;
  --font-script: 'Cormorant Garamond', serif;
  --radius: 10px;
  --transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

html { scroll-behavior: smooth; }
body { font-family: var(--font-body); background: var(--black); color: var(--white); overflow-x: hidden; }
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
section { position: relative; overflow: hidden; }
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--dark); }
::-webkit-scrollbar-thumb { background: var(--tk-red); border-radius: 3px; }
.screen-reader-text { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

.container { max-width: 1300px; margin: 0 auto; padding: 0 28px; }
.section-label { font-family: var(--font-body); font-size: 11px; font-weight: 600; letter-spacing: 4px; text-transform: uppercase; color: var(--tk-red); display: flex; align-items: center; gap: 14px; margin-bottom: 14px; }
.section-label::before, .section-label::after { content: ''; flex: none; width: 24px; height: 1.5px; background: var(--tk-red); }
.section-label.light { color: rgba(255,255,255,0.5); }
.section-label.light::before, .section-label.light::after { background: rgba(255,255,255,0.3); }
.section-title { font-family: var(--font-display); font-size: clamp(42px, 6vw, 82px); font-weight: 800; line-height: 0.95; letter-spacing: 1px; text-transform: uppercase; }
.tk-red { color: var(--tk-red); }
.tk-navy { color: var(--tk-navy-light); }
.section-copy-light, .section-copy-dark { margin-top: 12px; font-size: 15px; line-height: 1.8; max-width: 520px; margin-left: auto; margin-right: auto; }
.section-copy-light, .section-copy-dark { color: rgba(255,255,255,0.38); }
.section-center { text-align: center; margin-bottom: 60px; }

.btn { display: inline-flex; align-items: center; gap: 10px; padding: 15px 36px; border-radius: 2px; font-family: var(--font-body); font-size: 12px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; cursor: pointer; border: none; transition: var(--transition); position: relative; overflow: hidden; }
.btn::after { content: ''; position: absolute; inset: 0; background: rgba(255,255,255,0.12); transform: translateX(-105%); transition: transform 0.4s ease; }
.btn:hover::after { transform: translateX(0); }
.btn-red { background: var(--tk-red); color: var(--white); box-shadow: 0 4px 20px rgba(237,25,58,0.35); }
.btn-red:hover { background: var(--tk-red-dark); transform: translateY(-2px); box-shadow: 0 10px 30px rgba(237,25,58,0.45); }
.btn-outline-white { background: transparent; color: var(--white); border: 1.5px solid rgba(255,255,255,0.35); }
.btn-outline-white:hover { border-color: var(--white); transform: translateY(-2px); }

.bg-shape { position: absolute; border-radius: 50%; filter: blur(90px); pointer-events: none; z-index: 0; animation: drift 12s ease-in-out infinite; }
@keyframes drift { 0%,100% { transform: translate(0,0); } 33% { transform: translate(25px,-35px); } 66% { transform: translate(-20px,25px); } }

#navbar { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; padding: 22px 0; transition: var(--transition); }
#navbar.scrolled { background: rgba(10,10,16,0.92); backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px); border-bottom: 1px solid rgba(237,25,58,0.15); padding: 14px 0; box-shadow: 0 4px 40px rgba(0,0,0,0.6); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; }
.nav-logo-wrap { display: flex; align-items: center; gap: 14px; cursor: pointer; }
.nav-logo-icon { width: 48px; height: 26px; flex-shrink: 0; }
.nav-logo-image { max-width: 96px; max-height: 44px; width: auto; height: auto; flex-shrink: 0; object-fit: contain; display: block; }
.nav-logo-text { display: flex; flex-direction: column; line-height: 1; }
.nav-logo-name { font-family: var(--font-display); font-weight: 800; font-size: 20px; letter-spacing: 3px; text-transform: uppercase; color: var(--white); }
.nav-logo-sub { font-family: var(--font-body); font-size: 8px; letter-spacing: 4px; text-transform: uppercase; color: var(--tk-gray-light); font-weight: 500; margin-top: 3px; }
.nav-links, .mobile-menu-links { display: flex; align-items: center; gap: 38px; }
.nav-links a { font-family: var(--font-body); font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.65); transition: color 0.3s; position: relative; }
.nav-links a::after { content: ''; position: absolute; bottom: -5px; left: 0; width: 0; height: 1.5px; background: var(--tk-red); transition: width 0.3s; }
.nav-links a:hover { color: var(--white); }
.nav-links a:hover::after { width: 100%; }
.nav-cta { padding: 11px 26px; font-size: 11px; }
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; background: transparent; border: 0; }
.hamburger span { width: 24px; height: 1.5px; background: var(--white); transition: var(--transition); display: block; }
.hamburger.active span:nth-child(1) { transform: rotate(45deg) translate(4px, 5px); }
.hamburger.active span:nth-child(2) { opacity: 0; }
.hamburger.active span:nth-child(3) { transform: rotate(-45deg) translate(4px, -5px); }
.mobile-menu { display: none; position: fixed; inset: 0; background: rgba(10,10,16,0.98); z-index: 999; flex-direction: column; align-items: center; justify-content: center; gap: 32px; }
.mobile-menu.open { display: flex; }
.mobile-menu-links { flex-direction: column; justify-content: center; }
.mobile-menu a { font-family: var(--font-display); font-size: 44px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: var(--white); transition: color 0.3s; }
.mobile-menu a:hover { color: var(--tk-red); }
.mobile-close { position: absolute; top: 26px; right: 28px; font-size: 28px; cursor: pointer; color: rgba(255,255,255,0.6); background: transparent; border: 0; }

#hero { min-height: 100vh; display: flex; align-items: flex-start; justify-content: center; position: relative; background: var(--dark); overflow: hidden; padding-top: 150px; }
.hero-canvas { position: absolute; inset: 0; z-index: 0; }
.hero-overlay { position: absolute; inset: 0; z-index: 1; background: radial-gradient(ellipse 60% 70% at 50% 55%, rgba(38,34,97,0.5) 0%, transparent 65%), radial-gradient(ellipse 40% 40% at 20% 80%, rgba(237,25,58,0.12) 0%, transparent 60%), linear-gradient(180deg, rgba(10,10,16,0.2) 0%, rgba(10,10,16,0.7) 100%); }
.hero-content { position: relative; z-index: 2; text-align: center; max-width: 1050px; padding: 0 28px; }
.hero-badge { display: inline-flex; align-items: center; gap: 10px; background: rgba(38,34,97,0.3); border: 1px solid rgba(38,34,97,0.6); border-radius: 30px; padding: 8px 22px; font-family: var(--font-body); font-size: 11px; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,0.75); margin-bottom: 30px; animation: fadeInDown 0.8s ease both; }
.hero-badge-dot { width: 7px; height: 7px; background: var(--tk-red); border-radius: 50%; animation: pulse 2s ease infinite; }
@keyframes pulse { 0%,100% { opacity:1; transform:scale(1); } 50% { opacity:0.4; transform:scale(1.5); } }
.hero-headline { font-family: var(--font-display); font-weight: 900; font-size: clamp(60px, 11.5vw, 148px); line-height: 0.88; letter-spacing: 2px; text-transform: uppercase; animation: fadeInUp 0.9s ease 0.15s both; }
.hero-headline .word-red { color: var(--tk-red); }
.hero-tagline { font-family: var(--font-script); font-style: italic; font-size: clamp(18px, 2.8vw, 28px); color: rgba(255,255,255,0.6); margin: 22px 0 16px; animation: fadeInUp 0.9s ease 0.3s both; }
.hero-desc { font-size: 15px; color: rgba(255,255,255,0.45); max-width: 500px; margin: 0 auto 44px; line-height: 1.85; font-weight: 400; animation: fadeInUp 0.9s ease 0.45s both; }
.hero-btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; animation: fadeInUp 0.9s ease 0.55s both; }
.hero-stats-bar { position: absolute; bottom: 0; left: 0; right: 0; z-index: 2; display: flex; border-top: 1px solid rgba(255,255,255,0.06); animation: fadeIn 1s ease 1s both; }
.hero-stat-item { flex: 1; text-align: center; padding: 22px 16px; border-right: 1px solid rgba(255,255,255,0.06); transition: background 0.3s; }
.hero-stat-item:last-child { border-right: none; }
.hero-stat-item:hover { background: rgba(237,25,58,0.06); }
.hero-stat-num { font-family: var(--font-display); font-size: 38px; font-weight: 800; color: var(--tk-red); line-height: 1; }
.hero-stat-label { font-size: 10px; letter-spacing: 2.5px; text-transform: uppercase; color: rgba(255,255,255,0.35); margin-top: 5px; }
.hero-scroll { position: absolute; bottom: 100px; right: 40px; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 8px; font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,0.25); writing-mode: vertical-lr; animation: fadeIn 1s ease 1.2s both; }
.hero-scroll-line { width: 1.5px; height: 50px; background: linear-gradient(to bottom, var(--tk-red), transparent); animation: scrollPulse 2s ease infinite; }
@keyframes scrollPulse { 0% { transform: scaleY(0); transform-origin: top; } 50% { transform: scaleY(1); transform-origin: top; } 51% { transform: scaleY(1); transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }
@keyframes fadeInUp { from { opacity:0; transform:translateY(32px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeInDown { from { opacity:0; transform:translateY(-20px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }

#about { padding: 130px 0; background: var(--black); }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 90px; align-items: center; }
.about-image-block { position: relative; height: 560px; }
.about-image-panel { position: relative; width: 100%; height: 100%; min-height: 420px; border-radius: var(--radius); overflow: hidden; background: linear-gradient(135deg, #1A1745 0%, #262261 60%, #3530A0 100%); box-shadow: 0 24px 60px rgba(0,0,0,0.5); border: 1px solid rgba(255,255,255,0.08); }
.about-image-panel img { width: 100%; height: 100%; object-fit: cover; }
.about-image-placeholder { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 40px; background: radial-gradient(circle at 50% 40%, rgba(237,25,58,0.18), transparent 35%); }
.about-img-card { position: absolute; border-radius: var(--radius); overflow: hidden; box-shadow: 0 24px 60px rgba(0,0,0,0.5); transition: transform 0.5s ease; }
.about-img-card:hover { z-index: 5; transform: scale(1.03) !important; }
.about-img-main { width: 64%; height: 72%; top: 0; left: 0; z-index: 2; }
.about-img-side { width: 52%; height: 55%; bottom: 0; right: 0; z-index: 3; }
.about-img-inset { width: 36%; height: 36%; top: 32%; left: 34%; z-index: 4; border: 2px solid var(--tk-red); }
.about-badge { position: absolute; z-index: 6; bottom: 22px; left: 8px; background: var(--tk-navy); backdrop-filter: blur(12px); border-radius: var(--radius); padding: 14px 20px; display: flex; align-items: center; gap: 12px; border: 1px solid rgba(38,34,97,0.6); }
.about-badge-icon { font-size: 26px; }
.about-badge-title { font-family: var(--font-display); font-size: 15px; font-weight: 700; letter-spacing: 1px; }
.about-badge-sub { font-size: 10px; color: rgba(255,255,255,0.55); letter-spacing: 1px; margin-top: 2px; }
.about-text { font-size: 15px; color: rgba(255,255,255,0.6); line-height: 1.9; margin: 22px 0 32px; font-weight: 400; }
.about-chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 32px; }
.about-chip { background: rgba(38,34,97,0.3); border: 1px solid rgba(38,34,97,0.5); border-radius: 30px; padding: 8px 18px; font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,0.7); transition: var(--transition); cursor: default; }
.about-chip:hover { background: var(--tk-navy); border-color: var(--tk-navy-light); color: var(--white); }
.about-features { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 30px; }
.about-feat { background: var(--glass); border: 1px solid var(--glass-border); border-radius: var(--radius); padding: 18px 20px; transition: var(--transition); }
.about-feat:hover { border-color: rgba(237,25,58,0.3); transform: translateY(-3px); }
.about-feat-icon { font-size: 22px; margin-bottom: 8px; }
.about-feat-title { font-family: var(--font-display); font-size: 16px; font-weight: 700; letter-spacing: 1px; margin-bottom: 4px; }
.about-feat-desc { font-size: 12px; color: rgba(255,255,255,0.45); line-height: 1.6; }

#services { padding: 130px 0; background: var(--dark-navy); }
.services-header { text-align: center; margin-bottom: 70px; }
.services-header .section-label { justify-content: center; color: rgba(255,255,255,0.5); }
.services-header .section-label::before, .services-header .section-label::after { background: rgba(255,255,255,0.25); }
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.service-card { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.07); border-radius: 14px; padding: 40px 32px; position: relative; overflow: hidden; cursor: pointer; transition: var(--transition); transform-style: preserve-3d; }
.service-card::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(237,25,58,0.06) 0%, rgba(38,34,97,0.08) 100%); opacity: 0; transition: opacity 0.4s; }
.service-card:hover::before { opacity: 1; }
.service-card:hover { border-color: rgba(237,25,58,0.3); transform: translateY(-8px); box-shadow: 0 24px 60px rgba(237,25,58,0.12), 0 0 0 1px rgba(237,25,58,0.15); }
.service-card-top-line { position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(to right, var(--tk-red), var(--tk-navy-light)); transform: scaleX(0); transform-origin: left; transition: transform 0.4s ease; }
.service-card:hover .service-card-top-line { transform: scaleX(1); }
.service-icon-wrap { width: 58px; height: 58px; background: linear-gradient(135deg, var(--tk-red), var(--tk-red-dark)); border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 26px; margin-bottom: 22px; position: relative; z-index: 1; box-shadow: 0 8px 24px rgba(237,25,58,0.3); transition: transform 0.4s ease; }
.service-card:hover .service-icon-wrap { transform: scale(1.1) rotate(-5deg); }
.service-card-title { font-family: var(--font-display); font-size: 24px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 12px; position: relative; z-index: 1; }
.service-card-desc { font-size: 13px; color: rgba(255,255,255,0.5); line-height: 1.8; position: relative; z-index: 1; }
.service-card-link { display: inline-flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--tk-red); margin-top: 18px; position: relative; z-index: 1; transition: gap 0.3s; }
.service-card:hover .service-card-link { gap: 14px; }
.service-card-num { position: absolute; right: 22px; bottom: 16px; font-family: var(--font-display); font-size: 70px; font-weight: 900; color: rgba(255,255,255,0.025); line-height: 1; letter-spacing: 2px; }

#service-details { padding: 110px 0; background: var(--off-white); }
.details-header { text-align: center; margin-bottom: 60px; }
.details-header .section-label { justify-content: center; }
.details-header .section-title { color: var(--black); }
.details-sub { color: var(--tk-gray); font-size: 15px; max-width: 480px; margin: 14px auto 0; line-height: 1.8; }
.details-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.detail-card { background: var(--white); border-radius: var(--radius); padding: 30px 22px; text-align: center; box-shadow: 0 2px 16px rgba(0,0,0,0.06); border-bottom: 3px solid transparent; transition: var(--transition); cursor: pointer; }
.detail-card:hover { transform: translateY(-6px); border-bottom-color: var(--tk-red); box-shadow: 0 14px 40px rgba(0,0,0,0.1); }
.detail-card-icon { width: 68px; height: 68px; background: linear-gradient(135deg, #FDE8EC, #FBD0D8); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 28px; margin: 0 auto 16px; transition: var(--transition); }
.detail-card:hover .detail-card-icon { background: linear-gradient(135deg, var(--tk-red), var(--tk-red-dark)); color: var(--white); }
.detail-card-title { font-family: var(--font-display); font-size: 18px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: var(--black); margin-bottom: 9px; }
.detail-card-desc { font-size: 12px; color: var(--tk-gray); line-height: 1.7; }
.detail-tags { display: flex; flex-wrap: wrap; gap: 5px; justify-content: center; margin-top: 12px; }
.detail-tag { background: #FDE8EC; border-radius: 20px; padding: 3px 11px; font-size: 10px; font-weight: 600; color: var(--tk-red); letter-spacing: 0.5px; }

#gallery { padding: 130px 0; background: var(--black); }
.gallery-header { text-align: center; margin-bottom: 46px; }
.gallery-filters { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-bottom: 36px; }
.filter-btn { padding: 9px 22px; border-radius: 2px; font-family: var(--font-body); font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; cursor: pointer; transition: var(--transition); background: transparent; border: 1.5px solid rgba(255,255,255,0.12); color: rgba(255,255,255,0.45); }
.filter-btn:hover, .filter-btn.active { background: var(--tk-red); border-color: var(--tk-red); color: var(--white); }
.gallery-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 220px; gap: 10px; }
.g-item { position: relative; overflow: hidden; border-radius: 8px; cursor: pointer; transition: var(--transition); }
.g-item.tall { grid-row: span 2; }
.g-item.wide { grid-column: span 2; }
.g-item-bg { width: 100%; height: 100%; transition: transform 0.6s ease; display: block; background-size: cover; background-position: center; background-repeat: no-repeat; }
.g-item-bg.has-photo { display: block; }
.g-item:hover .g-item-bg { transform: scale(1.06); }
.g-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 30%, rgba(10,10,16,0.9) 100%); opacity: 0; transition: opacity 0.4s; display: flex; flex-direction: column; justify-content: flex-end; padding: 20px; }
.g-item:hover .g-overlay { opacity: 1; }
.g-cat { font-size: 9px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--tk-red); font-weight: 700; margin-bottom: 4px; }
.g-title { font-family: var(--font-display); font-size: 20px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; }
.gb1 { background: linear-gradient(135deg, #1A1745 0%, #262261 60%, #3530A0 100%); }
.gb2 { background: linear-gradient(135deg, #0A0010 0%, #1A1745 100%); }
.gb3 { background: linear-gradient(160deg, #3A0010 0%, #8A0A20 60%, #ED193A 100%); }
.gb4 { background: linear-gradient(135deg, #0F1030 0%, #262261 100%); }
.gb5 { background: linear-gradient(135deg, #1a0a20 0%, #4A2060 100%); }
.gb6 { background: linear-gradient(135deg, #0A1A2A 0%, #0F3060 100%); }
.gb7 { background: linear-gradient(135deg, #200010 0%, #5A0020 60%, #C01130 100%); }
.gb8 { background: linear-gradient(160deg, #10101A 0%, #262261 50%, #ED193A 100%); }

#why-us { padding: 130px 0; background: var(--dark-navy); }
.why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 90px; align-items: center; }
.why-left .section-intro { font-size: 15px; color: rgba(255,255,255,0.5); line-height: 1.9; margin: 20px 0 42px; max-width: 420px; }
.counters-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.counter-card { background: var(--glass); border: 1px solid var(--glass-border); border-radius: var(--radius); padding: 30px 24px; text-align: center; transition: var(--transition); position: relative; overflow: hidden; }
.counter-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(to right, var(--tk-red), var(--tk-navy-light)); }
.counter-card:hover { border-color: rgba(237,25,58,0.25); transform: translateY(-4px); }
.counter-icon { font-size: 28px; margin-bottom: 10px; }
.counter-val { font-family: var(--font-display); font-size: 52px; font-weight: 900; color: var(--tk-red); line-height: 1; }
.counter-lbl { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.4); margin-top: 6px; }
.why-features { display: flex; flex-direction: column; gap: 14px; }
.why-feat { display: flex; gap: 18px; align-items: flex-start; padding: 20px 22px; background: var(--glass); border: 1px solid var(--glass-border); border-radius: var(--radius); transition: var(--transition); cursor: default; }
.why-feat:hover { border-color: rgba(237,25,58,0.3); transform: translateX(6px); }
.why-feat-icon { width: 46px; height: 46px; min-width: 46px; background: linear-gradient(135deg, var(--tk-red), var(--tk-red-dark)); border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 20px; }
.why-feat-title { font-family: var(--font-display); font-size: 17px; font-weight: 700; letter-spacing: 1px; margin-bottom: 5px; text-transform: uppercase; }
.why-feat-desc { font-size: 12px; color: rgba(255,255,255,0.45); line-height: 1.7; }

#process { padding: 120px 0; background: var(--off-white); }
.process-header { text-align: center; margin-bottom: 70px; }
.process-header .section-title { color: var(--black); }
.process-sub { color: var(--tk-gray); font-size: 15px; margin-top: 14px; }
.process-steps { position: relative; display: flex; gap: 0; }
.process-line { position: absolute; top: 44px; left: calc(10% + 30px); right: calc(10% + 30px); height: 2px; background: linear-gradient(to right, var(--tk-red), var(--tk-navy)); z-index: 0; }
.process-step { flex: 1; text-align: center; position: relative; z-index: 1; padding: 0 12px; transition: var(--transition); }
.process-step:hover { transform: translateY(-8px); }
.process-circle { width: 56px; height: 56px; border-radius: 50%; background: var(--white); border: 2.5px solid var(--tk-red); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 20px; font-weight: 800; color: var(--tk-red); margin: 0 auto 18px; position: relative; z-index: 2; box-shadow: 0 0 0 6px var(--off-white); transition: var(--transition); }
.process-step:hover .process-circle { background: var(--tk-red); color: var(--white); box-shadow: 0 0 0 6px rgba(237,25,58,0.1), 0 8px 24px rgba(237,25,58,0.3); }
.process-emoji { font-size: 26px; margin-bottom: 10px; }
.process-step-title { font-family: var(--font-display); font-size: 18px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: var(--black); margin-bottom: 10px; }
.process-step-desc { font-size: 12px; color: var(--tk-gray); line-height: 1.7; max-width: 150px; margin: 0 auto; }

#testimonials { padding: 130px 0; background: var(--dark); }
.testimonials-header { text-align: center; margin-bottom: 60px; }
.testimonials-slider { overflow: hidden; }
.testimonials-track { display: flex; transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
.t-card { min-width: calc(33.333% - 16px); margin-right: 24px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.07); border-radius: 14px; padding: 34px 30px; position: relative; overflow: hidden; flex-shrink: 0; }
.t-card::before { content: '"'; position: absolute; top: 10px; right: 20px; font-family: var(--font-script); font-size: 110px; color: rgba(237,25,58,0.08); line-height: 1; }
.t-card:hover { border-color: rgba(237,25,58,0.2); }
.t-stars { display: flex; gap: 3px; margin-bottom: 14px; font-size: 15px; color: var(--tk-red); }
.t-text { font-size: 14px; color: rgba(255,255,255,0.65); line-height: 1.85; margin-bottom: 22px; position: relative; z-index: 1; }
.t-author { display: flex; align-items: center; gap: 14px; }
.t-avatar { width: 46px; height: 46px; border-radius: 50%; background: linear-gradient(135deg, var(--tk-red), var(--tk-navy)); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 20px; font-weight: 800; border: 2px solid rgba(237,25,58,0.3); }
.t-name { font-family: var(--font-display); font-size: 16px; font-weight: 700; letter-spacing: 1px; margin-bottom: 3px; text-transform: uppercase; }
.t-role { font-size: 11px; color: rgba(255,255,255,0.35); }
.t-type { font-size: 10px; color: var(--tk-red); font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; margin-top: 2px; }
.slider-controls { display: flex; align-items: center; justify-content: center; gap: 16px; margin-top: 40px; }
.slider-btn { width: 44px; height: 44px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,0.15); background: transparent; color: var(--white); font-size: 18px; cursor: pointer; transition: var(--transition); display: flex; align-items: center; justify-content: center; }
.slider-btn:hover { border-color: var(--tk-red); color: var(--tk-red); }
.slider-dots { display: flex; gap: 8px; }
.s-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.18); cursor: pointer; transition: var(--transition); }
.s-dot.active { background: var(--tk-red); width: 24px; border-radius: 4px; }

#cta-banner { padding: 110px 0; text-align: center; position: relative; overflow: hidden; background: linear-gradient(135deg, var(--tk-navy-dark) 0%, var(--tk-navy) 50%, #3530A0 100%); }
#cta-banner::before { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ED193A' fill-opacity='0.04'%3E%3Cpath d='M0 0h40v40H0zm40 40h40v40H40z'/%3E%3C/g%3E%3C/svg%3E"); }
.cta-bg-red, .cta-bg-red2 { position: absolute; border-radius: 50%; pointer-events: none; }
.cta-bg-red { width: 500px; height: 500px; background: radial-gradient(circle, rgba(237,25,58,0.18), transparent); top: -150px; right: -100px; }
.cta-bg-red2 { width: 400px; height: 400px; background: radial-gradient(circle, rgba(237,25,58,0.12), transparent); bottom: -100px; left: -100px; }
.cta-inner { position: relative; z-index: 1; }
.cta-pre { font-family: var(--font-script); font-style: italic; font-size: 22px; color: rgba(255,255,255,0.6); margin-bottom: 12px; }
.cta-title { font-family: var(--font-display); font-weight: 900; font-size: clamp(52px, 9vw, 110px); text-transform: uppercase; letter-spacing: 2px; line-height: 0.92; margin-bottom: 24px; }
.cta-title span { color: var(--tk-red); }
.cta-desc { font-size: 16px; color: rgba(255,255,255,0.6); max-width: 500px; margin: 0 auto 44px; line-height: 1.8; }
.cta-btns { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

#contact { padding: 130px 0; background: var(--black); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 90px; align-items: start; }
.contact-left-title { font-family: var(--font-display); font-size: 50px; font-weight: 900; text-transform: uppercase; letter-spacing: 2px; line-height: 1; margin-bottom: 18px; }
.contact-left-desc { font-size: 14px; color: rgba(255,255,255,0.5); line-height: 1.85; margin-bottom: 36px; }
.contact-info-list { display: flex; flex-direction: column; gap: 14px; margin-bottom: 32px; }
.contact-info-item { display: flex; align-items: center; gap: 16px; padding: 16px 18px; background: var(--glass); border: 1px solid var(--glass-border); border-radius: var(--radius); transition: var(--transition); }
.contact-info-item:hover { border-color: rgba(237,25,58,0.25); }
.contact-info-icon { width: 40px; height: 40px; min-width: 40px; background: linear-gradient(135deg, var(--tk-red), var(--tk-red-dark)); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 17px; }
.contact-info-lbl { font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.35); }
.contact-info-val { font-size: 13px; font-weight: 500; margin-top: 2px; }
.contact-socials { display: flex; gap: 10px; }
.soc-btn, .fsoc { width: 42px; height: 42px; border-radius: 9px; background: var(--glass); border: 1px solid var(--glass-border); display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; transition: var(--transition); cursor: pointer; }
.soc-btn:hover, .fsoc:hover { background: var(--tk-red); border-color: var(--tk-red); transform: translateY(-3px); }
.contact-form-box { background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; padding: 44px 40px; }
.form-head { font-family: var(--font-display); font-size: 28px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 6px; }
.form-sub { font-size: 13px; color: rgba(255,255,255,0.4); margin-bottom: 30px; }
.form-status { border-radius: 8px; padding: 14px 16px; font-size: 13px; margin-bottom: 18px; }
.form-status.success { background: rgba(29,122,64,0.18); border: 1px solid rgba(29,122,64,0.5); color: #b8f4c9; }
.form-status.error { background: rgba(192,17,48,0.14); border: 1px solid rgba(192,17,48,0.5); color: #ffd1da; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-grp { margin-bottom: 14px; }
.form-grp label { display: block; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.4); margin-bottom: 7px; font-weight: 600; }
.form-grp input, .form-grp select, .form-grp textarea { width: 100%; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 7px; padding: 13px 15px; color: var(--white); font-family: var(--font-body); font-size: 14px; font-weight: 400; transition: var(--transition); outline: none; -webkit-appearance: none; }
.form-grp input:focus, .form-grp select:focus, .form-grp textarea:focus { border-color: var(--tk-red); background: rgba(237,25,58,0.04); box-shadow: 0 0 0 3px rgba(237,25,58,0.08); }
.form-grp select option { background: #1A1745; }
.form-grp textarea { height: 110px; resize: vertical; }
.form-submit-btn { width: 100%; padding: 17px; font-size: 12px; letter-spacing: 3px; margin-top: 6px; border-radius: 7px; }
.map-placeholder { margin-top: 28px; height: 170px; border-radius: var(--radius); background: linear-gradient(135deg, rgba(38,34,97,0.2), rgba(237,25,58,0.1)); border: 1px solid rgba(38,34,97,0.3); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; cursor: pointer; transition: var(--transition); }
.map-placeholder:hover { border-color: rgba(237,25,58,0.3); }
.map-placeholder span { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.3); }

footer { background: var(--dark); border-top: 1px solid rgba(255,255,255,0.05); padding: 80px 0 28px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.2fr; gap: 60px; margin-bottom: 60px; }
.footer-brand-lockup { display: flex; align-items: center; gap: 12px; margin-bottom: 4px; }
.footer-brand-lockup .nav-logo-icon { width: 52px; height: 28px; }
.footer-brand-lockup .nav-logo-image { max-width: 104px; max-height: 48px; }
.footer-brand-name { font-family: var(--font-display); font-weight: 800; font-size: 18px; letter-spacing: 3px; text-transform: uppercase; }
.footer-brand-sub { font-size: 8px; letter-spacing: 4px; text-transform: uppercase; color: var(--tk-gray-light); margin-top: 2px; }
.footer-brand-desc { font-size: 13px; color: rgba(255,255,255,0.38); line-height: 1.85; margin: 14px 0 22px; max-width: 260px; }
.footer-social-row { display: flex; gap: 9px; }
.footer-col-head { font-family: var(--font-display); font-size: 14px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--tk-red); margin-bottom: 18px; }
.footer-links { display: flex; flex-direction: column; gap: 11px; }
.footer-links a { font-size: 13px; color: rgba(255,255,255,0.42); transition: color 0.3s; }
.footer-links a:hover { color: var(--white); }
.footer-nl-desc { font-size: 13px; color: rgba(255,255,255,0.38); line-height: 1.7; margin-bottom: 14px; }
.footer-nl-input { width: 100%; background: var(--glass); border: 1px solid var(--glass-border); border-radius: 5px; padding: 11px 14px; color: var(--white); font-family: var(--font-body); font-size: 13px; outline: none; margin-bottom: 9px; transition: border-color 0.3s; }
.footer-nl-input:focus { border-color: var(--tk-red); }
.footer-nl-input::placeholder { color: rgba(255,255,255,0.25); }
.footer-nl-btn { width: 100%; justify-content: center; padding: 12px; font-size: 11px; border-radius: 5px; }
.footer-contact-note { font-size: 11px; color: rgba(255,255,255,0.2); margin-top: 12px; line-height: 1.7; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.05); padding-top: 24px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 10px; }
.footer-copy, .footer-made { font-size: 12px; color: rgba(255,255,255,0.25); }
.footer-made span { color: var(--tk-red); }

.whatsapp-fab { position: fixed; bottom: 96px; right: 26px; z-index: 999; width: 54px; height: 54px; border-radius: 50%; background: #25D366; color: var(--white); display: flex; align-items: center; justify-content: center; font-size: 16px; font-weight: 700; box-shadow: 0 6px 20px rgba(37,211,102,0.4); cursor: pointer; transition: var(--transition); animation: popIn 0.5s ease 2s both; }
.whatsapp-fab:hover { transform: scale(1.1); box-shadow: 0 10px 28px rgba(37,211,102,0.5); }
.wa-tooltip { position: absolute; right: 66px; white-space: nowrap; background: #25D366; color: var(--white); padding: 5px 12px; border-radius: 20px; font-size: 12px; font-weight: 600; opacity: 0; pointer-events: none; transition: opacity 0.3s; }
.whatsapp-fab:hover .wa-tooltip { opacity: 1; }
.sticky-cta { position: fixed; bottom: 26px; right: 26px; z-index: 998; opacity: 0; pointer-events: none; transform: translateY(8px); transition: var(--transition); }
.sticky-cta.visible { opacity: 1; pointer-events: all; transform: translateY(0); }
@keyframes popIn { from { transform: scale(0); opacity: 0; } 60% { transform: scale(1.15); } to { transform: scale(1); opacity: 1; } }

.page-hero, .interior-hero { padding: 170px 0 90px; background: radial-gradient(circle at 20% 20%, rgba(237,25,58,0.16), transparent 30%), radial-gradient(circle at 80% 20%, rgba(38,34,97,0.28), transparent 32%), linear-gradient(180deg, rgba(17,17,40,1) 0%, rgba(10,10,16,1) 100%); }
.interior-hero-inner { position: relative; z-index: 1; max-width: 900px; }
.interior-summary { font-size: 16px; line-height: 1.85; color: rgba(255,255,255,0.58); max-width: 720px; margin-top: 22px; }
.interior-section { padding: 90px 0 120px; background: var(--black); }
.content-shell { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); border-radius: 18px; padding: 36px; box-shadow: 0 20px 60px rgba(0,0,0,0.25); }
.entry-media { border-radius: 14px; overflow: hidden; margin-bottom: 28px; }
.entry-image, .archive-card-image { width: 100%; height: auto; display: block; }
.single-content { color: rgba(255,255,255,0.72); font-size: 16px; line-height: 1.9; }
.single-content > * + * { margin-top: 1em; }
.single-content h1, .single-content h2, .single-content h3, .single-content h4, .single-content h5, .single-content h6 { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 1px; color: var(--white); line-height: 1.05; }
.single-content a { color: var(--tk-red); }
.single-content ul, .single-content ol { padding-left: 1.2rem; }
.post-meta-row { display: flex; flex-wrap: wrap; gap: 12px 20px; color: rgba(255,255,255,0.48); margin-top: 18px; font-size: 12px; letter-spacing: 1px; text-transform: uppercase; }
.archive-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.archive-grid-two { grid-template-columns: repeat(2, 1fr); margin-top: 28px; }
.archive-card { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; padding: 24px; transition: var(--transition); }
.archive-card:hover { border-color: rgba(237,25,58,0.28); transform: translateY(-4px); }
.archive-card-media { display: block; border-radius: 12px; overflow: hidden; margin-bottom: 18px; }
.archive-card-meta { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--tk-red); margin-bottom: 10px; }
.archive-card-title { font-family: var(--font-display); font-size: 26px; line-height: 1; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 12px; }
.archive-card-excerpt { color: rgba(255,255,255,0.56); line-height: 1.8; font-size: 14px; }
.nav-card { min-height: 170px; display: flex; flex-direction: column; justify-content: center; }
.pagination-wrap { margin-top: 38px; display: flex; justify-content: center; }
.pagination-wrap .nav-links, .pagination-wrap .page-numbers { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; justify-content: center; }
.pagination-wrap .page-numbers { width: 42px; height: 42px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.15); display: inline-flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.75); transition: var(--transition); }
.pagination-wrap .page-numbers.current, .pagination-wrap .page-numbers:hover { background: var(--tk-red); border-color: var(--tk-red); color: var(--white); }
.empty-state { text-align: center; max-width: 780px; margin: 0 auto; }
.post-navigation-wrap { margin-top: 24px; }

.reveal { opacity: 0; transform: translateY(36px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-left { opacity: 0; transform: translateX(-36px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal-left.visible { opacity: 1; transform: translateX(0); }
.reveal-right { opacity: 0; transform: translateX(36px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal-right.visible { opacity: 1; transform: translateX(0); }

@media (max-width: 1100px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .details-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .about-grid, .why-grid, .contact-grid, .archive-grid { grid-template-columns: 1fr; gap: 60px; }
  .archive-grid-two { grid-template-columns: 1fr 1fr; }
  .about-image-block { height: 420px; }
  .gallery-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  .nav-links, .nav-cta { display: none; }
  .hamburger { display: flex; }
  #hero { padding-top: 130px; }
  .services-grid, .archive-grid, .archive-grid-two { grid-template-columns: 1fr; }
  .details-grid { grid-template-columns: 1fr 1fr; }
  .process-steps { flex-direction: column; gap: 24px; }
  .process-line { display: none; }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .g-item.wide { grid-column: span 1; }
  .t-card { min-width: 85%; }
  .form-row { grid-template-columns: 1fr; }
  .hero-stats-bar { display: none; }
  .counters-grid { grid-template-columns: 1fr 1fr; }
  .contact-form-box, .content-shell { padding: 26px 20px; }
  .footer-grid { grid-template-columns: 1fr; gap: 34px; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .page-hero, .interior-hero { padding-top: 140px; }
}

@media (max-width: 480px) {
  .gallery-grid, .details-grid, .about-features, .counters-grid { grid-template-columns: 1fr; }
  .g-item.tall { grid-row: span 1; }
}
