/* =========================================
   JUST JANA ART - MAIN CSS
========================================= */

:root {
    --bg: #FDFDFD; 
    --text: #242426; 
    --accent: #DCA214; /* Mustard */
    --border: #DCDCDC;
    --font-main: 'Inter', sans-serif;
}

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

body {
    background-color: var(--bg);
    color: var(--text);
    font-family: var(--font-main);
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden; 
    width: 100%;
}

::selection { background-color: var(--accent); color: #fff; }
a { text-decoration: none; color: inherit; outline: none; transition: all 0.3s ease; }

/* =========================================
   ANIMACIJE
========================================= */
@keyframes drawLine {
    0% { width: 0; }
    100% { width: 150px; }
}
.anim-line {
    height: 1px;
    background-color: var(--accent);
    width: 0;
    animation: drawLine 1.5s ease-out forwards;
    margin-bottom: 30px;
}

/* =========================================
   LANGUAGE SWITCHER LOGIC
========================================= */
.lang-en { display: none; }
body.en-active .lang-sr { display: none; }
body.en-active .lang-en { display: block; }
span.lang-en { display: none; }
body.en-active span.lang-en { display: inline; }
body.en-active span.lang-sr { display: none; }

/* =========================================
   UI ELEMENTS
========================================= */
.tech-line { height: 1px; background-color: var(--text); width: 100%; opacity: 0.2; }
.tech-line.accent { background-color: var(--accent); height: 1px; width: 150px; opacity: 1; }

.pill {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 8px 16px; border: 1px solid var(--border);
    font-size: 10px; font-weight: 400; text-transform: uppercase; letter-spacing: 0.15em;
    background: transparent; color: var(--text); transition: all 0.3s ease;
}
.pill i { font-size: 16px; color: var(--accent); transition: 0.3s; }
.pill:hover { border-color: var(--text); }
.pill.accent-bg { border-color: var(--border); }
.pill.accent-bg:hover { border-color: var(--text); }

.btn {
    display: inline-flex; align-items: center; gap: 15px;
    padding: 16px 32px; background-color: transparent; color: var(--text);
    font-size: 11px; font-weight: 400; text-transform: uppercase; letter-spacing: 0.1em;
    border: 1px solid var(--text); transition: all 0.3s ease; cursor: pointer;
}
.btn i { color: var(--accent); font-size: 18px; transition: transform 0.3s; }
.btn:hover { background-color: var(--text); color: var(--bg); }
.btn:hover i { transform: translateX(8px); color: var(--bg); }

/* =========================================
   HEADER & NAVIGATION
========================================= */
header {
    position: fixed; top: 0; left: 0; right: 0;
    padding: 25px 5vw; display: flex; justify-content: space-between; align-items: center;
    z-index: 100; background: rgba(253, 253, 253, 0.98); border-bottom: 1px solid var(--border);
}
.logo { font-size: 16px; font-weight: 300; letter-spacing: 0.05em; text-transform: uppercase; color: var(--text); }
.logo span { color: var(--accent); }

.nav-right { display: flex; align-items: center; gap: 40px; }
.menu-link { font-size: 11px; font-weight: 400; text-transform: uppercase; letter-spacing: 0.1em; display: flex; align-items: center; gap: 10px; color: var(--text); }
.menu-link:hover { color: var(--accent); }
.menu-link i { color: var(--accent); font-size: 18px; font-weight: 300; }

.lang-switcher { font-size: 11px; font-weight: 400; letter-spacing: 0.1em; cursor: pointer; display: flex; gap: 5px; color: var(--text); }
.switch-sr { color: var(--accent); transition: 0.3s; }
.switch-en { color: var(--text); opacity: 0.4; transition: 0.3s; }
body.en-active .switch-sr { color: var(--text); opacity: 0.4; }
body.en-active .switch-en { color: var(--accent); opacity: 1; }

/* SECTIONS COMMON */
.section-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 40px; }
.section-title { font-size: 3vw; font-weight: 300; letter-spacing: -0.02em; text-transform: uppercase; line-height: 1.1; }

/* =========================================
   FRONT PAGE SECTIONS
========================================= */
/* 1. Hero */
.hero { min-height: 100vh; display: grid; grid-template-columns: 1.2fr 1fr; padding: 15vh 5vw 5vh; align-items: end; gap: 5vw; }
.hero-meta { display: flex; gap: 12px; margin-bottom: 40px; flex-wrap: wrap; }
.hero-text h1 { font-size: 8.5vw; line-height: 0.9; font-weight: 300; letter-spacing: -0.04em; text-transform: uppercase; margin-bottom: 40px; }
.hero-text h1 span { color: var(--accent); font-weight: 300; }
.hero-subtitle { font-size: 15px; font-weight: 300; max-width: 450px; line-height: 1.8; margin-top: 30px; padding-left: 20px; border-left: 1px solid var(--accent); color: #555; }

.hero-img-wrap { width: 100%; height: 75vh; border: 1px solid var(--border); overflow: hidden; position: relative; }
.hero-img { width: 100%; height: 100%; background-position: center; background-size: cover; filter: grayscale(100%); transition: transform 1.2s ease, filter 0.8s; }
.hero-img-wrap:hover .hero-img { transform: scale(1.03); filter: grayscale(0%); }

/* 2. Manifesto */
.manifesto { padding: 15vh 5vw; border-top: 1px solid var(--border); display: grid; grid-template-columns: 1fr 1fr; gap: 10vw; }
.manifesto h2 { font-size: 3.5vw; font-weight: 300; text-transform: uppercase; line-height: 1.1; letter-spacing: -0.02em; }
.manifesto p { font-weight: 300; line-height: 1.8; font-size: 16px; color: #555; }

/* 3. Services / Ekspertiza */
.services { padding: 15vh 5vw; border-top: 1px solid var(--border); }
.services-grid { border-top: 1px solid var(--border); }
.service-row { display: grid; grid-template-columns: 80px 1fr 1.5fr 50px; padding: 40px 0; border-bottom: 1px solid var(--border); align-items: start; transition: background 0.3s; cursor: pointer; }
.service-row:hover { background: #F9F9F9; padding-left: 15px; }
.s-num { font-size: 12px; font-weight: 400; color: var(--accent); }
.s-title { font-size: 2vw; font-weight: 300; text-transform: uppercase; color: var(--text); }
.s-desc { font-size: 14px; color: #666; line-height: 1.8; max-width: 350px; font-weight: 300; }
.s-icon { font-size: 24px; color: var(--text); transition: all 0.3s ease; text-align: right; font-weight: 300; }
.service-row:hover .s-icon { transform: rotate(45deg); color: var(--accent); }

/* 4. Parallax Break (BULLETPROOF, LEVO PORAVNANO, MRAČNA SLIKA) */
.parallax-break { 
    width: 100%; 
    height: 70vh; 
    position: relative; 
    overflow: hidden; 
    background-image: url('https://images.unsplash.com/photo-1516575150278-771891de774e?ixlib=rb-4.0.3&auto=format&fit=crop&w=2000&q=80') !important;
    background-attachment: fixed !important; 
    background-position: center center !important;
    background-repeat: no-repeat !important;
    background-size: cover !important; 
    display: flex; 
    align-items: center; 
    justify-content: flex-start; /* Levo poravnanje */
    border-top: 1px solid var(--border); 
    border-bottom: 1px solid var(--border);
}
.parallax-break::before { 
    content: ''; 
    position: absolute; 
    top: 0; left: 0; right: 0; bottom: 0; 
    background: rgba(0,0,0,0.65) !important; /* Mračni overlay */
    z-index: 1; 
}
.parallax-content { 
    position: relative; 
    z-index: 2; 
    text-align: left; /* Levo poravnanje teksta */
    color: #fff; 
    padding: 0 5vw; 
}
.parallax-content h2 { font-size: 5vw; font-weight: 300; text-transform: uppercase; letter-spacing: -0.02em; line-height: 1.1; margin-bottom: 20px; text-shadow: 0 2px 10px rgba(0,0,0,0.4); }
.parallax-content p { font-size: 16px; font-weight: 300; letter-spacing: 0.15em; text-transform: uppercase; opacity: 0.9; }

/* 5. Portfolio Grid (Front & Portfolio Page) */
.portfolio { padding: 15vh 5vw; border-top: 1px solid var(--border); }
.portfolio-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px; padding: 5vh 0; }
.proj { position: relative; cursor: pointer; display: flex; flex-direction: column; }
.proj.large { grid-column: 1 / -1; }
.proj-img-wrap { width: 100%; aspect-ratio: 16/10; overflow: hidden; position: relative; border: 1px solid var(--border); background: var(--bg); }
.proj img { width: 100%; height: 100%; object-fit: cover; display: block; filter: grayscale(100%); transition: all 0.8s ease; }
.proj:hover img { filter: grayscale(0%); transform: scale(1.03); }

.proj-tags { position: absolute; top: 20px; left: 20px; display: flex; gap: 10px; z-index: 10; flex-wrap: wrap; }
.proj-meta { margin-top: 20px; display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--border); padding-bottom: 15px; flex-grow: 1; }
.proj-meta h3 { font-size: 16px; font-weight: 400; text-transform: uppercase; color: var(--text); letter-spacing: 0.05em; }

.proj-btn { width: 40px; height: 40px; min-width: 40px; border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; color: var(--text); transition: all 0.3s; }
.proj-btn i { font-size: 20px; color: var(--text); font-weight: 300; }
.proj-btn:hover { border-color: var(--text); }

/* 6. Process / Metodologija */
.process { padding: 10vh 5vw; border-top: 1px solid var(--border); }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--border); margin-top: 60px; border: 1px solid var(--border); }
.process-item { background: var(--bg); padding: 40px 30px; }
.process-item i { font-size: 32px; color: var(--accent); margin-bottom: 30px; display: block; font-weight: 200; }
.process-item h4 { font-size: 12px; font-weight: 500; text-transform: uppercase; margin-bottom: 15px; color: var(--text); letter-spacing: 0.1em; }
.process-item p { font-size: 13px; font-weight: 300; line-height: 1.8; color: #666; }

/* 7. Grand CTA (Levo poravnano sa linijom) */
.grand-cta { padding: 20vh 5vw; text-align: left; background: var(--bg); border-top: 1px solid var(--border); display: flex; flex-direction: column; align-items: flex-start; }
.grand-cta h2 { font-size: 6vw; font-weight: 300; text-transform: uppercase; letter-spacing: -0.04em; line-height: 1.1; margin-bottom: 40px; color: var(--text); }
.grand-cta h2 span { color: var(--accent); font-weight: 300; }
.grand-cta p { font-size: 16px; color: #555; max-width: 600px; font-weight: 300; line-height: 1.8; margin-bottom: 50px; }

/* =========================================
   SUBPAGES: ABOUT, SERVICES, SINGLE, CONTACT
========================================= */
.page-header { margin-top: 80px; padding: 15vh 5vw 5vh; border-bottom: 1px solid var(--border); text-align: left; }
.page-header h1 { font-size: 8vw; font-weight: 300; text-transform: uppercase; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 20px; color: var(--text); }
.page-header p { font-size: 16px; color: #555; font-weight: 300; max-width: 600px; line-height: 1.8; }

.filter-bar { display: flex; gap: 30px; padding: 25px 5vw; border-bottom: 1px solid var(--border); overflow-x: auto; white-space: nowrap; }
.filter-btn { font-family: var(--font-main); font-size: 11px; font-weight: 400; text-transform: uppercase; letter-spacing: 0.15em; background: none; border: none; color: var(--text); opacity: 0.5; cursor: pointer; transition: all 0.3s ease; padding: 5px 0; position: relative; }
.filter-btn::after { content: ''; position: absolute; bottom: -1px; left: 0; width: 0; height: 1px; background: var(--accent); transition: 0.3s; }
.filter-btn:hover { opacity: 1; }
.filter-btn.active { opacity: 1; color: var(--text); }
.filter-btn.active::after { width: 100%; }
.hide { display: none !important; opacity: 0; transform: scale(0.98); }

.project-hero { padding: 20vh 5vw 5vh; border-bottom: 1px solid var(--border); }
.ph-tags { display: flex; gap: 10px; margin-bottom: 40px; }
.ph-title { font-size: 9vw; font-weight: 300; text-transform: uppercase; line-height: 0.9; letter-spacing: -0.04em; margin-bottom: 40px; }
.ph-title span { color: var(--accent); font-weight: 300; }
.ph-img-wrap { width: 100%; height: 80vh; border: 1px solid var(--border); overflow: hidden; position: relative; }
.ph-img { width: 100%; height: 100%; background-position: center; background-size: cover; filter: grayscale(100%); transition: filter 1.2s ease, transform 1.5s ease; }
.ph-img-wrap:hover .ph-img { filter: grayscale(0%); transform: scale(1.02); }

.project-meta { display: grid; grid-template-columns: repeat(4, 1fr); border-bottom: 1px solid var(--border); }
.meta-box { padding: 40px 5vw; border-right: 1px solid var(--border); }
.meta-box:last-child { border-right: none; }
.meta-label { font-size: 10px; font-weight: 400; text-transform: uppercase; letter-spacing: 0.15em; color: var(--accent); margin-bottom: 10px; display: block; }
.meta-value { font-size: 14px; font-weight: 400; text-transform: uppercase; letter-spacing: 0.05em; }

.concept-section { padding: 15vh 5vw; display: grid; grid-template-columns: 1fr 2fr; gap: 10vw; border-bottom: 1px solid var(--border); }
.concept-title { font-size: 3vw; font-weight: 300; text-transform: uppercase; letter-spacing: -0.02em; }
.concept-text { font-size: 18px; line-height: 1.8; font-weight: 300; color: #555; }

.gallery { padding: 10vh 5vw; }
.gallery-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5vw; margin-bottom: 5vw; }
.gal-img-wrap { width: 100%; overflow: hidden; border: 1px solid var(--border); position: relative; }
.gal-img-wrap.full { grid-column: 1 / -1; }
.gal-img { width: 100%; height: auto; display: block; filter: grayscale(100%); transition: all 0.8s ease; }
.gal-img-wrap:hover .gal-img { filter: grayscale(0%); transform: scale(1.02); }
.gal-caption { padding-top: 15px; font-size: 10px; font-weight: 400; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text); border-bottom: 1px solid var(--border); padding-bottom: 15px; display: flex; justify-content: space-between; }

.service-block { display: grid; grid-template-columns: 1fr 1.2fr; border-bottom: 1px solid var(--border); min-height: 80vh; }
.sb-text { padding: 10vh 5vw; display: flex; flex-direction: column; justify-content: center; align-items: flex-start; border-right: 1px solid var(--border); }
.sb-num { font-size: 12px; font-weight: 400; color: var(--accent); margin-bottom: 25px; letter-spacing: 0.1em; }
.sb-title { font-size: 4vw; font-weight: 300; text-transform: uppercase; line-height: 1.1; letter-spacing: -0.02em; margin-bottom: 30px; text-align: left; color: var(--text); }
.sb-desc { font-size: 16px; line-height: 1.8; color: #555; font-weight: 300; max-width: 450px; text-align: left; }
.sb-img-wrap { width: 100%; height: 100%; overflow: hidden; position: relative; background: var(--bg); }
.sb-img { width: 100%; height: 100%; background-size: cover; background-position: center; filter: grayscale(100%); transition: transform 1.5s ease, filter 0.8s ease; }
.service-block:hover .sb-img { transform: scale(1.03); filter: grayscale(0%); }

.about-hero { padding: 20vh 5vw 5vh; border-bottom: 1px solid var(--border); display: grid; grid-template-columns: 1fr 1fr; gap: 5vw; align-items: end; min-height: 85vh; }
.about-title { font-size: 6.5vw; font-weight: 300; text-transform: uppercase; line-height: 1.1; letter-spacing: -0.03em; margin-bottom: 40px; }
.about-title span { color: var(--accent); font-weight: 300; }
.about-img-wrap { width: 100%; height: 70vh; border: 1px solid var(--border); overflow: hidden; position: relative; }
.about-img { width: 100%; height: 100%; background-size: cover; background-position: center; filter: grayscale(100%); transition: transform 1.5s ease; }
.about-img-wrap:hover .about-img { transform: scale(1.03); filter: grayscale(0%); }

.about-story { padding: 15vh 5vw; border-bottom: 1px solid var(--border); }
.story-label { font-size: 11px; font-weight: 400; text-transform: uppercase; letter-spacing: 0.2em; color: var(--accent); margin-bottom: 20px; display: block; }
.story-heading { font-size: 4vw; font-weight: 300; text-transform: uppercase; line-height: 1.1; letter-spacing: -0.02em; margin-bottom: 60px; max-width: 800px; }
.story-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10vw; }
.story-text { font-size: 16px; line-height: 1.8; font-weight: 300; color: #555; }
.story-text p { margin-bottom: 30px; }

.values-grid { display: grid; grid-template-columns: 1fr; border-bottom: 1px solid var(--border); }
.value-row { display: grid; grid-template-columns: 100px 1fr 2fr; padding: 6vh 5vw; border-bottom: 1px solid var(--border); align-items: start; }
.value-row:last-child { border-bottom: none; }
.v-title { font-size: 2.5vw; font-weight: 300; text-transform: uppercase; letter-spacing: -0.02em; }
.v-desc { font-size: 15px; line-height: 1.8; color: #666; font-weight: 300; max-width: 500px; }

.contact-page { margin-top: 80px; min-height: calc(100vh - 80px); display: grid; grid-template-columns: 1fr 1.2fr; border-bottom: 1px solid var(--border); }
.contact-info { padding: 15vh 5vw; border-right: 1px solid var(--border); display: flex; flex-direction: column; justify-content: space-between; }
.contact-info h1 { font-size: 6vw; font-weight: 300; text-transform: uppercase; line-height: 1; letter-spacing: -0.04em; margin-bottom: 50px; }
.contact-info h1 span { color: var(--accent); font-weight: 300; }
.contact-details { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.cd-label { font-size: 10px; font-weight: 400; text-transform: uppercase; letter-spacing: 0.15em; color: var(--accent); display: block; margin-bottom: 15px; }
.cd-text { font-size: 13px; font-weight: 400; line-height: 1.8; text-transform: uppercase; letter-spacing: 0.05em; }
.contact-form-wrapper { padding: 15vh 5vw; background: var(--bg); }
.contact-form-wrapper h3 { font-size: 20px; font-weight: 300; text-transform: uppercase; margin-bottom: 50px; letter-spacing: 0.05em; }

.arti-form { width: 100%; max-width: 700px; }
.arti-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin-bottom: 40px; }
.arti-form .form-group { margin-bottom: 40px; position: relative; }
.arti-form label { font-size: 10px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.15em; color: var(--text); opacity: 0.6; margin-bottom: 10px; display: block; }
.arti-form input[type="text"], .arti-form input[type="email"], .arti-form input[type="tel"], .arti-form select, .arti-form textarea { width: 100%; background: transparent; border: none; border-bottom: 1px solid var(--border); padding: 15px 0; font-family: var(--font-main); font-size: 15px; font-weight: 300; color: var(--text); border-radius: 0; outline: none; transition: all 0.3s ease; }
.arti-form input:focus, .arti-form select:focus, .arti-form textarea:focus { border-bottom-color: var(--accent); }
.arti-form .select-wrap { position: relative; }
.arti-form select { -webkit-appearance: none; -moz-appearance: none; appearance: none; cursor: pointer; padding-right: 30px; }
.arti-form .select-wrap::after { content: '▼'; position: absolute; right: 0; top: 15px; font-size: 10px; color: var(--text); pointer-events: none; opacity: 0.5; }
.arti-form textarea { resize: none; min-height: 120px; }
.arti-form .form-submit-wrap { margin-top: 50px; }
.arti-form input[type="submit"] { background-color: transparent; color: var(--text); font-family: var(--font-main); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.15em; padding: 16px 32px; border: 1px solid var(--text); cursor: pointer; transition: all 0.4s ease; border-radius: 0; display: inline-block; }
.arti-form input[type="submit"]:hover { background-color: var(--text); color: var(--bg); }
.wpcf7-response-output { font-size: 12px; font-weight: 400; text-transform: uppercase; letter-spacing: 0.1em; padding: 15px !important; margin-top: 30px !important; border-radius: 0 !important; border: 1px solid var(--border) !important; }
.wpcf7 form.sent .wpcf7-response-output { border-color: var(--accent) !important; color: var(--accent); }

/* =========================================
   FOOTER
========================================= */
footer { padding: 10vh 5vw 5vh; text-align: left; border-top: 1px solid var(--border); background: var(--bg); color: var(--text); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; margin-bottom: 10vh; }
.footer-title { font-size: 3vw; font-weight: 300; text-transform: uppercase; line-height: 1.1; }
.footer-links h5 { font-size: 10px; text-transform: uppercase; color: var(--accent); margin-bottom: 20px; letter-spacing: 0.2em; font-weight: 400; }
.footer-links a { display: block; font-size: 12px; font-weight: 400; color: #666; text-decoration: none; margin-bottom: 12px; text-transform: uppercase; transition: color 0.3s; letter-spacing: 0.05em; }
.footer-links a:hover { color: var(--text); }
.footer-bottom { border-top: 1px solid var(--border); padding-top: 40px; display: flex; justify-content: space-between; align-items: flex-end; }
.f-logo-small { font-size: 18px; font-weight: 300; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text); }
.f-logo-small span { color: var(--accent); }

/* =========================================
   PERFECT MOBILE RESPONSIVE
========================================= */
@media (max-width: 1024px) {
    .page-header h1 { font-size: 10vw; }
    .hero { grid-template-columns: 1fr; padding-top: 15vh; gap: 40px; }
    .hero-img-wrap { height: 50vh; }
    .hero-text h1 { font-size: 11vw; }
    .manifesto { grid-template-columns: 1fr; gap: 30px; }
    .manifesto h2 { font-size: 7vw; }
    .service-row { grid-template-columns: 1fr; gap: 15px; padding: 30px 0; }
    .s-title { font-size: 6vw; }
    
    .parallax-break { height: 50vh; background-attachment: scroll !important; } /* iOS scroll fix */
    .parallax-content h2 { font-size: 8vw; }
    .grand-cta h2 { font-size: 9vw; }

    .process-grid { grid-template-columns: 1fr 1fr; }
    .portfolio-grid { grid-template-columns: 1fr; gap: 40px; } 
    
    .project-meta { grid-template-columns: 1fr 1fr; }
    .meta-box { border-bottom: 1px solid var(--border); }
    .meta-box:nth-child(2n) { border-right: none; }
    .concept-section { grid-template-columns: 1fr; gap: 30px; }
    .gallery-grid { grid-template-columns: 1fr; }
    
    .service-block { grid-template-columns: 1fr; }
    .sb-text { border-right: none; border-bottom: 1px solid var(--border); padding: 8vh 5vw; }
    .sb-title { font-size: 8vw; }
    .sb-img-wrap { min-height: 50vh; }
    
    .about-hero { grid-template-columns: 1fr; padding-top: 15vh; }
    .about-title { font-size: 12vw; }
    .story-heading { font-size: 8vw; }
    .story-grid { grid-template-columns: 1fr; gap: 40px; }
    .value-row { grid-template-columns: 1fr; gap: 15px; padding: 6vh 5vw; }
    .v-title { font-size: 6vw; }
    
    .contact-page { grid-template-columns: 1fr !important; }
    .contact-info { border-right: none !important; border-bottom: 1px solid var(--border); padding-bottom: 10vh !important; }
    .arti-form .form-row { grid-template-columns: 1fr; gap: 0; margin-bottom: 0; }
    
    .footer-grid { grid-template-columns: 1fr; gap: 60px; }
    .footer-title { font-size: 7vw; }
    .section-title { font-size: 6vw; }
}

@media (max-width: 768px) {
    header { padding: 15px 5vw; }
    .nav-right { gap: 15px; }
    .menu-link span, .pill span { display: none; } 
    .menu-link i, .pill i { margin: 0; font-size: 22px; color: var(--text); }
    .lang-switcher { margin-right: 10px; }
    
    .hero-text h1 { font-size: 13vw; margin-bottom: 20px; }
    .hero-subtitle { font-size: 14px; margin-top: 20px; }
    .btn { padding: 14px 24px; font-size: 10px; }
    
    .manifesto h2 { font-size: 8vw; }
    .manifesto p { font-size: 15px; }
    
    .parallax-content h2 { font-size: 10vw; }
    .grand-cta h2 { font-size: 11vw; }

    .process-grid { grid-template-columns: 1fr; } 
    .process-item { padding: 30px 20px; }
    
    .footer-bottom { flex-direction: column; align-items: flex-start; gap: 20px; }
    .footer-bottom > div { text-align: left !important; }
}