You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
194 lines
9.5 KiB
194 lines
9.5 KiB
'use client';
|
|
|
|
import { motion } from 'framer-motion';
|
|
import { useInView } from 'framer-motion';
|
|
import { useRef, useState, useEffect } from 'react';
|
|
import Image from 'next/image';
|
|
|
|
export default function Values() {
|
|
const sectionRef = useRef(null);
|
|
const isInView = useInView(sectionRef, { once: true, margin: '-100px' });
|
|
const [mounted, setMounted] = useState(false);
|
|
|
|
useEffect(() => {
|
|
setMounted(true);
|
|
}, []);
|
|
|
|
// Prevent hydration mismatch by using consistent initial state
|
|
const shouldAnimate = mounted && isInView;
|
|
|
|
const services = [
|
|
{
|
|
title: 'Bilingual Upbringing',
|
|
description: 'Living in a multilingual home is not always easy. Parents often lack guidance and support, and without a clear plan some children are left confused and unable to construct a coherent identity around their fragmented language skills. I\'m here to guide both (future) parents and adult bilinguals reconnecting with their roots.',
|
|
icon: (
|
|
<svg className="w-12 h-12 text-orange-600" fill="none" stroke="currentColor" viewBox="0 0 24 24">
|
|
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M17 20h5v-2a3 3 0 00-5.356-1.857M17 20H7m10 0v-2c0-.656-.126-1.283-.356-1.857M7 20H2v-2a3 3 0 015.356-1.857M7 20v-2c0-.656.126-1.283.356-1.857m0 0a5.002 5.002 0 019.288 0M15 7a3 3 0 11-6 0 3 3 0 016 0zm6 3a2 2 0 11-4 0 2 2 0 014 0zM7 10a2 2 0 11-4 0 2 2 0 014 0z" />
|
|
</svg>
|
|
),
|
|
image: 'https://kagi.com/proxy/OIP.UAcj5KYX7RKEhVZ6DRqGsgHaE7?c=MvlWCDdicm1aK3zpADFz56M-jyjW-k_WkjPX8kg3kd7yGoRM-QOn_I1vlzUgMSdd3ZA0VkTSDpsSnaT8MntfyiWi4KFJRlP6WmtGvfIyCytNxoxitLvzxtR-qUOcdepb',
|
|
},
|
|
{
|
|
title: 'Polish Lessons',
|
|
description: 'It is exciting to be in a relationship with a speaker of a different language. You are curious, motivated and you want to start speaking immediately. It sometimes takes a few Duolingo levels and a few \'classes\' with your partner before you understand it takes a professional teacher to do the job. I\'m here to assist you.',
|
|
icon: (
|
|
<svg className="w-12 h-12 text-orange-600" fill="none" stroke="currentColor" viewBox="0 0 24 24">
|
|
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M12 6.253v13m0-13C10.832 5.477 9.246 5 7.5 5S4.168 5.477 3 6.253v13C4.168 18.477 5.754 18 7.5 18s3.332.477 4.5 1.253m0-13C13.168 5.477 14.754 5 16.5 5c1.747 0 3.332.477 4.5 1.253v13C19.832 18.477 18.247 18 16.5 18c-1.746 0-3.332.477-4.5 1.253" />
|
|
</svg>
|
|
),
|
|
image: 'https://kagi.com/proxy/images?c=_m3km2RjA3G0qleowsZXHZb9NEn0fSsEYIHbKzMDyAFb4nUPIanknmQV_g0rmdCIsgzAMsPq08VleluyScXQQ4izz3KxqIw42uNpJM0UVdSW3vFxwNsADK8GLjDKETNDP1zByVU0b1ao6Y7_TdQpnQ%3D%3D',
|
|
},
|
|
];
|
|
|
|
const qualifications = [
|
|
{
|
|
title: 'MA in Linguistics',
|
|
description: 'My thesis focused on bilingualism and its challenges related with pronunciation and spelling',
|
|
icon: (
|
|
<svg className="w-12 h-12 text-orange-600" fill="none" stroke="currentColor" viewBox="0 0 24 24">
|
|
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M12 14l9-5-9-5-9 5 9 5z" />
|
|
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M12 14l6.16-3.422a12.083 12.083 0 01.665 6.479A11.952 11.952 0 0012 20.055a11.952 11.952 0 00-6.824-2.998 12.078 12.078 0 01.665-6.479L12 14z" />
|
|
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M12 14v7M5.176 10.5a11.952 11.952 0 00-1.824 2.998M18.824 13.498a11.952 11.952 0 01-1.824-2.998" />
|
|
</svg>
|
|
),
|
|
},
|
|
{
|
|
title: '20 Years of Experience',
|
|
description: 'I\'ve been teaching foreign languages in Austria, Poland, Spain and the Netherlands',
|
|
icon: (
|
|
<svg className="w-12 h-12 text-orange-600" fill="none" stroke="currentColor" viewBox="0 0 24 24">
|
|
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M12 8v4l3 3m6-3a9 9 0 11-18 0 9 9 0 0118 0z" />
|
|
</svg>
|
|
),
|
|
},
|
|
{
|
|
title: 'Speech Therapy',
|
|
description: 'During my professional education I mastered the basics of speech therapy and vocal emission',
|
|
icon: (
|
|
<svg className="w-12 h-12 text-orange-600" fill="none" stroke="currentColor" viewBox="0 0 24 24">
|
|
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M19 11a7 7 0 01-7 7m0 0a7 7 0 01-7-7m7 7v4m0 0H8m4 0h4m-4-8a3 3 0 01-3-3V5a3 3 0 116 0v6a3 3 0 01-3 3z" />
|
|
</svg>
|
|
),
|
|
},
|
|
{
|
|
title: 'Dyslexia Support',
|
|
description: 'I completed a professional training in "Supporting learners in difficulties with reading and writing"',
|
|
icon: (
|
|
<svg className="w-12 h-12 text-orange-600" fill="none" stroke="currentColor" viewBox="0 0 24 24">
|
|
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M9 12h6m-6 4h6m2 5H7a2 2 0 01-2-2V5a2 2 0 012-2h5.586a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V19a2 2 0 01-2 2z" />
|
|
</svg>
|
|
),
|
|
},
|
|
{
|
|
title: 'Coaching and Counseling',
|
|
description: 'I\'m a certified junior coach/counsellor and work with individual clients in Polish and English',
|
|
icon: (
|
|
<svg className="w-12 h-12 text-orange-600" fill="none" stroke="currentColor" viewBox="0 0 24 24">
|
|
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M9.663 17h4.673M12 3v1m6.364 1.636l-.707.707M21 12h-1M4 12H3m3.343-5.657l-.707-.707m2.828 9.9a5 5 0 117.072 0l-.548.547A3.374 3.374 0 0014 18.469V19a2 2 0 11-4 0v-.531c0-.895-.356-1.754-.988-2.386l-.548-.547z" />
|
|
</svg>
|
|
),
|
|
},
|
|
{
|
|
title: 'Improv Theatre',
|
|
description: 'I love theatre, comedy and improvisation! My hobby, and teaching tool is improvised comedy and physical theatre.',
|
|
icon: (
|
|
<svg className="w-12 h-12 text-orange-600" fill="none" stroke="currentColor" viewBox="0 0 24 24">
|
|
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M14.752 11.168l-3.197-2.132A1 1 0 0010 9.87v4.263a1 1 0 001.555.832l3.197-2.132a1 1 0 000-1.664z" />
|
|
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M21 12a9 9 0 11-18 0 9 9 0 0118 0z" />
|
|
</svg>
|
|
),
|
|
},
|
|
];
|
|
|
|
return (
|
|
<section id="services" className="py-20 md:py-32 bg-gradient-to-b from-white to-orange-50" ref={sectionRef}>
|
|
<div className="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8">
|
|
<motion.div
|
|
initial={{ opacity: 0, y: 30 }}
|
|
animate={shouldAnimate ? { opacity: 1, y: 0 } : { opacity: 0, y: 30 }}
|
|
transition={{ duration: 0.8, ease: [0.25, 0.1, 0.25, 1] }}
|
|
className="text-center mb-16"
|
|
>
|
|
<h2 className="text-3xl md:text-4xl lg:text-5xl font-bold text-slate-800 mb-4">
|
|
Services
|
|
</h2>
|
|
</motion.div>
|
|
|
|
<div className="grid grid-cols-1 md:grid-cols-2 gap-8 lg:gap-12 mb-20">
|
|
{services.map((service, index) => (
|
|
<motion.div
|
|
key={index}
|
|
initial={{ opacity: 0, y: 50 }}
|
|
animate={shouldAnimate ? { opacity: 1, y: 0 } : { opacity: 0, y: 50 }}
|
|
transition={{
|
|
duration: 0.8,
|
|
delay: 0.2 + index * 0.1,
|
|
ease: [0.25, 0.1, 0.25, 1],
|
|
}}
|
|
className="bg-white rounded-2xl shadow-md hover:shadow-xl transition-shadow border border-slate-100 overflow-hidden"
|
|
>
|
|
{service.image && (
|
|
<div className="relative h-48 w-full">
|
|
<Image
|
|
src={service.image}
|
|
alt={service.title}
|
|
fill
|
|
className="object-cover"
|
|
sizes="(max-width: 768px) 100vw, 50vw"
|
|
unoptimized
|
|
/>
|
|
</div>
|
|
)}
|
|
<div className="p-8">
|
|
<div className="mb-6">{service.icon}</div>
|
|
<h3 className="text-2xl md:text-3xl font-bold text-slate-800 mb-4">
|
|
{service.title}
|
|
</h3>
|
|
<p className="text-slate-600 text-lg leading-relaxed">
|
|
{service.description}
|
|
</p>
|
|
</div>
|
|
</motion.div>
|
|
))}
|
|
</div>
|
|
|
|
<motion.div
|
|
initial={{ opacity: 0, y: 30 }}
|
|
animate={shouldAnimate ? { opacity: 1, y: 0 } : { opacity: 0, y: 30 }}
|
|
transition={{ duration: 0.8, delay: 0.4, ease: [0.25, 0.1, 0.25, 1] }}
|
|
className="text-center mb-16"
|
|
>
|
|
<h2 className="text-3xl md:text-4xl lg:text-5xl font-bold text-slate-800 mb-4">
|
|
Qualifications & Experience
|
|
</h2>
|
|
</motion.div>
|
|
|
|
<div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-8 lg:gap-12">
|
|
{qualifications.map((qual, index) => (
|
|
<motion.div
|
|
key={index}
|
|
initial={{ opacity: 0, y: 50 }}
|
|
animate={shouldAnimate ? { opacity: 1, y: 0 } : { opacity: 0, y: 50 }}
|
|
transition={{
|
|
duration: 0.8,
|
|
delay: 0.5 + index * 0.1,
|
|
ease: [0.25, 0.1, 0.25, 1],
|
|
}}
|
|
className="bg-white p-8 rounded-2xl shadow-md hover:shadow-xl transition-shadow border border-slate-100"
|
|
>
|
|
<div className="mb-6">{qual.icon}</div>
|
|
<h3 className="text-xl md:text-2xl font-bold text-slate-800 mb-4">
|
|
{qual.title}
|
|
</h3>
|
|
<p className="text-slate-600 text-base leading-relaxed">
|
|
{qual.description}
|
|
</p>
|
|
</motion.div>
|
|
))}
|
|
</div>
|
|
</div>
|
|
</section>
|
|
);
|
|
}
|
|
|