/* ==========================================================================
   1. VÁLTOZÓK ÉS ALAP BEÁLLÍTÁSOK
   ========================================================================== */
:root {
    --text-dark: #0f0f0f;
    --background-paper: #fdfaf5;
    --accent-history: #8c3b3b;
    --accent-hungarian: #3b598c;
    --accent-kids: #b88655;
    --border-light: #d1c8b8;
 --font-heading: "Quicksand", sans-serif;
--font-body: "Quicksand", sans-serif;

    --text-muted: #383737;

      /* --- PIXEL-ALAPÚ REM BETŰMÉRETEK --- */
    /* 1rem = 16px (böngésző alapértelmezés), minimum 18px */
    --rem-13px: 1.125rem;   /* 18px (felskálázva 13→18) */
    --rem-14px: 1.125rem;   /* 18px (felskálázva 14→18) */
    --rem-15px: 1.125rem;   /* 18px (felskálázva 15→18) */
    --rem-16px: 1.125rem;   /* 18px (felskálázva 16→18) */
    --rem-18px: 1.125rem;   /* 18px */
    --rem-22px: 1.375rem;   /* 22px */
    --rem-26px: 1.625rem;   /* 26px */
    --rem-28px: 1.75rem;    /* 28px */
    --rem-38px: 2.375rem;   /* 38px */
    --rem-52px: 3.25rem;    /* 52px */
    --rem-56px: 3.5rem;     /* 56px */
}


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

html {
    scroll-behavior: smooth;
}

body {
    background-color: var(--background-paper);
    color: var(--text-dark);
    font-family: var(--font-body);
    line-height: 1.8;
    overflow-x: hidden;
    letter-spacing: 0.065em;
    font-weight: 500;
    text-align: left;
    hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    word-break: break-word;
}

/* Amikor a header megkapja a 'nav-open' osztályt, a benne lévő .main-nav láthatóvá válik */
header.nav-open .main-nav {
    display: flex; /* Flexboxot használunk a jobb igazításért */
    flex-direction: column; /* Az elemek egymás alá kerülnek */
    position: absolute;
    top: 100%; /* A fejléc aljától kezdődik */
    left: 0;
    right: 0;
    background-color: var(--background-paper);
    padding: 10px 0;
    border-top: 1px solid var(--border-light);
    box-shadow: 0 8px 15px rgba(0, 0, 0, 0.08);
    animation: slideDown 0.3s ease-out; /* Finom animáció */
}

/* A menüpontok stílusa a lenyílt menüben */
header.nav-open .main-nav a {
    padding: 15px 20px;
    margin-left: 0; /* Felülírjuk az asztali nézet margóját */
    text-align: center;
    border-bottom: 1px solid #f0ebe4;
    font-size: var(--rem-18px);
    font-family: inherit; /* Az alap betűtípus használata */
    color: inherit; /* A szöveg színének öröklése */
    text-transform: uppercase; /* Nagybetűsítés */
    font-weight: bold; /* Vastag betűtípus */
    font-weight: 700;
}

/* Utolsó menüpont: nincs alsó szegély */
header.nav-open .main-nav a:last-child {
    border-bottom: none;
}

/* Animáció a lenyíláshoz */
@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}


:focus-visible {
    outline: 3px solid var(--accent-history);
    outline-offset: 3px;
    border-radius: 4px;
}

.skip-link {
    position: absolute;
    top: -999px;
    left: 0;
    background: var(--accent-history);
    color: white;
    padding: 10px 20px;
    z-index: 9999;
    text-decoration: none;
    font-weight: bold;
    border-radius: 0 0 10px 0;
}

.skip-link:focus {
    top: 0;
}

/* ==========================================================================
   2. MOBIL ALAPSTÍLUSOK (MINDENRE ÉRVÉNYES)
   ========================================================================== */

/* --- ÁLTALÁNOS KONTÉNER --- */
.container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
}

/* --- FEJLÉC --- */
header {
    background: rgba(253, 250, 245, 0.98);
    backdrop-filter: blur(12px);
    position: sticky;
    top: 0;
    z-index: 100;
    padding: 12px 0;
    border-bottom: 1px solid var(--border-light);
    transition: all 0.3s ease;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.03);
}

header.scrolled {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

header .container {
    max-width: 100%;
    padding-left: 20px;
    padding-right: 20px;
}

.header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo,
.logohead {
    display: flex;
    align-items: center;
    text-decoration: none;
    padding: 5px 0;
    margin-bottom: 10px;
}

.logo img,
.logohead img {
    width: 50%;
    height: auto;
    transition: all 0.3s ease;
}

.logo img {
    max-width: 400px;
}

.logohead img {
    max-width: 80px;
}



.header-right {
    display: flex;
    align-items: center;
    gap: 15px;
}

.main-nav {
    display: none;
}

.mobile-menu-toggle {
    display: block;
    background: none;
    border: none;
    font-size: var(--rem-28px);
    cursor: pointer;
    padding: 5px;
    color: var(--text-dark);
}

.lang-switch {
    display: flex;
    gap: 5px;
    padding: 4px;
    border-radius: 8px;
    white-space: nowrap;
    flex-shrink: 1;
}

.lang-switch a {
    
    font-weight: 700;
    text-decoration: none;
    color: var(--text-muted);
    transition: all 0.3s ease;
    padding: 4px 8px;
    border-radius: 6px;
    font-size: clamp(0.88rem, 1.5vw, 1rem);
    padding: clamp(2px, 0.5vw, 6px) clamp(4px, 1vw, 10px);
}

.lang-switch a.active {
    color: var(--text-dark);
    background: white;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.lang-switch a:hover:not(.active) {
    color: var(--text-dark);
    background: rgba(255, 255, 255, 0.6);
}

/* --- FŐ ELRENDEZÉS --- */
.split-layout {
    display: block;
}

.sticky-visual-pane {
    display: none;
}

.scrollable-content-pane {
    width: 100%;
    padding: 0;
}

/* --- SZEKCIÓK ÁLTALÁBAN --- */
.section {
    padding: 60px 20px;
}

.section:first-child {
    padding-top: 40px;
}

.section-title {
    margin-bottom: 40px;
    text-align: center;
}

.section-title h2 {
    font-family: var(--font-heading);
    font-size: var(--rem-28px);
    font-weight: 600;
    margin-bottom: 15px;
}

.section-title p {
    font-size: var(--rem-16px);
    color: var(--text-dark);
}

/* --- HERO SZEKCIÓ --- */
.hero-content h1 {
    font-family: var(--font-heading);
    font-size: var(--rem-38px);
    font-weight: 600;
    margin-bottom: 20px;
    line-height: 1.2;
    opacity: 0;
    transform: translateY(20px);
    animation: fadeInUp 0.8s ease forwards;
}

.hero-content p {
    font-size: var(--rem-22px);
    margin-bottom: 30px;
    opacity: 0;
    transform: translateY(20px);
    animation: fadeInUp 0.8s ease 0.2s forwards;
}

.hero-content .btn {
    opacity: 0;
    transform: translateY(20px);
    animation: fadeInUp 0.8s ease 0.4s forwards;
    letter-spacing: 0.05em;  /* Betűköz 0.05em távolságra */
}

@keyframes fadeInUp {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.btn {
    background: var(--background-paper);
    color: var(--text-dark);
    padding: 16px 30px;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 700;
    font-size: var(--rem-16px);
    display: inline-block;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 4px 15px rgba(58, 53, 47, 0.2);
    position: relative;
    overflow: hidden;
    border: none;
    cursor: pointer;
    width: 100%;
    text-align: center;
}

.btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
    transition: left 0.5s;
}

.btn:hover::before {
    left: 100%;
}

.btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 25px rgba(140, 59, 59, 0.35);
}

.btn:active {
    transform: translateY(-1px);
    box-shadow: 0 4px 15px rgba(140, 59, 59, 0.25);
}

/* --- RÁCSOK ÉS KÁRTYÁK MOBILNÉZETBEN --- */
.programs-grid,
.method-grid,
.pricing-grid,
.contact-grid,
.footer-grid {
    display: block;
}

.program-card,
.method-item,
.price-card,
.contact-info,
.contact-form,
.footer-grid > div {
    margin-bottom: 30px;
}

/* --- PROGRAMOK KÁRTYA --- */
.program-card {
    background: white;
    padding: 35px 25px;
    border-radius: 16px;
    box-shadow: 0 5px 30px rgba(0, 0, 0, 0.06);
    transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    border-top: 5px solid transparent;
    opacity: 0;
    transform: translateY(40px);
    position: relative;
    overflow: hidden;
}

.program-card.visible {
    opacity: 1;
    transform: translateY(0);
}

.program-card:hover {
    transform: translateY(-12px) scale(1.02);
    box-shadow: 0 15px 50px rgba(0, 0, 0, 0.12);
}

.program-card.high-school { border-top-color: var(--accent-history); }
.program-card.elementary { border-top-color: var(--accent-kids); }

.program-card:hover .icon {
    transform: scale(1.15) rotate(5deg);
}

.program-card h3 {
    font-family: var(--font-heading);
    font-size: var(--rem-22px);
    margin-bottom: 12px;
    line-height: 1.3;
}

.program-card .age-badge {
    display: inline-block;
    background: linear-gradient(135deg, var(--border-light), #f5f0e8);
    padding: 6px 16px;
    border-radius: 25px;
    font-size: var(--rem-13px);
    font-weight: 700;
    margin-bottom: 18px;
    color: var(--text-dark);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.program-card p {
    font-size: var(--rem-16px);
    line-height: 1.8;
    margin-bottom: 25px;
    color: #6b6560;
}

.program-card ul { list-style: none; }
.program-card li {
    padding-left: 30px;
    position: relative;
    margin-bottom: 14px;
    font-size: var(--rem-15px);
    line-height: 1.6;
    transition: transform 0.2s ease;
}

.program-card li:hover {
    transform: translateX(5px);
}

.program-card li:hover::before {
    transform: scale(1.3);
}

/* --- MÓDSZERTAN KÁRTYA --- */
.method-grid {
    margin-top: 40px;
}

.method-item {
    text-align: center;
    padding: 40px 25px;
    opacity: 0;
    transform: translateY(30px);
    background: white;
    border-radius: 16px;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 3px 20px rgba(0, 0, 0, 0.04);
}

.method-item.visible {
    opacity: 1;
    transform: translateY(0);
}

.method-item:hover {
    transform: translateY(-8px);
    box-shadow: 0 8px 35px rgba(0, 0, 0, 0.1);
}

.method-item .icon {
    font-size: var(--rem-56px);
    margin-bottom: 20px;
    display: block;
    transition: all 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    filter: grayscale(0.3);
}

.method-item:hover .icon {
    transform: scale(1.2) rotate(-5deg);
    filter: grayscale(0);
}

.method-item h4 {
    font-family: var(--font-heading);
    font-size: var(--rem-22px);
    margin-bottom: 12px;
    color: var(--text-dark);
}

.method-item p {
    font-size: var(--rem-15px);
    color: #6b6560;
    line-height: 1.7;
}

/* --- ÁRAK KÁRTYA --- */
.pricing-grid {
    margin-top: 40px;
}

.price-card {
    background: white;
    padding: 40px 25px;
    border-radius: 20px;
    box-shadow: 0 5px 30px rgba(0, 0, 0, 0.06);
    text-align: center;
    transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    opacity: 0;
    transform: translateY(30px);
    position: relative;
    border: 2px solid transparent;
    display: flex;
    flex-direction: column;
}

.price-card.visible {
    opacity: 1;
    transform: translateY(0);
}

.price-card:hover {
    transform: translateY(-10px) scale(1.03);
    box-shadow: 0 15px 50px rgba(0, 0, 0, 0.15);
}

.price-card .price {
    font-size: var(--rem-26px);
    font-weight: 700;
    background: linear-gradient(135deg, var(--accent-history), var(--accent-hungarian));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 12px;
    line-height: 1.2;
    overflow-wrap: break-word;
}

.price-card .period {
    font-size: var(--rem-16px);
    color: var(--text-muted);
    margin-bottom: 30px;
    font-weight: 500;
}

.price-card ul {
    list-style: none;
    margin-bottom: 35px;
    text-align: left;
    flex-grow: 1;
}

.price-card li {
    padding-left: 30px;
    position: relative;
    margin-bottom: 15px;
    font-size: var(--rem-15px);
    line-height: 1.6;
}

/* --- LISTA PIPÁK --- */
.program-card li::before,
.price-card li::before {
    content: '✓' / "";
    position: absolute;
    left: 0;
    font-weight: 700;
    font-size: var(--rem-18px);
    transition: transform 0.2s ease;
}
.program-card.high-school li::before { color: var(--accent-history); }
.program-card.elementary li::before { color: var(--accent-kids); }
.price-card li::before { color: var(--accent-history); }

/* --- IKONOK --- */
.program-card .icon,
.method-item .icon,
.contact-item .icon {
    display: inline-block;
    font-style: normal;
}
.program-card.high-school .icon::before { content: '🎓' / ""; display: block; }
.program-card.elementary .icon::before { content: '🌱' / ""; display: block; }
.method-grid .method-item:nth-child(1) .icon::before { content: '🎯' / ""; }
.method-grid .method-item:nth-child(2) .icon::before { content: '💡' / ""; }
.method-grid .method-item:nth-child(3) .icon::before { content: '📚' / ""; }
.method-grid .method-item:nth-child(4) .icon::before { content: '🤝' / ""; }
.contact-item:nth-of-type(1) .icon::before { content: '📧' / ""; }
.contact-item:nth-of-type(2) .icon::before { content: '📍' / ""; }
.contact-item:nth-of-type(3) .icon::before { content: '⏰' / ""; }

/* --- .contact-item:nth-of-type(2) .icon::before { content: '📱' / ""; } --- */

/* --- KAPCSOLAT SZEKCIÓ --- */
.contact-grid {
    margin-top: 40px;
}

.contact-info h3 {
    font-family: var(--font-heading);
    font-size: var(--rem-26px);
    margin-bottom: 30px;
}

.contact-item {
    margin-bottom: 30px;
    padding: 20px;
    background: white;
    border-radius: 12px;
    transition: all 0.3s ease;
    border-left: 4px solid transparent;
}

.contact-item:hover {
    background: #fff;
    border-left-color: var(--accent-history);
    transform: translateX(5px);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

.contact-item strong {
    display: block;
    margin-bottom: 8px;
    font-weight: 700;
    font-size: var(--rem-16px);
}

.contact-item a {
    color: var(--text-dark);
    text-decoration: underline;
    transition: color 0.3s ease;
    font-size: var(--rem-16px);
}

.contact-item a:hover {
    color: var(--accent-history);
}

.contact-form {
    background: white;
    padding: 40px 25px;
    border-radius: 20px;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.1);
}

.contact-form h3 {
    font-family: var(--font-heading);
    font-size: var(--rem-26px);
    margin-bottom: 30px;
}

.form-group {
    margin-bottom: 25px;
}

.form-group label {
    display: block;
    margin-bottom: 10px;
    font-weight: 700;
    font-size: var(--rem-14px);
    letter-spacing: 0.3px;
}

.form-group input,
.form-group textarea,
.form-group select {
    width: 100%;
    padding: 14px 18px;
    border: 2px solid var(--border-light);
    border-radius: 10px;
    font-family: var(--font-body);
    font-size: var(--rem-15px);
    transition: all 0.3s ease;
    background: #fdfaf5;
    color: var(--text-dark);
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: var(--accent-history);
    background: white;
    box-shadow: 0 0 0 4px rgba(140, 59, 59, 0.1);
}

.form-group textarea {
    resize: vertical;
    min-height: 130px;
}

.contact-form .btn {
    width: 100%;
    margin-top: 10px;
}

/* --- LÁBLÉC --- */
footer {
  border-top: 1px solid #131110; /* Unified border style */
  background-color: var(--background-paper); /* Ensure the background is set */
  color: var(--text-dark); /* Replace with the desired text color */
  padding: 60px 20px 30px 20px;
 
}

.footer-grid {
    margin-bottom: 40px;
}

.footer-about h3 {
    font-family: var(--font-heading);
    font-size: var(--rem-22px);
    margin-bottom: 18px;
}

.footer-about p {
    font-size: var(--rem-15px);
    line-height: 1.8;
    color: var(--text-dark)
}

/* A címsort megtartjuk, de érdemes középre igazítani, ha vízszintes a lista */
.footer-links h4 {
    font-family: var(--font-heading);
    font-size: var(--rem-18px);
    margin-bottom: 20px;
    font-weight: 600;
    text-align: center; /* Hozzáadva: középre igazítás */
}

/* a listát rugalmas sorrá alakítjuk */
.footer-links ul { 
    list-style: none; 
    padding-left: 0;
    display: flex;             /* Hozzáadva: sorba rendezi az elemeket */
    flex-direction: row;       /* Hozzáadva: vízszintes irány */
    justify-content: center;   /* Hozzáadva: középre igazítja a linkeket */
    flex-wrap: wrap;           /* Hozzáadva: ha nem fér el mobilon, törjön több sorba */
    gap: 20px;                 /* Hozzáadva: távolság a linkek között */
}

/* A korábbi margin-bottom-ot (alsó hely) töröljük, mert már nem egymás alatt vannak */
.footer-links li { 
    margin-bottom: 0;          /* Módosítva: 12px-ről 0-ra */
}

.footer-links a {
    color: var(--text-dark);
    text-decoration: none;
    font-size: var(--rem-14px);
    transition: all 0.3s ease;
    display: inline-block;     /* Fontos az animáció (translateX) miatt */
}

.footer-links a:hover {
    color: var(--background-paper);
    /* Megtartva a kért elmozdulás, de vízszintes listánál 
       érdemesebb lehet translateY(-3px)-re cserélni, hogy felfelé mozogjon */
    transform: translateX(5px); 
}

.footer-bottom {
    border-top: 1px solid rgba(253, 250, 245, 0.15);
    padding-top: 25px;
    text-align: center;
    font-size: var(--rem-14px);
    color: rgba(253, 250, 245, 0.6);
}

/* --- EGYÉB / MISC --- */
.gpu-accelerated {
    will-change: transform, opacity;
    transform: translateZ(0);
}

.scrolling-fast #thread-canvas-svg {
    opacity: 0.7;
    transition: opacity 0.3s ease;
}

.scroll-indicator {
    display: none; /* Mobilon nem jelenik meg */
}

/* ==========================================================================
   3. TABLET NÉZET (768px-től)
   ========================================================================== */
@media (min-width: 768px) {
    .btn {
        width: auto;
    }

    /* --- RÁCSOK BEKAPCSOLÁSA --- */
    .programs-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 40px;
        margin-top: 60px;
    }

    .method-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 40px;
    }

    .pricing-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 30px;
    }

    .contact-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 50px;
    }

    .footer-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 40px;
        text-align: left;
        margin-bottom: 50px;
    }

    /* --- BETŰMÉRETEK ÉS TÉRKÖZÖK NÖVELÉSE --- */
    .section {
        padding: 80px 40px;
    }

    .section-title h2 {
        font-size: var(--rem-38px);
    }

    .hero-content h1 {
        font-size: var(--rem-52px);
    }

    .contact-item a {
        font-size: var(--rem-16px);
    }

    .program-card h3 { font-size: var(--rem-26px); }
    .contact-info h3, .contact-form h3 { font-size: var(--rem-28px); }
    .footer-about h3 { font-size: var(--rem-26px); }
}

/* ==========================================================================
   4. DESKTOP NÉZET (1100px-től)
   ========================================================================== */
@media (min-width: 1100px) {
    /* --- FEJLÉC --- */
    header {
        padding: 18px 0;
    }
    header.scrolled {
        padding: 12px 0;
    }
    header .container {
        padding-left: 40px;
        padding-right: 40px;
    }
    .logo img {
        height: 70px;
    }
    header.scrolled .logo img {
        height: 50px;
    }
    .header-right {
        gap: 45px;
    }
    .mobile-menu-toggle {
        display: none;
    }
    .main-nav {
        display: flex;
        align-items: center;
    }
    .main-nav a {
        font-size: var(--rem-18px);
        text-decoration: none;
        color: var(--text-dark);
        margin-left: 30px;
        transition: all 0.3s ease;
        position: relative;
        font-weight: 520;
        padding: 8px 0;
        
    }
    .main-nav a::after { content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 0; height: 2px; background: var(--accent-history); transition: width 0.3s ease; }
    .main-nav a:hover::after {
        width: 100%;
    }
    .main-nav a:hover {
        color: var(--accent-history);
    }

    /* --- FŐ ELRENDEZÉS VISSZAÁLLÍTÁSA --- */
    .split-layout {
        display: flex;
    }
    .sticky-visual-pane {
        display: block;
        width: 35%;
        height: 100vh;
        position: sticky;
        top: 0;
        border-right: 1px solid var(--border-light);
        overflow: hidden;
        background: linear-gradient(135deg, var(--background-paper) 0%, rgba(253, 250, 245, 0.95) 100%);
    }
    #thread-canvas-svg {
        width: 100%;
        height: 100%;
    }
    .scrollable-content-pane {
        width: 65%;
        padding: 0 5%;
    }
    .section {
        padding: 40px 0;
    }
    .section:first-child {
        padding-top: 80px;
    }

    /* --- RÁCSOK FINOMHANGOLÁSA DESKTOPRA --- */
    .programs-grid {
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 50px;
    }
    .pricing-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: clamp(20px, 2vw, 40px);
    }
    .contact-grid {
        grid-template-columns: 1fr 1fr;
        gap: 70px;
    }
    .footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: 50px;
    }
    .form-group input,
    .form-group textarea,
    .form-group select {
        width: 100%;
    }

    /* --- SCROLL INDICATOR --- */
    .scroll-indicator {
        display: block;
        position: absolute;
        bottom: 30px;
        left: 50%;
        transform: translateX(-50%);
        opacity: 0;
        animation: fadeIn 1s ease 1s forwards, bounce 2s ease-in-out 2s infinite;
    }
    .scroll-indicator svg {
        width: 24px;
        height: 24px;
        fill: var(--text-dark);
    }
    @keyframes fadeIn { to { opacity: 0.6; } }
    @keyframes bounce {
        0%, 100% { transform: translateX(-50%) translateY(0); }
        50% { transform: translateX(-50%) translateY(10px); }
    }
}

button, input, select, textarea {
    font-family: inherit;
}